前台js escape及后台C# Server.UrlEncode 对QueryString传参的含~!@#$%^&*等特殊字符的处理 通常情况下,我们在List列表页面,会包含Create,Edit

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

通常情况下,我们在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();

   进行跳转等处理

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值