jquery向.ashx文件post中文亂碼問(wèn)題的解決方法
更新時(shí)間:2011年03月28日 22:29:07 作者:
jquery向.ashx文件post中文亂碼問(wèn)題的解決方法,需要的朋友可以參考下。
1.我的環(huán)境:vs2005,未裝SP1補(bǔ)丁,不能創(chuàng)建Web應(yīng)用程序,只能創(chuàng)建網(wǎng)站;jquery版本1.5.1
2.web.config中的相關(guān)配置
<globalization requestEncoding="gb2312" responseEncoding="gb2312"/>
3.jquery的Post數(shù)據(jù)的寫(xiě)法
$(document).ready(function (){
$("#btnSend").click(function(){
$.ajax({
type: "POST",
url: "PrecisionAHandle.ashx",
contentType:"application/x-www-form-urlencoded; charset=UTF-8",
data: { "StudentId": $("#LblStudentId").attr("innerText"),"StudentName": $("#LblStudentName").attr("innerText"),"StudentAge": $("#txtStudentAge").attr("value")},
success: function(html){
$("#TabContainer").html(html);
}
});
});
});
其中StudentName是中文
4.在.ashx文件中接收參數(shù)的寫(xiě)法
string strStudentName = context.Request.Params["StudentName"];
注意:如果沒(méi)有contentType:"application/x-www-form-urlencoded; charset=UTF-8",則context.Request.Params["StudentName"]是亂碼。
經(jīng)過(guò)在.ashx中跟蹤context.Request.ContentEncoding,可知jquery所post過(guò)來(lái)的數(shù)據(jù)采用的是gb2312編碼,可能context.Request在接收到數(shù)據(jù)時(shí)默認(rèn)采用utf-8進(jìn)行解碼,但是jquery在Post數(shù)據(jù)的時(shí)候卻不是用的utf-8才導(dǎo)致.ashx的context.Request.Params["StudentName"]顯示為亂碼。
感覺(jué)比較奇怪的現(xiàn)象:
現(xiàn)象1:在不添加contentType:"application/x-www-form-urlencoded; charset=UTF-8",的情況下,在.ashx文件中使用下面的語(yǔ)句卻可以正確顯示字符串:
StreamReader steamRd = new StreamReader(HttpContext.Current.Request.InputStream);
string strPostData = steamRd .ReadToEnd();
strPostData =HttpUtility.UrlDecode(strPostData, Encoding.GetEncoding("utf-8"));
現(xiàn)象2:將web.config中的相關(guān)配置改為
<globalization requestEncoding="utf-8" responseEncoding="utf-8"/>
之后,不管是否加上contentType:"application/x-www-form-urlencoded; charset=UTF-8",后臺(tái)的.ashx文件接收到的參數(shù)仍然是亂碼。修改web.config之后網(wǎng)站編譯的很慢且運(yùn)行的也很慢。
參考文章:
http://www.dbjr.com.cn/article/26658.htm
http://www.dbjr.com.cn/article/26659.htm
2.web.config中的相關(guān)配置
<globalization requestEncoding="gb2312" responseEncoding="gb2312"/>
3.jquery的Post數(shù)據(jù)的寫(xiě)法
復(fù)制代碼 代碼如下:
$(document).ready(function (){
$("#btnSend").click(function(){
$.ajax({
type: "POST",
url: "PrecisionAHandle.ashx",
contentType:"application/x-www-form-urlencoded; charset=UTF-8",
data: { "StudentId": $("#LblStudentId").attr("innerText"),"StudentName": $("#LblStudentName").attr("innerText"),"StudentAge": $("#txtStudentAge").attr("value")},
success: function(html){
$("#TabContainer").html(html);
}
});
});
});
其中StudentName是中文
4.在.ashx文件中接收參數(shù)的寫(xiě)法
string strStudentName = context.Request.Params["StudentName"];
注意:如果沒(méi)有contentType:"application/x-www-form-urlencoded; charset=UTF-8",則context.Request.Params["StudentName"]是亂碼。
經(jīng)過(guò)在.ashx中跟蹤context.Request.ContentEncoding,可知jquery所post過(guò)來(lái)的數(shù)據(jù)采用的是gb2312編碼,可能context.Request在接收到數(shù)據(jù)時(shí)默認(rèn)采用utf-8進(jìn)行解碼,但是jquery在Post數(shù)據(jù)的時(shí)候卻不是用的utf-8才導(dǎo)致.ashx的context.Request.Params["StudentName"]顯示為亂碼。
感覺(jué)比較奇怪的現(xiàn)象:
現(xiàn)象1:在不添加contentType:"application/x-www-form-urlencoded; charset=UTF-8",的情況下,在.ashx文件中使用下面的語(yǔ)句卻可以正確顯示字符串:
復(fù)制代碼 代碼如下:
StreamReader steamRd = new StreamReader(HttpContext.Current.Request.InputStream);
string strPostData = steamRd .ReadToEnd();
strPostData =HttpUtility.UrlDecode(strPostData, Encoding.GetEncoding("utf-8"));
現(xiàn)象2:將web.config中的相關(guān)配置改為
<globalization requestEncoding="utf-8" responseEncoding="utf-8"/>
之后,不管是否加上contentType:"application/x-www-form-urlencoded; charset=UTF-8",后臺(tái)的.ashx文件接收到的參數(shù)仍然是亂碼。修改web.config之后網(wǎng)站編譯的很慢且運(yùn)行的也很慢。
參考文章:
http://www.dbjr.com.cn/article/26658.htm
http://www.dbjr.com.cn/article/26659.htm
您可能感興趣的文章:
- Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法總結(jié)
- jquery中$.post()方法的簡(jiǎn)單實(shí)例
- javascript jQuery $.post $.ajax用法
- jQuery get和post 方法傳值注意事項(xiàng)
- jQuery中ajax的post()方法用法實(shí)例
- jquery ajax post提交數(shù)據(jù)亂碼
- Jquery AJAX POST與GET之間的區(qū)別
- jquery post方式傳遞多個(gè)參數(shù)值后臺(tái)以數(shù)組的方式進(jìn)行接收
- jquery中g(shù)et,post和ajax方法的使用小結(jié)
- jQuery post數(shù)據(jù)至ashx實(shí)例詳解
相關(guān)文章
使用js dom和jquery分別實(shí)現(xiàn)簡(jiǎn)單增刪改
今天學(xué)了jquery框架的簡(jiǎn)單使用。于是用它實(shí)現(xiàn)簡(jiǎn)單的增刪改,接著也用原始的javascript實(shí)現(xiàn)同樣的功能,兩者對(duì)比可以看出jquery的強(qiáng)大2014-09-09
jQuery 1.2.x 升級(jí) 1.3.x 注意事項(xiàng)
2009-05-05
jQuery?UI旋轉(zhuǎn)器部件Spinner?Widget
這篇文章介紹了jQuery?UI旋轉(zhuǎn)器部件Spinner?Widget,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
Jquery Ajax學(xué)習(xí)實(shí)例7 Ajax所有過(guò)程事件分析示例
JQuery在執(zhí)行Ajax的過(guò)程中會(huì)觸發(fā)很多事件。2010-03-03
jQuery插件HighCharts繪制的基本折線圖效果示例【附demo源碼下載】
這篇文章主要介紹了jQuery插件HighCharts繪制的基本折線圖效果,結(jié)合實(shí)例形式分析了jQuery基于HighCharts插件繪制圖形的具體實(shí)現(xiàn)步驟與相關(guān)操作技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-03-03
Jquery仿淘寶京東多條件篩選可自行結(jié)合ajax加載示例
仿淘寶京東多條件篩選可自行結(jié)合ajax加載,使用Jquery簡(jiǎn)單實(shí)現(xiàn),具體如下,喜歡的朋友可以參考下2013-08-08

