Webview.loadDataWithBaseURL

问题原因:由于4.4浏览器不兼容,因为这里列出了二个样式来适应不同的浏览器版本

第一种加载:mWebView.loadUrl("file:///android_asset/chart_top01.html");
这种加载方式,会出现问题,那么采用第二种加载:
说明:这种方式是字符串的加载形式,直接给文件的地址会出现错误,因此需要把上面本地文件读出来,然后采用下面的加载方式:

webView.loadDataWithBaseURL("about:blank",bodyBuffer.toString(),"text/html", "utf-8",null);
读取assets文件的方法:这里可以读取HTML文件:
/**
 * 资产文件帮助类
 */
public class AssetsUtil {

	// 从assets 文件夹中获取文件并读取数据
	public static String getFromAssets(Context context, String fileName) {
		String result = "";
		try {
			InputStream in = context.getResources().getAssets().open(fileName);
			// 获取文件的字节数
			int lenght = in.available();
			// 创建byte数组
			byte[] buffer = new byte[lenght];
			// 将文件中的数据读到byte数组中
			in.read(buffer);
			result = EncodingUtils.getString(buffer, "UTF-8");
		} catch (Exception e) {
			e.printStackTrace();
		}
		return result;
	}

}

将上面读取的字符串二次加载:
这样能完成网页的二次添加样式,从而去掉4.4的BUG
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		mWebView = (WebView) findViewById(R.id.webview);

		WebViewUtils.setting(mWebView);

		// mWebView.loadUrl("file:///android_asset/chart_top01.html");
		// mWebView.loadDataWithBaseURL("about:blank",
		// "APK'>file:///android_asset/chart_top01.html", "text/html",
		// "utf-8",null);
		// String data =
		// "<HTML>在模拟器 2.1 上测试,这是<IMG src=\"APK'>file:///android_asset/igg.jpg\"/>APK里的图片";

		// webView.loadDataWithBaseURL("about:blank",bodyBuffer.toString(),
		// "text/html", "utf-8",null);
		String data = getFromAssets("chart_top01.html");

		int currentapiVersion = android.os.Build.VERSION.SDK_INT;
		Log.i("fuck", currentapiVersion + "");
		if (currentapiVersion >= 19) {
			data += "<link rel=\"stylesheet\" type=\"text/css\" href=\"product_survey.css\" />";
			mWebView.loadDataWithBaseURL("file:///android_asset/product_survey.css", data, "text/html", "utf-8", null);
		} else {
			data += "<link rel=\"stylesheet\" type=\"text/css\" href=\"product_survey2.css\" />";
			mWebView.loadDataWithBaseURL("file:///android_asset/product_survey2.css", data, "text/html", "utf-8", null);
		}

	}

### Navicat 数据传输错误解决方案 当使用Navicat进行数据传输时,如果遇到了特定类型的错误,可以通过调整配置参数来解决问题。对于错误 `[Err] 1153 - Got a packet bigger than 'max_allowed_packet' bytes` ,这通常是由于尝试发送的数据包大小超过了 MySQL 配置中的 `max_allowed_packet` 参数所允许的最大值所致[^1]。 为了修正这个问题,在服务器端或客户端增加 `max_allowed_packet` 的数值是一个有效的办法。具体来说: - **修改MySQL配置文件**:编辑 MySQL 的配置文件(my.cnf 或 my.ini),找到 `[mysqld]` 和 `[client]` 节点下添加或更改如下行: ```ini max_allowed_packet=64M ``` - **通过SQL语句临时设置**:也可以登录到 MySQL 控制台并通过 SQL 命令动态改变此变量的值而不重启服务 ```sql SET GLOBAL max_allowed_packet=67108864; ``` 另外,在处理大规模数据迁移项目时,比如从 Oracle 到 MySQL 的转换过程,利用 Navicat 自带的数据传输功能可以简化工作流程。按照官方指南完成相应步骤后,记得在选项中启用“遇到错误时继续”的开关以便于忽略非致命性的警告信息并持续执行后续任务[^2]。 对于权限认证类别的问题,如 `1045 (28000): Access denied for user` 错误,则可能是因为用户名/密码不匹配或者是账户被锁定等原因引起。此时建议先验证输入凭证无误后再考虑重设 root 密码或是运行安全配置向导 (`mysql_secure_installation`) 来加强安全性的同时解锁受限账号[^4]。 最后值得注意的是,当仅需获取表结构而不需要实际记录时,可以在 Navicat 中选择只导出DDL语句的方式来进行操作,从而减少不必要的资源消耗和潜在的风险[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值