ajax中post方法传参数,会丢失&,%,+',要转义

本文讨论了在使用Ajax进行POST请求时,对于特殊字符如'+'和'&'无法通过JavaScript的encodeURI()进行正确编码的问题,并提供了手动转义的方法。包括将'+'替换为'%2B','&'替换为'%26',以及对'%'进行相应的处理。文章还提供了代码示例,展示了如何在验证用户名和密码时进行必要的转义操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ajax中post的escape对有些特殊字符无法转换,例如:+ % &号,因此需要对其进行转义。

如果不然,Http传输就会丢失这个字符,这个时候必须将“+”手动转成 “%2B”,同时需要手动转的字符还有“&”->“%26”,“%”->“%25”等。这几个特殊字符是不能用javascript的encodeURI()来编码的,所以即使“笨”一点手动转那也是没办法。不过除了这三个顽固的家伙,尚未发现其它字符也需要在POST方式提交XML文本的情况下先作转。

  1. if (password != null && password != "")  
  2.     {  
  3.         password=password.replace(//+/g, "%2B");  
  4.         password=password.replace(//&/g, "%26");  
  5.     }  
  6.     if (username != null && username != "")  
  7.     {  
  8.         username=username.replace(//+/g, "%2B");  
  9.         username=username.replace(//&/g, "%26");          
  10.     } 

原贴地址:http://blog.youkuaiyun.com/budapest/article/details/5462435#




.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值