js 使用get 接口如何传递 特殊字符给后端,类似 # 等特殊字符

今天开发遇到个问题。用户输入了 # 怎么把文本完整的传递给后端

如果直接传输就会出现

# 之后的东西全都没有,

解决方法如下:

1,使用其他特殊字符代替,使用replaceAll  

// 使用replaceAll  替换所有 #,然后后端再替换回来
let newStr =  newQue.replaceAll('#','&')

  缺点,会影响到其他特殊字符的传递

2,使用加密传输,前端加密后,后端解密即可

var code = 'coasd@@!啊是的撒啊实打实2安师大1安师大@#@#¥#%¥%¥……\n\n\n阿萨德23阿打算llo")';
var en = escape(code);
var de = unescape(en);
console.log(en)
console.log(de)  

 缺点,加密后的文本更长。容易导致get接口长度超长

3,使用  encodeURIComponent

根据官方文档可知   文档链接

encodeURIComponent() 函数可把字符串作为 URI 组件进行编码。

该方法不会对 ASCII 字母和数字进行编码,也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ' ( ) 。

其他字符(比如 :;/?:@&=+$,# 这些用于分隔 URI 组件的标点符号),都是由一个或多个十六进制的转义序列替换的。

 使用方法,在接口发送之前对目标参数

newQue = encodeURIComponent(newQue)

 结果

 

posted @ 2023-07-01 17:48  fanjiajia  阅读(718)  评论(0)    收藏  举报