Android WebView彻底解决乱码问题!

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

Android WebView 彻底解决乱码问题!

最近做WebView加载本地html,发现了网上说的utf-8乱码的问题。解决也很简单,这里有篇很不错的文章写的很详细。偷懒拿来借鉴~!主要三个方法的选择,我这里建议如果直接显示网络URL使用第一个,如果加载本地html使用第三个(第一个会有乱码问题)

在网上看了许多关于WebView 的例子。但当自己做起来时,总是有些差别,是另一种体会。这节我就以模拟器为2.1 为例来讲。

WebView 主要调用三个方法:LoadUrl、LoadData、LoadDataWithBaseURL。

1、LoadUrl 直接加载网页、图片并显示。(本地或是网络上的网页、图片、gif)

2、LoadData 显示文字与图片内容(模拟器1.5、1.6)

3、LoadDataWithBase 显示文字与图片内容(支持多个模拟器版本)

下面来看看代码片段:

Java代码

package com.webviewd emo;

import .URLEncod er;

import android.app.Activity;

import android.os.Bundl e;

import android.webkit.WebView;

public class WebViewDemo extends Activity {

private WebView MyWebView;

static final String mimeType = "text/html";

static final String encoding = "utf-8";

/** Call ed when the activity is first created. */

@Overrid e

public void onCreate(Bundl e savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(yout.main);

//

MyWebView = (WebView) findViewById(R.id.MyWebview);

// this.webHtml();

// this.webImage();

// this.l ocalHtmlZh();

// this.l ocalImage();

// this.l ocalHtml();

this.l ocalHtmlImage();

}

/**

* 直接网页显示

*/

private void webHtml() {

try {

MyWebView.l oadUrl("http://www.googl ");

} catch (Exception ex) {

ex.printStackTrace();

}

}

/**

* 直接网络图片显示

*/

private void webImage() {

try {

MyWebView .l oadUrl("http://www.googl /intl/zh-CN/images/l ogo_cn.gif");

} catch (Exception ex) {

ex.printStackTrace();

}

}

/**

* 中文显示

*/

private void l ocalHtmlZh() {

try {

String data = "在模拟器2.1 上测试";

// utf-8编码处理(在SDK1.5模拟器和真实设备上都将出现乱码,SDK1.6上能正常显示) // MyWebView.l oadData(data, mimeType, encoding);

// 对数据进行编码处理(SDK1.5版本)

MyWebView.l oadData(URLEncoder.encod e(data, encoding), mimeType, encoding);

// MyWebView.l oadDataWithBaseURL(null, data, mimeType, encoding, null);

} catch (Exception ex) {

ex.printStackTrace();

}

}

/**

* 显示本地图片文件

*/

private void l ocalImage() {

try {

// 本地文件处理

String str = "fil e:///android_asset/icon.png";

MyWebView.l oadUrl(str);

} catch (Exception ex) {

ex.printStackTrace();

}

}

/**

* 显示本地网页文件

*/

private void l ocalHtml() {

try {

// 本地文件处理(如果文件名中有空格需要用+来替代)

MyWebView.l oadUrl("fil e:///android_asset/test.html");

} catch (Exception ex) {

ex.printStackTrace();

}

}

/**

* 显示本地图片和文字混合的Html内容

*/

private void l ocalHtmlImage() {

try {

String data = "在模拟器2.1 上测试,这是

src=\"APK'>fil e:///android_asset/igg.jpg\"/>APK里的图片";

// SDK1.5本地文件处理(不能显示图片)

//MyWebView.l oadData(URLEncoder.encod e(data, encoding), mimeType, encoding);

// SDK1.6及以后版本

//MyWebView.l oadData(data, mimeType, encoding);

// 本地文件处理(能显示图片)

MyWebView.l oadDataWithBaseURL(null, data, mimeType, encoding, null);

} catch (Exception ex) {

ex.printStackTrace();

}

}

}

在上面的所有方法中,模拟器2.1下调用LoadData 方法总是出现乱码。我想应该是2.1已经不在用它了吧。直接用LoadDataWithBaseURL 方法最简单,不再牵涉编码的转换。

记住:显示本地文件时必须使用APK'>fil e:/// 作为前缀。

来源:清源教育

相关文档
最新文档