您的位置:首页 > 产品设计 > UI/UE

前台js escape及后台C# Server.UrlEncode 对QueryString传参的含~!@#$%^&*等特殊字符的处理

2013-12-13 11:45 423 查看
通常情况下,我们在List列表页面,会包含Create,Edit,Delete等操作按钮,

而通常的处理是:

Create按钮跳转到DataCreate.aspx

Edit按钮跳转到DataEdit.aspx?DataId=1&DataName=abc

一般在后台通过 string dataName = Request.QueryString["DataName"]的方式 来获取传入的参数

然后 var DataModel = getModelByDataName(dataName)

在DataId=1&DataName=abc时,没有特殊字符,参数接收正确,一切处理顺利

但在DataId=1&DataName=abc~!@#$%^&* 时,因为包含了&等特殊字符 ,参数接收错误

常用处理如下:

在前台js,用escape 进行处理

DataEdit.aspx?DataId=1&DataName=escape(abc~!@#$%^&*)

后台正常接收就可以了

在后台c#,用Server.UrlEncode 进行处理

"DataEdit.aspx?DataId=1&DataName=" + Server.UrlEncode(Request.QueryString["DataName"].ToString();

进行跳转等处理
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐