您的位置:首页 > 理论基础 > 计算机网络

使用J2me网络编程访问网页内容--转载哦~~

2009-09-20 15:08 190 查看
一、请求与响应的格式


我们非常需要关注请求与响应格式的一至性,比如:客户端使用:

HttpConnection c = (HttpConnection)Connector.open
(urlStr
);

c.setRequestProperty("Content-Type", "application/xhtml+xml

")

表明自己识别的是:
application/xhtml+xml
类型的格式,服务器在传输时请按照相应格式给我组织响应的
byte[]
流;

那么服务器最好按照客户端要求的格式来响应;

这叫配套,如果请求和响应不配套就会出现很多怪问题,比如丢字,乱码等;

至于配套的格式都有多少种,在网络上可以查到,我就不一一列举了,下面是一个关于
Content-Type
说明的地址:

http://cocp.blogdriver.com/cocp/1221254.html

这个地址不知道会开放多久,如果访问不到,就在
Google
上查
”Content-Type”
即可

二、使用网关代理


如果我们只能通过中国移动的
cmwap
接入点访问网站页面(
cmwap
接入点也是移动梦网的网关)或者我们要访问位于移动梦网内的页面,那么我们就必须指定用于访问这些页面的代码网关:
10.0.0
.172:80

下面的例子表明了如何使用中国移动的代理网关;

例一:通过

URL

拆分的方法使用代理网关


Boolean UseAgent=true;

if (!UseAgent) {

c = (HttpConnection) Connector.open("http://" + “www.sina.com” + “
/webui/index.html
”, Connector.READ_WRITE, true);

} else {

c = (HttpConnection) Connector.open("http://10.0.0.172:80/"

+ “
/webui/index.html
”, Connector.READ, true);

c.setRequestProperty("X-Online-Host", “www.sina.com”);

}

之所以这样来写
url
,是为了方便大家看清楚在使用代理网关时如何进行
url
的拆分;

例二:不拆分

URL

,直接使用代理网关


Boolean UseAgent=true;

if (!UseAgent) {

c=(HttpConnection)Connector.open
(
urlStr
);

} else {

c=(HttpConnection)Connector.open
("http://10.0.0.172:80/"+
urlStr
);

c.setRequestProperty("X-Online-Host",
urlStr
);

c.setRequestProperty("Accept","*/*");

}

那两种方式有何区别?

例一的方式是标准的写法,但是用这种方法访问移动梦网内的网页会有问题:无法得到正确的网页;这时候就要用第二种方法了。第一种方法能做的事情,第二种方法似乎都能做到,至少我还没有遇见过反例。

至于这是为什么?我也不知道,知道的大仙如果感兴趣请回贴说明一下吧,小神在此先谢过。

关于
cmnet

cmwap
,读者可以在
google
上查

活猴工作室

,这哥们是
CTO
,他的
blog
上有一些非常不错的文章;

三、读取服务器响应的内容:


我们通常用以下几种方式读取服务器端响应的内容:

例一:按指定编码逐字符读取


int

ch=0;

StringBuffer

sb = new StringBuffer
();

InputStreamReader

isr = new InputStreamReader
(dis,"utf-8");

try

{

while

((ch=isr.read())!=-1){

System.out.print((char)ch);

sb.append((char)ch);

}

}catch
(Exception
ex){

sb.append("/r/n");

sb.append(ex.toString());

}

isr.close();

这种方法的优点是:它是在读取文本内容时最方便的一种作法,不过这种作法有一个缺陷,如果服务器端使用
asp.net
,用
Response.write(“”)
的方法向客户端返回的话,
isr.read()
永远读不到
-1

.net

java
在数值的字节流转换上划的不是一套拳。这时候就只能依靠使用最外层的那个
try
{}
catch()
来捕获错误的方法来终止读取,因此,这种方法看起来似乎总有点傻乎乎的感觉;

例二:先原样读取字节流,然后再对字节流进行转码;


ByteArrayOutputStream baout = new
ByteArrayOutputStream(1024);

byte

[] bytes = new
byte
[128];

int

size = 0;

int

TotalSize = 0;

requestByte = null
;

while

((size = is.read(bytes)) != -1) {

baout.write(bytes, 0, size);

TotalSize += size;

}

bytes = null
;

responseByte = baout.toByteArray();

String responseStr = new String(responseByte,"UTF-8");

注:
responseStr
即为所求;

这种方法忠实的读取出所有返回到客户端的字节流,并将这些字节流记录下来;

不过,要想这种方法读取到正确的字节流,我们需要留意在第一节中所提到的内容:

请求与响应的格式


这种方法的好处是以不变应万变,万变不离其宗,管它服务器发来什么,不过都是一大堆的
byte[]
流而已,就像黑客帝国中的尼奥,他看破了这层
byte[]
流,想干嘛就干嘛。

四、编码


常用的汉字编码有:
GB2313(GB2313-80)

GBK

UTF8

BIG5
码,
BIG5
编码在港台用;

常用的其它编码有:
ASC-II

ISO-8859-1

Unicode

为了获得网页的内容,当然要指定正确的编码了,不同的网页使用的编码会不同,所以使用相同的程序在访问不同的网页时会表现不同,这时千万别

大惊失色

,其实只是小问题;

说到这里,我要说个很苦恼的事情:我在
google
上很难查到各种国家标准,可能是这些链接很少被人关注到,一直希望能找到这样一个网站,上面有各种国家发布的标准、法律文件等可以被广大人民群众方便的查询到。不但齐全完整,而且还能与时具进,不知哪位大仙能告诉我几个这种网站的网址?小神在此先谢过!

下面这个网站是中国国家教育部网站下面收藏的
GB2312-80
字符集;用
google
翻出来的,如果想从教育部网站首页上找到它反而有点难度。另外,这个页面不知道能存放在那里多久。

http://www.moe.edu.cn/edoas/website18/info16417.htm

关于作者:


布老虎,
QQ

67090182
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐