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%","+")。

如果还有其它请指正

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
前端传参 "signFields": \[ "WJ", "FJ" \] 后端Java如何接收? 在后端Java,可以使用数组或List来接收前端传递的参数。假设前端传递的参数名为"signFields",可以在后端定义一个与之对应的数组或List类型的参数。例如,可以使用String\[\]或List<String>来接收前端传递的字符串数组。 示例代码如下: ```java public void receiveSignFields(String\[\] signFields) { // 处理接收到的参数 for (String field : signFields) { System.out.println(field); } } ``` 或者使用List<String>来接收: ```java public void receiveSignFields(List<String> signFields) { // 处理接收到的参数 for (String field : signFields) { System.out.println(field); } } ``` 通过以上代码,可以将前端传递的字符串数组\["WJ", "FJ"\]分别打印出来。这样就可以在后端Java接收并处理前端传递的参数了。 #### 引用[.reference_title] - *1* *2* [java-关于值传参和引用传参:c-值传递和指针传递](https://blog.csdn.net/qq_25652949/article/details/79134214)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [base64上传文件,后端接受处理(四)](https://blog.csdn.net/hanshanyunhai/article/details/121831201)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值