关于AJAX使用中出现中文乱码的问题
自己初学AJAX,遇到一个棘手的bug就是xmlHttp.open("get",url,false);url里面有中文,结果出现乱码。不过最后在百度,和诸位博主的帮助下,成功解决了。
解决方法:
<SCRIPT language="JavaScript" type="text/javascript">
function query(){
var sname= document.queryForm.sname.value;
var xmlHttp;
if(window.XMLHttpRequest)
{
xmlHttp=new XMLHttpRequest();
}
else{
xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");//定义了Msxml2.XMLHTTP对象(不同浏览器定义方法不一样,它具有异步提交功能)
}
xmlHttp.open("get","query.do?sname="+sname,false);//get表示以get方式提交,p6.jsp表示提交到的页面,true表示异步提交。注意,这句代码运行时并没有提交。
xmlHttp.onreadystatechange=function(){
if(xmlHttp.readyState==4){
result.innerHTML = xmlHttp.responseText;
}
else{
result.innerHTML = "正在查询,请稍等...";
}
}
xmlHttp.send();//xmlHttp异步提交
}
</SCRIPT>
这段代码有个问题,就是query.do?sname="+sname,会出错,就算你写成query.do?sname=你好",传到action里面也是一个??,就是乱码.
怎么解决呢?在var sname= document.queryForm.sname.value;
sname=encodeURI(sname);//对字符串进行编码
这样传到action里面就是中文了,
action代码:
public class QueryAction extends Action {
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response) {
// TODO Auto-generated method stub
String sname = request.getParameter("sname");
System.out.println("得到"+sname);
try{
sname = new String(sname.getBytes("ISO-8859-1"),"utf-8");
}catch(Exception ex){}
System.out.println("转码"+sname);
StudentDao sdao = new StudentDao();
ArrayList stus = sdao.queryStuByName(sname);
request.setAttribute("stus", stus);
return new ActionForward("/p6.jsp");
}
}
这里打印出来就
得到(传过来的参数)
转码??
还是会出现??,怎么解决?
把try{
sname = new String(sname.getBytes("ISO-8859-1"),"utf-8");
}catch(Exception ex){}删除掉,就正常了.
归根到底,就是中文编码的问题,因为ajax的默认编码是ISO-8859-1,所以你就算写了filter过滤器也不能解决这个问题。jsp开头写<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>也没有用。
最后提供一下中文过滤器的代码,可以解决很多jsp显示中文乱码的问题:
Filter.java
package filter;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
public class Efilter implements Filter {
public Efilter(){
//System.out.println("过滤构造函数");
}
private String encodingName;
public void init(FilterConfig fc) throws ServletException {
// 初始化函数,服务器运行能自动运行一次
//System.out.println("过滤器init函数");
encodingName =fc.getInitParameter("encodingName");//得到局部参数
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
// TODO Auto-generated method stub
//每次提交都会运行
//System.out.println("过滤器doFilter函数");
request.setCharacterEncoding(encodingName);//解决中文问题
//过滤器是在提交到处处理模块之前运行,所以这里要将请求向后传递
chain.doFilter(request,response);
}
public void destroy() {
//消亡函数
//System.out.println("过滤器destroy函数");
}
}
之后到web.xml里面进行注册:
<!-- 注册过滤器-->
<filter>
<filter-name>Efilter</filter-name>
<filter-class>filter.Efilter</filter-class>
<init-param>
<param-name>encodingName</param-name>
<param-value>gb2312</param-value><!-- 可以识别简体中文-->
</init-param>
</filter>
<filter-mapping>
<filter-name>Efilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
关于AJAX使用中出现中文乱码的问题的更多相关文章
- jquery的ajax()函数传值中文乱码解决方法介绍
jquery的ajax()函数传值中文乱码解决方法介绍,需要的朋友可以参考下 代码如下: $.ajax({ dataType : ‘json', type : ‘POST', url : ‘http: ...
- ajax()函数传值中文乱码解决方法介绍
jquery的ajax()函数传值中文乱码解决方法介绍,需要的朋友可以参考下 复制代码 代码如下: $.ajax({ dataType : ‘json',type : ‘POST',url : ‘ht ...
- Ajax提交后台中文乱码问题
今天项目组同事反映,之前有一个正常的请求,今天突然后台获取参数的值出现了中文乱码,怀疑是之前更新jar包所致,笔者仔细想了想更新的内容,仿佛没有涉及到编码的变更啊,然后开始排查,首先后台加了强制以ut ...
- ajax提交 返回中文乱码问题
接口返回数据相关 使用@ResponseBody后返回NUll 说明:刚把后台运行起来,兴高采烈的测试接口数据,结果无论如何都是返回null, 最终通过各种百度,发现原来是没有引入关键的Jar包. 解 ...
- 数据传递-------ajaxJson------spring3mvc中使用ajax传json中文乱码解决
参考来源:http://blog.csdn.net/dangerous_fire/article/details/25904225 第一种解决方法,适用所有情况 因为在controller中返回jso ...
- ajax参数传递时中文乱码问题
ajax传递参数时,一般就是js向程序页面传递和程序向js文件传递两种情况,当出现中文汉字时,会出现乱码. 因为存在上述两种情况,所以解决起来也要分开对待. 这里是php系统中遇到的问题,所以以php ...
- ajax GET 传输中文乱码
关于客户端get传输到服务端乱码解决: <script> //ajakx 传输变量 var xmlhttp; if (window.XMLHttpRequest) {// code for ...
- struts2 action获取ajax提交数据中文乱码问题
有个人和我问题相同,地址在这: 解决方法: 在ajax的属性添加这句:contentType:'application/x-www-form-urlencoded; charset=utf-8',
- ajax url参数中文乱码解决
1.较好的处理办法,对js的url中的中文参数值使用两次encodeURI(),即 encodeURI(encodeURI("url的中文参数值")), java代码中使用URLD ...
随机推荐
- SE6 不定参数和默认参数详解和使用细节
在SE5以前我们通常通过arguments类数组对象来引用不定形参,SE6则使用了一种叫做不定参数的写法,比起隐式的arguments要直观的多. 不定参数使用...参数名来指定一个不定参数,参数名指 ...
- Codeforces 378B. Parade
B. Parade time limit per test 1 second memory limit per test 256 megabytes input standard input outp ...
- VS2015企业版序列号
vs2015 企业版HM6NR-QXX7C-DFW2Y-8B82K-WTYJV2XNFG-KFHR8-QV3CP-3W6HT-683CH
- ionic生成apk使用build命令下载gradle-2.2.1-all.zip卡,解决方案
ionic生成apk使用build命令下载gradle-2.2.1-all.zip卡,解决方案 直接使用ionic build android命令,自动下载gradle-2.2.1-all.zip超慢 ...
- 【机器学习】TensorFlow学习(一)
感谢中国人民大学胡鹤老师,课讲得非常好~ 首先,何谓tensor?即高维向量,例如矩阵是二维,tensor是更广义意义上的n维向量(有type+shape) TensorFlow执行过程为定义图,其中 ...
- 微信小程序入门(一)
想必当你对官方文档了解地差不多的时候,一颗跃跃欲试的心就开始骚动了吧. 开发小程序之前的准备工作: 1).准备一个域名 2).准备一台云服务器 3).搭建小程序的后台,博主的小程序后台请求的的是自己写 ...
- 我在学JavaScript中的循环
for (var num1 = 1;num1 < 10;num1++ ){ for (var num2 = 1;num2< 10;num2++ ){ console.log(num1+'* ...
- web前端vertical-align的作用及对象详解
很多程序员知道web前端技术里的vertical-align是什么意思,但是对于vertical-align到底以什么为对齐标准却一知半解,今天我们就来说说web前端vertical-align. 1 ...
- 教你五步制作精美的HTML时钟
学了一段时间的HTML.CSS和JS后,给大家做一款漂亮的不像实力派的HTML时钟,先看图:涉及到的知识点有: CSS3动画.DOM操作.定时器.圆点坐标的计算(好多人是不是已经还给自己的老师了~) ...
- web前端-----jQuery
web前端之jQuery篇 一 jQuery是什么? [1] jQuery由美国人John Resig创建,至今已吸引了来自世界各地的众多 javascript高手加入其team. [2] j ...