使用javascript的encodeURIComponent出现的问题

本文探讨了使用javascript的encodeURIComponent在不同环境下导致的乱码问题。分析了开发与线上环境中字符编码差异的原因,并提供了修改server.xml文件来统一字符编码的解决方案。

使用javascript的encodeURIComponent出现的问题

Symptom

在前端是使用encodeURIComponent进行转义的时候,在开发和线上环境出现了不同的表现。

前台传汉字过来,开发的时候直接过来是乱码,需要从ISO-8859-1转换成UTF-8才是正确的汉字

在线上却是直接就是汉字

Analyze

项目肯定需要配置CharacterEncodingFilter,如果是spring boot项目的话自动已经配置了,默认的字符集是UTF-8。如果是spring mvc项目的话,那么需要手动配置。

这样子就能设置好request和response的encoding。

观察线上和开发环境不同的是,在线上环境配置了:

export URI_ENCODING = UTF-8

那么肯定是因为这个才造成的差别。查一下就查到了tomcat的encoding配置,默认是iso-8859-1。

Solution

修改开发环境默认的encoding, 配置的方式是:

修改server.xml,在connector标签中设置<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" URIEncoding="UTF-8" />

添加环境变量应该也可以,不过在Windows上没有测试.

### JavaScript 中 `encodeURIComponent` 的用法 `encodeURIComponent` 是一个用于对 URI 组件进行编码的内置 JavaScript 函数。它会对字符串中的非 ASCII 字符以及具有特殊含义的标点符号进行转义,确保生成的字符串可以安全地作为 URI 的一部分使用[^1]。 #### 主要特点 - 该函数会将除了字母、数字以及以下字符 `- _ . ! ~ * ' ( )` 以外的所有字符转换为百分号 `%` 后跟两位十六进制数的形式。 - 它特别适用于对 URI 查询字符串中的键或值进行编码[^4]。 #### 参数说明 - `uri`: 必需参数,表示需要被编码的 URI 组件或其他文本字符串。 #### 示例代码 以下是一个使用 `encodeURIComponent` 的示例: ```javascript var uri = "http://example.com/my test.php?name=ståle&car=saab"; document.write(encodeURIComponent(uri)); ``` 上述代码的输出结果为: ``` http%3A%2F%2Fexample.com%2Fmy%20test.php%3Fname%3Dst%C3%A5le%26car%3Dsaab ``` 在实际应用中,通常会结合表单数据来构造查询字符串。例如: ```javascript for (var i = 0; i < whichform.elements.length; i++) { var element = whichform.elements[i]; dataparts[i] = element.name + '=' + encodeURIComponent(element.value); } ``` 此代码片段展示了如何对表单元素的值进行编码并拼接成查询字符串的一部分[^3]。 #### 与 `encodeURI` 的区别 需要注意的是,`encodeURIComponent` 和 `encodeURI` 虽然功能相似,但存在关键差异。`encodeURI` 不会对某些在 URI 中具有特殊意义的字符(如 `?`, `#`, `&` 等)进行编码,而 `encodeURIComponent` 则会对这些字符进行编码。 #### 注意事项 当处理包含多维数组或复杂对象的数据时,建议先将其序列化为 JSON 字符串,然后再使用 `encodeURIComponent` 进行编码,以避免因特殊字符未被正确转义而导致的问题[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值