`
seastar1989_zhx
  • 浏览: 3619 次
  • 性别: Icon_minigender_1
最近访客 更多访客>>
社区版块
存档分类
最新评论

解决Ajax中文乱码

    博客分类:
  • Ajax
 
阅读更多

    解决中文乱码推荐方式

1.前台web界面

<body>
    请输入用户名:<input type="text" id="name" /><br />
    <input type="submit" value="校验" onclick="verify()"/>
    <div id="showMsg"></div>
</body>

 

js代码

function verify(){

    var username = encodeURI(encodeURI($("#name").val()));

    ......

    ......

}

 

2.后台代码

 

String username = reqeust.getPatameter("name");

username = java.net.URLDecoder.decode(username, "utf-8");

 

很奇怪为什么前台页面要使用两次encodeURI()方法那?

    查找得知,很多服务器默认使用ISO8859-1编码方式进行编码和解码,encodeURI()方法将传递的参数使用utf-8进行编码,中文本身是特殊字符,编码之后编程:"%英文/数字"的形式,若只采用一次encodeURI()方法,服务器会解码成ISO8859-1形式,自然是乱码。

    同理,我们在使用一次encodeURI()方法,将已经编码成utf-8的参数再次编码,传到服务器使用ISO8859-1解码后仍然是:“%字母/数字“,不是乱码,之后使用java,net包中的URLDecoder类的decode方法对该字符串解码为utf-8形式,这样便实现了中文的编码和解码过程,服务器响应的页面不会出现乱码了!!哇哈哈哈哈!!

 

    当然,若不使用两次encodeURI(),可以在服务器使用下列代码

username = new String(username.getBytes("ISO8859-1"), “utf-8”);

将转换的编码提取出来,在用utf-8形式进行编码(FireFox可用,IE貌似不行,求高手解答!)

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics