记一次URL参数处理

Posted Stupid_Bire

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了记一次URL参数处理相关的知识,希望对你有一定的参考价值。

由于需要前台传入一些加密值到服务器后端,前端参数直接填入一个隐藏的input中,当需要的时候取这个值进行url传参。

并且这个参数值,本身是由服务端加密的字符串。

后台已经使用

var str="xxx";
HttpUtility.UrlEncode(str);

UrlEncode方法进行转换。

 

问题:

转换后的值在Url传参时,在服务端接收时已经进行处理,会有“ ”(空格出现),其实这个“ ”(空格)真实字符为“+”,需要特殊处理。

 

作为记录,供参考。

有更好思路请留言。

记一次解密的坑

做项目遇到请求对方页面,对方返回的参数串直接拼接到我的URL上,是一个加密串.

因为忘记了之前有URLEncoder这个步骤, 解密的时候没有使用URLDecoder进行解密, 直接使用AES解密遇到报错,

Input length must be multiple of 16 when decrypting with pad

还可能报

Illegal base64 character

皆是因为我少了一步URL解密, 先URL解密后再AES解密,解密成功.

这次的坑希望以后不会再踏了, 经验不足啊~~~~~~~

 

以上是关于记一次URL参数处理的主要内容,如果未能解决你的问题,请参考以下文章

记一次 CesiumJS 中非 4326/3857 WMTS 数据的加载

记一次URL重定向漏洞的探测脚本的优化

记一次OOM查询处理过程

记一次线上问题排查:C#可选参数的坑

记一次抽象类中定义的静态变量,多个子类继承后,在方法中被重写引起的问题

记一次http网站换成https的处理