j2me中的page编码转化
来源:互联网 发布:女孩子英文名知乎 编辑:程序博客网 时间:2024/05/29 18:55
(源自:http://www.matrix.org.cn/resource/article/2006-01-16/j2me_44154.html)
j2me中的page编码转化
cleverpig 发表于 2006-01-16 01:06:06作者:cleverpig 来源:Matrix
评论数:1 点击数:2,163 投票总得分:13 投票总人次:3
关键字:页面,编码,乱码
摘要:
根据xinshouj2me在j2me版提出的httpconnection网络连接的问题,本人分析了一下:由于www.163.com上的页面编码为gb2312,所以使用utf8读取由于编码方式不同会得到乱码。于是本人根据page的编码灵活进行编码转化,在此与大家共享、讨论。工具箱
本站收藏美味书签
投票评分
发表评论
复制链接
版权声明:任何获得Matrix授权的网站,转载时请务必保留以下作者信息和链接
作者:cleverpig(作者的Blog:http://blog.matrix.org.cn/page/cleverpig)
原文:http://www.matrix.org.cn/resource/article/44/44154_j2me.html
关键字:j2me,页面,编码,乱码
一、摘要
根据xinshouj2me在j2me版提出的“httpconnection网络连接的问题”,本人分析了一下:由于www.163.com上的页面编码为gb2312,所以使用utf8读取由于编码方式不同会得到乱码。于是本人根据page的编码灵活进行编码转化,在此与大家共享、讨论。
二、代码分析
1.HttpConnectionHandler接口类
最好根据page的编码灵活进行编码转化,于是本人定义了一个HttpConnectionHandler接口类:
HttpConnectionHandler.java
2.HTML_HttpConnectionHandlerImpl类
根据HttpConnectionHandler接口规范实现了该接口——HTML_HttpConnectionHandlerImpl类。
HTML_HttpConnectionHandlerImpl.java
上面实现类中根据page中的实际编码类型对html字符串进行了编码转化,这样就实现了page编码的灵活转化。
虽然灵活性加强了,但是对于内存的占用也随之增加了一倍。
三.测试代码
更多问题,请到Matrix J2me版讨论
作者:cleverpig(作者的Blog:http://blog.matrix.org.cn/page/cleverpig)
原文:http://www.matrix.org.cn/resource/article/44/44154_j2me.html
关键字:j2me,页面,编码,乱码
一、摘要
根据xinshouj2me在j2me版提出的“httpconnection网络连接的问题”,本人分析了一下:由于www.163.com上的页面编码为gb2312,所以使用utf8读取由于编码方式不同会得到乱码。于是本人根据page的编码灵活进行编码转化,在此与大家共享、讨论。
二、代码分析
1.HttpConnectionHandler接口类
最好根据page的编码灵活进行编码转化,于是本人定义了一个HttpConnectionHandler接口类:
HttpConnectionHandler.java
package com.bjinfotech.practice.j2me.httpConnection;
import java.util.Hashtable;
import javax.microedition.io.HttpConnection;
/**
* Http连接处理器接口
* @author cleverpig
*
*/
public interface HttpConnectionHandler {
//http请求常量
public static final String RQH_HOST="X-Online-Host";
public static final String RQH_ACCEPT="Accept";
public static final String RQH_CONTENT_LANGUAGE="Content-Language";
public static final String RQH_CONTENT_TYPE="Content-Type";
public static final String RQH_CONNECTION_OPTION="Connection";
//http回应常量
public static final String RSH_DATE="Date";
public static final String RSH_SERVER="Server";
public static final String RSH_MODIFIEDDATE="Last-Modified";
public static final String RSH_CONTENT_ENCODING="Content-Encoding";
public static final String RSH_CONTENT_LENGTH="Content-Length";
public static final String RSH_CONTENT_TYPE="Content-Type";
public boolean putRequestHeaderProperty(
HttpConnection conn,
String key,
String keyValue);
public String getResponseHeaderProperty(
HttpConnection conn,
String key);
public boolean setRequestMethod(
HttpConnection conn,
String methodName);
public boolean putRequestHeader(
HttpConnection conn,
Hashtable propertiesPair);
public Hashtable getResponseHeader(
HttpConnection conn,
String[] propertyNames);
public boolean sendRequestData(
HttpConnection conn,
Object sendData);
public Object getResponseData(HttpConnection conn);
}
2.HTML_HttpConnectionHandlerImpl类
根据HttpConnectionHandler接口规范实现了该接口——HTML_HttpConnectionHandlerImpl类。
HTML_HttpConnectionHandlerImpl.java
package com.bjinfotech.practice.j2me.httpConnection;
import java.io.DataOutputStream;
import java.io.DataInputStream;
import java.util.Hashtable;
import java.util.Vector;
import java.util.Enumeration;
import javax.microedition.io.HttpConnection;
/**
* http连接处理器实现
* @author cleverpig
*
*/
public class HTML_HttpConnectionHandlerImpl implements HttpConnectionHandler{
private String message="";
public HTML_HttpConnectionHandlerImpl(){
}
public boolean putRequestHeaderProperty(
HttpConnection conn,
String key,
String keyValue){
message="";
try{
conn.setRequestProperty(key,keyValue);
return true;
}
catch(Exception ex){
message=ex.getMessage();
}
return false;
}
public String getResponseHeaderProperty(
HttpConnection conn,
String key){
return conn.getRequestProperty(key);
}
public boolean putRequestHeader(
HttpConnection conn,
Hashtable propertiesPair){
Enumeration keyEnumer=propertiesPair.keys();
boolean result=true;
while(keyEnumer.hasMoreElements()){
String keyName=(String)keyEnumer.nextElement();
String keyValue=(String)propertiesPair.get(keyName);
if (putRequestHeaderProperty(conn,keyName,keyValue)==false){
result=false;
}
}
return result;
}
public boolean setRequestMethod(
HttpConnection conn,
String methodName){
message="";
try{
conn.setRequestMethod(methodName);
return true;
}
catch(Exception ex){
message=ex.getMessage();
return false;
}
}
public Hashtable getResponseHeader(
HttpConnection conn,
String[] propertyNames){
Hashtable result=new Hashtable();
for(int i=0;i<propertyNames.length;i++){
String keyValue=conn.getRequestProperty(propertyNames[i]);
result.put(propertyNames[i],keyValue);
}
return result;
}
public boolean sendRequestData(
HttpConnection conn,
Object sendData){
message="";
try{
DataOutputStream os=conn.openDataOutputStream();
os.writeUTF((String)(sendData));
os.flush();
return true;
}
catch(Exception ex){
message=ex.getMessage();
return false;
}
}
public Object getResponseData(HttpConnection conn){
DataInputStream is=null;
message="";
try{
is=conn.openDataInputStream();
}
catch(Exception ex){
message=ex.getMessage();
return null;
}
byte[] data=null;
String type=getResponseHeaderProperty(conn,RSH_CONTENT_TYPE);
int len = 0;
try{
len=Integer.parseInt(getResponseHeaderProperty(conn,RSH_CONTENT_LENGTH));
}
catch(Exception ex){
len=0;
}
if (len > 0) {
int actual = 0;
int bytesread = 0 ;
data = new byte[len];
while ((bytesread != len) && (actual != -1)) {
try{
actual = is.read(data, bytesread, len - bytesread);
bytesread += actual;
}
catch(Exception ex){
message=ex.getMessage();
return null;
}
}
} else {
int ch;
Vector vbuffer=new Vector();
try{
while ((ch = is.read()) != -1) {
vbuffer.addElement(new Integer(ch));
}
}
catch(Exception ex){
message=ex.getMessage();
return null;
}
len=vbuffer.size();
data = new byte[len];
for(int i=0;i<len;i++){
data[i]=((Integer)vbuffer.elementAt(i)).byteValue();
}
}
String result=new String(data);
int flagBeginPosition=result.indexOf("charset=");
int flagEndPosition=result.indexOf("/">",flagBeginPosition);
if (flagEndPosition>flagBeginPosition){
type=result.substring(flagBeginPosition+"charset=".length(),flagEndPosition);
}
System.out.println("获得html字符集:"+type);
if (type!=null){
try{
result=new String(data,type);
}
catch(Exception ex){
message=ex.getMessage();
}
}
return result;
}
public String getMessage(){
return message;
}
}
上面实现类中根据page中的实际编码类型对html字符串进行了编码转化,这样就实现了page编码的灵活转化。
虽然灵活性加强了,但是对于内存的占用也随之增加了一倍。
三.测试代码
package com.bjinfotech.practice.j2me.httpConnection;
import javax.microedition.midlet.MIDlet;
import javax.microedition.midlet.MIDletStateChangeException;
import javax.microedition.io.HttpConnection;
import javax.microedition.io.Connector;
import java.util.Hashtable;
public class HttpConnectionMIDlet extends MIDlet {
public HttpConnectionMIDlet() {
super();
}
protected void startApp() throws MIDletStateChangeException {
HTML_HttpConnectionHandlerImpl handler=new HTML_HttpConnectionHandlerImpl();
try{
String host="10.11.3.99";
String url="http://10.11.3.99:8080/test_gbk.html";
// String url="http://10.11.3.99:8080/test_gb2312.html";
// String url="http://10.11.3.99:8080/test_utf8.html";
HttpConnection conn=(HttpConnection)Connector.open(url);
if (conn.getResponseCode()==HttpConnection.HTTP_OK){
System.out.println("建立连接成功");
Hashtable requestHeaderPair=new Hashtable();
requestHeaderPair.put(
HTML_HttpConnectionHandlerImpl.RQH_HOST,
host);
requestHeaderPair.put(
HTML_HttpConnectionHandlerImpl.RQH_CONTENT_TYPE,
"application/octet-stream");
requestHeaderPair.put(
HTML_HttpConnectionHandlerImpl.RQH_CONTENT_LANGUAGE,
"en-US");
requestHeaderPair.put(
HTML_HttpConnectionHandlerImpl.RQH_ACCEPT,
"application/octet-stream");
requestHeaderPair.put(
HTML_HttpConnectionHandlerImpl.RQH_CONNECTION_OPTION,
"Keep-Alive");
handler.putRequestHeader(conn,requestHeaderPair);
handler.setRequestMethod(conn,HttpConnection.GET);
handler.sendRequestData(conn,"GET / HTTP/1.1");
if (conn.getResponseCode()==HttpConnection.HTTP_OK){
System.out.println("发送请求成功");
System.out.println("获得回应数据");
String reponseData=(String)handler.getResponseData(conn);
System.out.println(reponseData);
}
else{
System.out.println("发送请求失败");
System.out.println("错误信息:"+handler.getMessage());
}
}
else{
System.out.println("建立连接失败");
}
}
catch(Exception ex){
System.out.println("错误信息:"+handler.getMessage());
ex.printStackTrace();
}
}
protected void pauseApp() {
}
protected void destroyApp(boolean arg0) throws MIDletStateChangeException {
}
}
更多问题,请到Matrix J2me版讨论
本页页面地址:
投票评分(记入本贴作者的专家分)
非常好 还行 一般 扔鸡蛋 投票总得分: / 投票总人次:用户评论列表
#0000 author: 000 submitTime: 2006-00-00 12:59
#1 评论作者: cleverpig 发表时间: 2006-01-16 12:28 下午
呵呵,可以对上面的代码作优化!
对于在HTML_HttpConnectionHandlerImpl类中的getResponseData(HttpConnection conn)方法,可在取出charset字符串的部分作优化处理:
public Object getResponseData(HttpConnection conn){
....
//优化前新开辟了等同于data数组大小的字符串空间
//String result=new String(data);
//优化后只开辟100字节的字符串空间(假设100为charset字符集声明存在的范围)
String result=new String(data,0,100);
int flagBeginPosition=result.indexOf("charset=");
int flagEndPosition=result.indexOf("/">",flagBeginPosition);
if (flagEndPosition>flagBeginPosition){
type=result.substring(flagBeginPosition+"charset=".length(),flagEndPosition);
}
....
}
- j2me中的page编码转化
- c#中的编码转化
- libiconv Qt中的各种字符编码转化
- J2ME中访问网页对Url中的中文进行编码
- UE编码转化图以及 VS2013中的代码页设置
- J2ME中文编码问题
- j2me的Base64编码
- J2ME中文编码问题
- J2ME中文编码问题
- 编码转化的问题
- 字符编码转化
- 编码转化问题
- 编码的转化
- Base64编码转化
- C++编码转化
- linux 转化文件编码
- win32 编码转化函数
- webkit 编码格式转化
- 一步一步循序渐进学习TP三(新手篇)
- 微软软件测试基础
- j2me常用的字符,日期,以及转换编码实现
- Flex视频学习网址
- 开源网站
- j2me中的page编码转化
- J2ME读取本地文本文件(ANSI,Unicode,Unicode big endian,UTF-8编码)
- F#入门-第三章 功能性-第三节 高阶函数(fold)
- 怪事
- J2ME读取WEB服务器上的文本文件
- 在asp中,由汉字转成拼音的代码
- 用友、金蝶、神州数码ERP的优势、劣势?
- 又到纠结时
- 基于 RFT 和 STAF 进行的无需人工干预的跨平台自动化回归测试