解决Ajax中文乱码问题

      网上有很多解决这个问题的方法,试了一下都不好用,自己就对于这些方法测试了一下,然后逐个排除无用的设置,最后得到了最简单的方案。

      放在首页是因为个人觉得网上许多方案巨麻烦,而且不好用。只是一个小经验,大家分享,用不了多少时间就可以看完,免得以后要解决这个问题时从网上找浪费大家宝贵的时间。
js代码:
得到XmlHttpRequest的类

ContractedBlock.gif ExpandedBlockStart.gif Code
 1None.giffunction HttpRequest()
 2ExpandedBlockStart.gifContractedBlock.gifdot.gif{
 3InBlock.gif    //取得Request对象
 4ExpandedSubBlockStart.gifContractedSubBlock.gif    this.Request=function()dot.gif{
 5InBlock.gif        try
 6ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
 7InBlock.gif            if(window.XMLHttpRequest) request=new XMLHttpRequest();
 8InBlock.gif            if(!request)request=new ActiveXObject("Microsoft.XMLHTTP");
 9InBlock.gif            if(!request)request=new ActiveXObject("Msxml2.XMLHTTP");
10InBlock.gif            return request;
11ExpandedSubBlockEnd.gif        }

12InBlock.gif        catch(e)
13ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
14InBlock.gif            alert("不支持XMLHTTPRequest");
15ExpandedSubBlockEnd.gif        }
}

16ExpandedBlockEnd.gif}

调用过程:

ContractedBlock.gif ExpandedBlockStart.gif Code
 1None.gif<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="AjaxTest._Default"  %>
 2None.gif
 3None.gif<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 4None.gif<html xmlns="http://www.w3.org/1999/xhtml">
 5None.gif<head runat="server">
 6None.gif    <title>Untitled Page</title>
 7None.gif
 8None.gif    <script language="javascript" type="text/javascript" src="User.Base.js"></script>
 9None.gif
10None.gif    <script language="javascript" type="text/javascript">
11None.gif    function Check()
12ExpandedBlockStart.gifContractedBlock.gif    dot.gif{
13InBlock.gif    var request=new HttpRequest().Request();
14ExpandedSubBlockStart.gifContractedSubBlock.gif    request.onreadystatechange=function ()dot.gif{
15InBlock.gif        if(request.readyState==4)
16ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
17InBlock.gif            if(request.status==200)
18ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
19InBlock.gif                alert(request.responseText);
20ExpandedSubBlockEnd.gif            }

21InBlock.gif            else
22ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
23InBlock.gif                alert(request.responseText);
24ExpandedSubBlockEnd.gif            }

25ExpandedSubBlockEnd.gif        }

26ExpandedSubBlockEnd.gif    }

27InBlock.gif    var value=document.getElementById("val").value;
28InBlock.gif    request.open("POST","Default.aspx?Value="+value,true);
29InBlock.gif    //设置防止乱码的方法,只要一句话就行
30InBlock.gif    request.setRequestHeader("Content-Type","text/html;charset=gb2312");
31InBlock.gif    request.send(null);
32ExpandedBlockEnd.gif    }

33None.gif    </script>
34None.gif
35None.gif</head>
36None.gif<body>
37None.gif    <form id="form1" runat="server">
38None.gif    <div>
39None.gif        <input id="val" type="text" onblur="Check()" />
40None.gif    </div>
41None.gif    </form>
42None.gif</body>
43None.gif</html>
44None.gif

后台取得输入值:

None.gif          protected   void  Page_Load( object  sender, EventArgs e)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif {
InBlock.gif            
string value = Request["Value"];
ExpandedBlockEnd.gif        }

None.gif

测试过,可以得到正确的输入字符。

 

原创文章,转载请注明出处!
All CopyRight Reserved !

 

主页:http://jingtao.cnblogs.com

QQ:307073463
Email:jingtaodeemail@qq.com
MSN:sunjingtao@live.com

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值