AJAX应用技巧

 

XMLHTTPRequest浏览器缓存问题

Firefox浏览器中,XMLHTTPRequest对象相相同的url发送请求时,浏览器每次都会向服务器发送请求,不存在缓存的问题,而IE浏览器如果url请求地址相同时,浏览器会读取其缓存中的内容进行响应,而不再向服务器发送请求,解决浏览器缓存的办法是:在url后面加上时间戳参数,使浏览器认为请求的url不同,而不再读取缓存。

 

AJAX传递中文乱码问题

当使用AJAX处理中文参数时,浏览器会显示乱码,解决方法有如下两种解决方案:

方案一:

页面端:使用endcodeURI(参数)对中文参数进行编码。

服务器端:使用new String(参数.getBytes(“ISO8859-1”),”UTF-8”);对参数进行重新编码为UTF-8

缺点:服务器可能不是使用ISO8859-1,硬编码不方便修改。

方案二:

页面端:使用endcodeURI(endcodeURI(参数))对中文参数进行两次编码。

服务器端:使用URLDecoder.decode(参数,”UTF-8”);进行UTF-8解码。

此方法是推荐使用。

 

AJAX跨域访问问题

Web页面跨域访问时,会引起安全问题,因此,Firefox浏览器不允许跨越访问,IE浏览器会给出一个警告提示。如果要使AJAX程序可以顺利地跨域访问解决方案如下:

页面端:将跨域访问的http url请求地址中的“?”用“&”代替,然后将当前的url变为Proxy?url=改变后的url;

服务器端:编写一个名为Proxyservlet用于处理跨域访问,其编写思路如下:

A.    解析url和其参数,将其重新拼接成原始跨域访问的url

B.    访问url地址,并将获得的内容返回给页面端。

POST方式和GET方式有所不同,POST方式的参数是在HTTP请求的body中,而GET方式的参数是在请求的url中,因此代码有所不同。

POST方式核心代码如下:

 

 

GET方式核心代码如下:

 

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值