前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用encodeURI出现URI malformed报错?

使用encodeURI出现URI malformed报错?

作者头像
执行上下文
发布2023-07-24 16:46:34
7450
发布2023-07-24 16:46:34
举报
文章被收录于专栏:执行上下文执行上下文

今天在一个业务模块中遇到一个问题。在点击导出后出现了 URI malformed 报错提示。

一开始我以为是进行 encode 加密的时候将搜索对象进行了 JSON 序列化导致的。然后就将 JSON.stringify 去掉了,发现还是不行。

然后经过排查发现只有在查询条件 Name 字段输入值后,点击导出才会报错。对比发现 Name 字段相比其他字段多加上了 % 的前缀和后缀,把 % 去掉之后发现一切正常。

然后查找后发现浏览器在对 % 执行 decodeURI、decodeURIComponent、encodeURI、encodeURIComponent 的时候会报错。因为 % 在浏览器属于不安全字符。如下:

不安全符号

解释

空格

Url在传输的过程,或者用户在排版的过程,或者文本处理程序在处理Url的过程,都有可能引入无关紧要的空格,或者将那些有意义的空格给去掉

引号以及<>

引号和尖括号通常用于在普通文本中起到分隔Url的作用

#

通常用于表示书签或者锚点

%

百分号本身用作对不安全字符进行编码时使用的特殊字符,因此本身需要编码

{}\^[]`~

某一些网关或者传输代理会篡改这些字符

所以只需要将 % 转义为 %25 或者直接将 % 替换掉。具体的实现办法如下,可以看实际的需求来操作。

代码语言:javascript
复制
const str = "50%";
const newStr = str.replace(/%/g, "");

或者

const str = "50%";
const newStr = str.replace(/%/g, '%25');或者const newStr = decodeUrl(escape(字符串));
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2023-03-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 执行上下文 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档