JQuery向ashx提交中文参数方案 [转]
2015-03-24 09:38
260 查看
转自:/article/1649822.html
字符编码这个东西,一旦和中文打上交道就不可避免出现乱码,今天项目用到了JQuery向ashx提交中文参数的这一块,折腾了一天,开始是各种乱码,最后中算弄好了。
客户端:
[javascript] view plaincopyprint?
//异步获取数据
var tpAction=action+'getSearch.ashx?key='+encodeURIComponent('中国');
$.getJSON(tpAction,function(rsp){//请求成功
if(rsp.status=='1'){
var list=rsp.item;
var len=list.length;
if(len==0){
//没有数据直接返回
setNull();
return;
}
//组装数据
var s=zy_tmpl(templ,list,len);
$list.append(s);
}else{
alert('','加载数据失败,请重试','确定');
}
},'json',function(err){//请求失败
alert('','加载失败,请检查网络设置!','确定');
},'POST','');
服务器端:
[csharp] view plaincopyprint?
string keyy = context.Request["key"];
if (keyy != null)
{
string key = HttpUtility.UrlDecode(context.Request["key"].ToString());
//string key = context.Server.HtmlDecode(context.Request.Params["key"].ToString());
string log = "getSearch.ashx?key=" + key;
string logsql = "insert into logs(createtime,contents) values('" + DateTime.Now.ToString() + "','" + log + "')";
Sqlbase.ExecuteNonQuery(CommandType.Text, logsql, null);
//more
string sql = "select * from news where title like '%" + key + "%' order by id desc";
DataTable dt = Sqlbase.ExecuteTable(CommandType.Text, sql, null);
result rs = new result();
rs.status = 1;
rs.msg = "成功";
rs.item = dt;
string strJson = Newtonsoft.Json.JsonConvert.SerializeObject(rs);
context.Response.Clear();
context.Response.ContentEncoding = Encoding.UTF8;
context.Response.ContentType = "application/json";
context.Response.Write(strJson);
context.Response.Flush();
context.Response.End();
}
这里根本就没有进行什么编码设置,其实就是JS用encodeURIComponent()对中文字符串编码,C#用HttpUtility.UrlDecode(context.Request["key"].ToString())进行解码,是不是很简单呢!可是我一天的实践证明:JS端用encodeURIComponent()要比escape()好多了,至于区别大家可以google一下,C#的解码函数也一堆,像什么Server.UrlDecode之类的,但是推荐使用HttpUtility.UrlDecode(),好处大家同样也可以google!
字符编码这个东西,一旦和中文打上交道就不可避免出现乱码,今天项目用到了JQuery向ashx提交中文参数的这一块,折腾了一天,开始是各种乱码,最后中算弄好了。
客户端:
[javascript] view plaincopyprint?
//异步获取数据
var tpAction=action+'getSearch.ashx?key='+encodeURIComponent('中国');
$.getJSON(tpAction,function(rsp){//请求成功
if(rsp.status=='1'){
var list=rsp.item;
var len=list.length;
if(len==0){
//没有数据直接返回
setNull();
return;
}
//组装数据
var s=zy_tmpl(templ,list,len);
$list.append(s);
}else{
alert('','加载数据失败,请重试','确定');
}
},'json',function(err){//请求失败
alert('','加载失败,请检查网络设置!','确定');
},'POST','');
//异步获取数据 var tpAction=action+'getSearch.ashx?key='+encodeURIComponent('中国'); $.getJSON(tpAction,function(rsp){//请求成功 if(rsp.status=='1'){ var list=rsp.item; var len=list.length; if(len==0){ //没有数据直接返回 setNull(); return; } //组装数据 var s=zy_tmpl(templ,list,len); $list.append(s); }else{ alert('','加载数据失败,请重试','确定'); } },'json',function(err){//请求失败 alert('','加载失败,请检查网络设置!','确定'); },'POST','');
服务器端:
[csharp] view plaincopyprint?
string keyy = context.Request["key"];
if (keyy != null)
{
string key = HttpUtility.UrlDecode(context.Request["key"].ToString());
//string key = context.Server.HtmlDecode(context.Request.Params["key"].ToString());
string log = "getSearch.ashx?key=" + key;
string logsql = "insert into logs(createtime,contents) values('" + DateTime.Now.ToString() + "','" + log + "')";
Sqlbase.ExecuteNonQuery(CommandType.Text, logsql, null);
//more
string sql = "select * from news where title like '%" + key + "%' order by id desc";
DataTable dt = Sqlbase.ExecuteTable(CommandType.Text, sql, null);
result rs = new result();
rs.status = 1;
rs.msg = "成功";
rs.item = dt;
string strJson = Newtonsoft.Json.JsonConvert.SerializeObject(rs);
context.Response.Clear();
context.Response.ContentEncoding = Encoding.UTF8;
context.Response.ContentType = "application/json";
context.Response.Write(strJson);
context.Response.Flush();
context.Response.End();
}
string keyy = context.Request["key"]; if (keyy != null) { string key = HttpUtility.UrlDecode(context.Request["key"].ToString()); //string key = context.Server.HtmlDecode(context.Request.Params["key"].ToString()); string log = "getSearch.ashx?key=" + key; string logsql = "insert into logs(createtime,contents) values('" + DateTime.Now.ToString() + "','" + log + "')"; Sqlbase.ExecuteNonQuery(CommandType.Text, logsql, null); //more string sql = "select * from news where title like '%" + key + "%' order by id desc"; DataTable dt = Sqlbase.ExecuteTable(CommandType.Text, sql, null); result rs = new result(); rs.status = 1; rs.msg = "成功"; rs.item = dt; string strJson = Newtonsoft.Json.JsonConvert.SerializeObject(rs); context.Response.Clear(); context.Response.ContentEncoding = Encoding.UTF8; context.Response.ContentType = "application/json"; context.Response.Write(strJson); context.Response.Flush(); context.Response.End(); }
这里根本就没有进行什么编码设置,其实就是JS用encodeURIComponent()对中文字符串编码,C#用HttpUtility.UrlDecode(context.Request["key"].ToString())进行解码,是不是很简单呢!可是我一天的实践证明:JS端用encodeURIComponent()要比escape()好多了,至于区别大家可以google一下,C#的解码函数也一堆,像什么Server.UrlDecode之类的,但是推荐使用HttpUtility.UrlDecode(),好处大家同样也可以google!
相关文章推荐
- JQuery向ashx提交中文参数方案
- JQuery向ashx提交中文参数方案
- 页面编码为GBK时 jquery 提交ajax数据完美解决中文乱码方案
- JQuery中Ajax的Post提交中文乱码、windows.location.href 中文汉字乱码和springmvc使用原生态HttpServletRequest接收参数中文乱码解决办法
- 页面编码为GBK时_jquery_提交ajax数据完美解决中文乱码方案
- 页面编码为GBK时 jquery 提交ajax数据完美解决"中文乱码"方案
- 页面编码为GBK时 jquery 提交ajax数据完美解决"中文乱码"方案
- ASP.NET使用Jquery-Ajax向ashx传递参数中文出现乱码
- 通过url提交中文参数乱码问题
- Ajax带中文参数提交
- 彻底解决get显示提交时,参数中包含中文时出现乱码的问题
- 解决jQuery Ajax提交中文参数变成乱码的方法
- JSP中URL中文乱码问题!get提交时,服务器端乱码,url带中文参数乱码 [2]
- jquery form表单提交插件asp.net后台中文解码
- jquery方式提交中文乱码问题
- 用jquery提交AJAX的中文乱码问题
- 表单向Servlet提交参数时的中文乱码问题
- 解决jquery 传递中文参数到服务端乱码
- ajax GET方式提交,中文参数乱码的问题
- 修改jQuery.Autocomplete插件 支持中文输入法 避免TAB、ENTER键失效、导致表单提交