asp ajax 500乱码,Asp中使用JQuery的AJAX提交中文乱码解决方法

这篇博客介绍了在ASP中如何使用unescape()和escape()函数进行字符串编码和解码,以确保数据在客户端与服务器端之间的正确传输。文章通过示例展示了自定义的VbsEscape()和VbsUnEscape()函数,作为ASP内建函数的替代方案,并对比了JavaScript中的相应函数。最后,提出了更简洁的ASP实现方式,简化了编码和解码过程。
摘要由CSDN通过智能技术生成

客户端页:client.html

//jquery的post

$.post

(

'server.asp',

{

Act:'DoSubmit',

UserName:escape('编程圈'),//进行编码

WebSite:'www.jb51.net'

},

function(data)

{

alert(unescape(data));//对返回数据进行解码

}

);

服务器端页:server.asp

< %

Response.Charset="gb2312"

Dim UserName,WebSite

If Request.Form("Act")="DoSubmit" Then

UserName=Request.Form("UserName")

WebSite =Request.Form("WebSite")

'在服务器端解码

UserName=VbsUnEscape(UserName)//解码

'处理数据

'---省略数据处理部分

'数据处理后输出,先用VbsEscape()编码

Response.Write VbsEscape(UserName)

End If

%>

< %

'与javascript中的escape()等效

Function VbsEscape(str)

dim i,s,c,a

s=""

For i=1 to Len(str)

c=Mid(str,i,1)

a=ASCW(c)

If (a>=48 and a< =57) or (a>=65 and a< =90) or (a>=97 and a< =122) Then

s = s & c

ElseIf InStr("@*_+-./",c)>0 Then

s = s & c

ElseIf a>0 and a<16 Then

s = s & "%0" & Hex(a)

ElseIf a>=16 and a<256 Then

s = s & "%" & Hex(a)

Else

s = s & "%u" & Hex(a)

End If

Next

VbsEscape=s

End Function

'与javascript中的unescape()等效

Function VbsUnEscape(str)

Dim x

x=InStr(str,"%")

Do While x>0

VbsUnEscape=VbsUnEscape&Mid(str,1,x-1)

If LCase(Mid(str,x+1,1))="u" Then

VbsUnEscape=VbsUnEscape&ChrW(CLng("&H"&Mid(str,x+2,4)))

str=Mid(str,x+6)

Else

VbsUnEscape=VbsUnEscape&Chr(CLng("&H"&Mid(str,x+1,2)))

str=Mid(str,x+3)

End If

x=InStr(str,"%")

Loop

VbsUnEscape=VbsUnEscape&str

End Function

%>

在javascript 中escape() 函数可对字符串进行编码,这样就可以在所有的计算机上读取该字符串。

可以使用 unescape() 对 escape() 编码的字符串进行解码。

其实Asp中这两个函数也是起作用的,居然很多asp网站上没有进行介绍。

要不然只能像上面那样写函数进行解码编码了。复杂且性能不好。

上面的服务器端页:server.asp可以写成:

Asp中的unescape() 与 escape() 函数

< %

Response.Charset="gb2312"

Dim UserName,WebSite

If Request.Form("Act")="DoSubmit" Then

UserName=Request.Form("UserName")

WebSite =Request.Form("WebSite")

'在服务器端解码

UserName=UnEscape(UserName)//解码

'处理数据

'---省略数据处理部分

'数据处理后输出,先用VbsEscape()编码

Response.Write Escape(UserName)

End If

%>

这样就简单多了。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值