Extjs Ajax 乱码问题解决方案


Posted in Javascript onApril 15, 2009

在一次页面浏览过程中,客户端对一个URL发起浏览请求,服务端针对这次请求进行解析,而在字符编码解析方面,首先他检查该页面中的字符编码设置,即<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />,这样,在页面中显示声明了字符编码为UTF-8,服务器就会将该页面用UTF-8的编码输出,而如果页面中没有显示声明,在服务器中都有一个默认的字符编码,比如GB2312,针对没有声明的文件,他会用默认编码输出,这个时候,如果页面输出又是UTF-8,这样就会出现乱码。

而在Ext中的提交数据的过程中,Ext框架用的是都是UTF-8编码,而且通过JSON提交的数据也是UTF-8编码,所以要求所有的文件都是UTF-8编码。
解决乱码的方法
以下几项首先必须要在平时的编码过程中做到:

(1) JAVA后台文件加入 response.setContentType("text/html");
response.setCharacterEncoding("utf-8");

(2)在文件中显示声明字符编码,<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

(3)对于提交中出现的乱码,在Ext中可以修改Request Header中Content-Type的设置,具体的方法为:Ext.lib.Ajax.defaultPostHeader += ";charset=utf-8";

最后,问题还可能出现在文件的保存格式上。就是你把代码文件保存的时候,如果开发环境默认保存的不是UTF-8格式,那么也会出现问题! 所以就要对开发环境也有一个要求。
开发环境的配置
如果采用记事本来编写保存代码文件(.js),那这个就会出问题,主要是由于在windows系统里记事本默认的编码格式是ANSI,这样基本上和目前网页中编码的格式都不同因此就会出现编码格式不正确的问题。解决办法就是打开xx.js文件然后另存为,在保存类型处选择utf-8编码格式就可以了。
当然,主流还是使用MyEclipse,所以说一下MyEclipse里要配置哪些地方。
Preferences->General->Content Types 选中Text 编辑下面的Default encoding 为utf-8然后Update。
Preferences->General->Content Types->Editors->Text Editors->Spelling 下Encoding 选 Default(UTF-8)
Preferences->General->Content Types->Workspace下Text File Encoding 选 Other: UTF-8
最后如果还出现乱码 , 利用
System.out.print(request.getCharacterEncoding());
System.out.print(response.getCharacterEncoding());
察看request 或 response 编码是否不是utf-8
若不是,利用web.xml中的 filter 解决.

<filter>
<description>no</description>
<display-name>EncodingFilter</display-name>
<filter-name>EncodingFilter</filter-name>
<filter-class>
com.hope.filters.SetCharacterEncodingFilter
</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>utf-8</param-value>
</init-param>
</filter>
或者设置
<globalization responseEncoding="utf-8" fileEncoding="utf-8" requestEncoding="utf-8"/>
Good Luck!

Javascript 相关文章推荐
javascript showModalDialog 多层模态窗口实现页面提交及刷新的代码
Nov 28 Javascript
jQuery获取地址栏参数插件(模仿C#)
Oct 26 Javascript
window.open打开页面居中显示的示例代码
Dec 27 Javascript
Javascript学习笔记之 对象篇(三) : hasOwnProperty
Jun 24 Javascript
JavaScript弹出窗口方法汇总
Aug 12 Javascript
JS实现简洁、全兼容的拖动层实例
May 13 Javascript
jquery获取当前元素索引值用法实例
Jun 10 Javascript
jquery实现二级导航下拉菜单效果
Dec 18 Javascript
js精准的倒计时函数分享
Jun 29 Javascript
详解js中==与===的区别
Jan 08 Javascript
JS使用正则表达式获取小括号、中括号及花括号内容的方法示例
Jun 01 Javascript
JavaScript接口实现方法实例分析
May 16 Javascript
网页开发中的容易忽略的问题 javascript HTML中的table
Apr 15 #Javascript
jQuery 入门讲解1
Apr 15 #Javascript
javascript 类方法定义还是有点区别
Apr 15 #Javascript
javaScript 读取和设置文档元素的样式属性
Apr 14 #Javascript
JavaScript获取GridView选择的行内容
Apr 14 #Javascript
用JavaScript页面不刷新时全选择,全删除(GridView)
Apr 14 #Javascript
JavaScript asp.net 获取当前超链接中的文本
Apr 14 #Javascript
You might like
php include的妙用,实现路径加密
2008/07/29 PHP
Linux中为php配置伪静态
2014/12/17 PHP
Yii基于数组和对象的Model查询技巧实例详解
2015/12/28 PHP
jquery datepicker参数介绍和示例
2014/04/15 Javascript
jquery实现初次打开有动画效果的网页TAB切换代码
2015/09/06 Javascript
JS基于myFocus库实现各种功能的tab选项卡切换效果
2015/09/19 Javascript
bootstrap学习笔记之初识bootstrap
2016/06/21 Javascript
javascript cookie用法基础教程(概念,设置,读取及删除)
2016/09/20 Javascript
JS命令模式例子之菜单程序
2016/10/10 Javascript
jQuery上传多张图片带进度条样式(DEMO)
2017/03/02 Javascript
ES6新增的math,Number方法
2017/08/06 Javascript
解决iView中时间控件选择的时间总是少一天的问题
2018/03/15 Javascript
微信小程序模拟cookie的实现
2018/06/20 Javascript
vue 属性拦截实现双向绑定的实例代码
2018/10/24 Javascript
Vue 一键清空表单的实现方法
2020/02/07 Javascript
如何在微信小程序中使用骨架屏的步骤
2020/06/12 Javascript
Python的Flask框架中Flask-Admin库的简单入门指引
2015/04/07 Python
说说如何遍历Python列表的方法示例
2019/02/11 Python
Python计算时间间隔(精确到微妙)的代码实例
2019/02/26 Python
python爬虫 urllib模块url编码处理详解
2019/08/20 Python
将pytorch转成longtensor的简单方法
2020/02/18 Python
Python greenlet和gevent使用代码示例解析
2020/04/01 Python
Python3实现英文字母转换哥特式字体实例代码
2020/09/01 Python
如何将anaconda安装配置的mmdetection环境离线拷贝到另一台电脑
2020/10/15 Python
CSS3 transition 实现通知消息轮播条
2020/10/14 HTML / CSS
物业经理求职自我评价
2013/09/22 职场文书
军训学生自我鉴定
2014/02/12 职场文书
2014年五一活动策划方案
2014/03/15 职场文书
单身申明具结书
2015/02/26 职场文书
个人更名证明
2015/06/23 职场文书
七年级作文之《我和我的祖国》观后感作文
2019/10/18 职场文书
css position fixed 左右双定位的实现代码
2021/04/29 HTML / CSS
openstack中的rpc远程调用的方法
2021/07/09 Python
python调用ffmpeg命令行工具便捷操作视频示例实现过程
2021/11/01 Python
分享五个Node.js开发的优秀实践 
2022/04/07 NodeJs
Python中文分词库jieba(结巴分词)详细使用介绍
2022/04/07 Python