Java中前端传参含有“+”“=”等特殊字符处理方式
前端在进行base64加密或者AES等加密手段的时候,生成的字符串很可能存在“+”“=”“/”等特殊字符。这些字符如果不进行特殊处理,在进行参数传递的时候,会出现错误。
比如“+”如果不经过处理,传到Java后台之后,就变成空格了,“=”就直接没了。。。。
处理方式:
在js中,对url的加密分别由三种方式:
escape("aa+aa aa")
加密后:"aa+aa%20aa"
encodeURI("aa+aa aa")
加密后:"aa+aa%20aa"
+变成%2B
encodeURIComponent("aa+aa aa")
加密后:"aa%2Baa%20aa"java加密代码:
// 加号变成%2B,空格变成加号
System.out.println(URLEncoder.encode("aa+aa aa","UTF-8"));
aa%2Baa+aa正常情况下,前端使用encodeURIComponent("aa+=")加密之后,传到Java后台,直接就是可以使用的,不需要再进行其它操作
如果发现不能直接使用,只需要根据实际的情况,进行字符串替换即可,比如replace("2B%","+")。
到此这篇关于Java中前端传参含有“+”“=”等特殊字符处理的文章就介绍到这了,更多相关java传参特殊字符处理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
解决Java中socket使用getInputStream()阻塞问题
这篇文章主要介绍了解决Java中socket使用getInputStream()阻塞问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-12-12
SpringBoot 集成 ShedLock 分布式锁的示例详解
ShedLock是一个在分布式环境中使用的定时任务框架,用于解决在分布式环境中的多个实例的相同定时任务在同一时间点重复执行的问题,本文重点给大家介绍SpringBoot 分布式锁ShedLock的相关知识,感兴趣的朋友一起看看吧2021-08-08


最新评论