坚果大叔 坚果大叔
  • 首页
  • 闲言碎语
  • 技术
  • 生活
  • 记录
  • 朋友
  • 热点新闻
  • 常用代码
  • 工具箱
  • 关于
首页 › 技术 › 使用encodeURI出现URI malformed报错?

使用encodeURI出现URI malformed报错?

坚果大叔
2023-03-14 16:38:10技术阅读 5,015

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

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

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

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

不安全符号 解释
空格 Url在传输的过程,或者用户在排版的过程,或者文本处理程序在处理Url的过程,都有可能引入无关紧要的空格,或者将那些有意义的空格给去掉
引号以及<> 引号和尖括号通常用于在普通文本中起到分隔Url的作用
# 通常用于表示书签或者锚点
% 百分号本身用作对不安全字符进行编码时使用的特殊字符,因此本身需要编码
{}\^[]`~ 某一些网关或者传输代理会篡改这些字符

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

const str = "50%";
const newStr = str.replace(/%/g, "");

或者

const str = "50%";
const newStr = str.replace(/%/g, '%25');

或者

decodeURI(escape(字符串))
赞赏 赞(1)
周末,公园,人多!!!
上一篇
3月已到月底,今年已过四分之一!
下一篇
在小程序中查看
搜你想看的
聚合文章
假期最后一天
一款高仿mac版微信的单页面应用(还在更新中)
好久没有出太阳了。
永远的曼巴
闲言碎语
Memos
npm install 出现 Error:EISDIR:illegal operation on a directory 的错误提示!
2025-03-31 19:02:11
551 0 0
iphone 利用 Scriptable 添加网上国网电费小组件
2025-01-06 20:40:20
4,938 6 2
在博客中加上memos记录展示。
2024-12-25 23:41:27
2,295 5 2
网页点击平滑滚动效果~
2024-10-17 16:43:08
2,011 4
1
  • 1
博主

一位佛系的前端开发者,略通摄影,乐于尝试新事物,热衷于美食。

友链
故事胶片
公众号
坚果大叔 执行上下文 卖坚果的怪叔叔 Dacking
Copyright © 2017-2025 坚果大叔

开往-友链接力

萌ICP备20230818号

苏ICP备18048410号-3
  • 首页
  • 闲言碎语
  • 技术
  • 生活
  • 记录
  • 朋友
  • 热点新闻
  • 常用代码
  • 工具箱
  • 关于
# CSS # # JavaScript # # vue # # 微信 # # 生活 #
坚果大叔
317
文章
125
评论
365
喜欢