URL传递如“+”等特殊参数的处理方式

网上很多都说用POST方法可以避免这个问题,但是,并没有。还有说使用encodeURIComponent()加密两次,后端再用URLDecoder解密两次的,也不行。

直接上答案:
encodeURIComponent()加密2次
URLDecoder解密1次。

为什么加密2次,但是解密1次?

var question = encodeURIComponent(encodeURIComponent(input.value))
				//ajax方式,发送问句
				ajax({

					url : '/rest/lh/question/query?question='+question,
public String query(@RequestParam(value = "question") String question, HttpSession session,HttpServletRequest request) throws Exception {
		question = URLDecoder.decode(question,"utf-8");

这是因为后端再给传入的参数赋值时,已经解码过一次了,所以,我们只需要经过一次解码即可得到原始字符串。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值