当前开发中,遇到特殊情况: 使用url进行跨页面(跨域)传值的时候,会出现某些带特殊字符的url,在浏览器上被处理了,例如:

后端传给前端的跳转路径:

http://127.0.0.1:8088/harbor/sign-in?userName=admin&userPassword=1Qaz2wsx#

浏览器跳转时浏览器地址栏的url变成:

http://127.0.0.1:8088/harbor/sign-in?userName=admin&userPassword=1Qaz2wsx

注意:末尾处的#不见了

还有其他情况,如url中的参数有 "/" "&" "@" "&" 特殊字符时,url都会出现错误...

解决方案: 使用URL的编码和解码 对 特殊字符进行处理

1. java 后端的解决:

方法 解释
URLEncoder.encode(String s, String enc) 

编码

s - 要转换的 String。
enc - 所支持的字符编码名称。

URLEncoder.decode(String s, String enc) 

解码

s - 要转换的 String。
enc - 所支持的字符编码名称。

对 String 编码时,使用以下规则:

  • 字母数字字符 "a" 到 "z"、"A" 到 "Z" 和 "0" 到 "9" 保持不变。
  • 特殊字符 "."、"-"、"*" 和 "_" 保持不变。
  • 空格字符 " " 转换为一个加号 "+"。
  • 所有其他字符都是不安全的,因此首先使用一些编码机制将它们转换为一个或多个字节。然后每个字节用一个包含 3 个字符的字符串 "%xy" 表示,其中 xy 为该字节的两位十六进制表示形式。推荐的编码机制是 UTF-8。但是,出于兼容性考虑,如果未指定一种编码,则使用相应平台的默认编码。

例如,使用 UTF-8 编码机制,字符串 "The string ü@foo-bar" 将转换为 "The+string+%C3%BC%40foo-bar",因为在 UTF-8 中,字符 ü 编码为两个字节,C3 (十六进制)和 BC (十六进制),字符 @ 编码为一个字节 40 (十六进制)。

//String str = "1Qaz2wsx#";try {String encode = URLEncoder.encode(str, "utf-8");//编码System.out.println(encode);String decode = URLDecoder.decode(encode, "utf-8");//解码System.out.println(decode);} catch (UnsupportedEncodingException e) {e.printStackTrace();}//显示:
1Qaz2wsx%23
1Qaz2wsx#

后端特殊处理后,传给前端的url变为:

http://127.0.0.1:8088/harbor/sign-in?userName=admin&userPassword=1Qaz2wsx%23

2. js 前端的解决

方法 解释
encodeURIComponent(str);

编码

str- 要转换的 String。

decodeURIComponent(str);

解码

str - 要转换的 String。

例如:

var password = decodeURIComponent("1Qazwsx%23");
console.log(password);//显示结果  1Qazwsx#

其他的变法解码方式:

示例(摘自W3School):

1 escape()

<script type="text/javascript">
document.write(escape("Visit W3School!") + "<br />")
document.write(escape("?!=()#%&"))
</script>

输出结果:

Visit%20W3School%21
%3F%21%3D%28%29%23%25%26

2 encodeURI()

<html>
<body>
<script type="text/javascript">
document.write(encodeURI("http://www.w3school.com.cn")+ "<br />")
document.write(encodeURI("http://www.w3school.com.cn/My first/")+ "<br />")
document.write(encodeURI(",/?:@&=+$#"))
</script>
</body>
</html>

输出结果:

http://www.w3school.com.cn
http://www.w3school.com.cn/My%20first/
,/?:@&=+$#

对整个URL进行编码,而URL的特定标识符不会被转码。

3  encodeURIComponent()

<script type="text/javascript">
document.write(encodeURIComponent("http://www.w3school.com.cn"))
document.write("<br />")
document.write(encodeURIComponent("http://www.w3school.com.cn/p 1/"))
document.write("<br />")
document.write(encodeURIComponent(",/?:@&=+$#"))
</script>

输出结果:

http%3A%2F%2Fwww.w3school.com.cn
http%3A%2F%2Fwww.w3school.com.cn%2Fp%201%2F
%2C%2F%3F%3A%40%26%3D%2B%24%23

对URL中的参数进行编码,因为参数也是一个URL,如果不编码会影响整个URL的跳转。

关于将URL中的特殊字符进行转码和解码相关推荐

  1. android处理url中的特殊字符

    java处理url中的特殊字符(如&,%...) URL(Uniform Resoure Locator,统一资源定位器)是Internet中对资源进行统一定位和管理的标志. 一个完整的URL ...

  2. java处理url中的特殊字符%等

    java处理url中的特殊字符(如&,%...) URL(Uniform Resoure Locator,统一资源定位器)是Internet中对资源进行统一定位和管理的标志. 一个完整的URL ...

  3. java 特殊字符过滤器_java处理url中的特殊字符

    java处理url中的特殊字符(如&,%...) URL(Uniform Resoure Locator,统一资源定位器)是Internet中对资源进行统一定位和管理的标志. 一个完整的URL ...

  4. JS中URL中的特殊字符问题:escape,encodeURI,encodeURIComponent(转)

    在使用url进行参数传递时,经常会传递一些中文名(或含有特殊字符)的参数或URL地址,在后台处理时会发生转换错误.在有些传递页面使用GB2312,而在接收页面使用UTF8,这样接收到的参数就可能会与原 ...

  5. Nginx配置 转发URL中包含特殊字符

    Nginx经常被用来作为代理服务器,可以有效的避免跨域问题. 老项目需要对接一个新的服务,但是存在跨域问题,然后就配置了一个代理 可是突然在某天,新接口出现了异常.接口报了400错误. # 转发 lo ...

  6. 微信小程序 webview 传递URL中含有特殊字符-,=

    解决办法:先encodeURIComponent,取到值以后再decodeURIComponent

  7. spring restTemplate的坑----会对String类型的url中的特殊字符进行转义

  8. js获取url中的参数,url中传递中文的时候通过js解码的方式

    如果传递的参数是: <a href="${pageContext.request.contextPath}/productdisplay/productDisplay_productD ...

  9. 033 Url中特殊字符的处理

    在url跳转页面的时候,参数值中的#不见了,一直没有处理,今天有空看了一下,后来发现后台的过滤器之类的都没有处理,就比较奇怪了,原来是特殊字符的问题. 一:Url中的特殊字符 1.说明 这里还是需要做 ...

最新文章

  1. 如何为 Python 添加远程调试能力而不修改系统代码
  2. Android全屏与透明状态栏
  3. 通过Java和Spring Boot应用程序将Gmail用作SMTP服务器
  4. 恒位油杯故障原因_抽油烟机常见故障及处理方法
  5. 信息学奥赛一本通 1107:校门外的树 | 1931:【05NOIP普及组】校门外的树 | OpenJudge NOI 1.6 06 | 洛谷 P1047 [NOIP2005 普及组] 校门外的树
  6. About Gaelyk
  7. hyphenation
  8. 三维人体姿态估计年度进展综述(周晓巍教授)
  9. Django框架详解
  10. 【浅谈】样本方差的分母“n”为什么要改为“n-1”
  11. ArcGIS矢量数据重分类
  12. 威纶触摸屏如何组态设置离散量报警及报警历史记录?
  13. 3.5 上标下标和特殊符号的输入 [原创Excel教程]
  14. php 教程推荐,php基础入门视频教程合集推荐
  15. 再战港交所的高视医疗,近视小伙伴的福音?
  16. 无线局域网中iPhone无法访问IIS
  17. 2022-2028年中国保健食品行业市场运营格局及前景战略分析报告
  18. VC - vs2017里poco的websocket使用netssl
  19. 参考文献起止页码怎么写_怎么看论文的起止页码
  20. 【虾皮选品分享】马来西亚/菲律宾市场时尚美妆热销趋势

热门文章

  1. 小黄鸭调试法,每个程序员都要知道的
  2. 提供对外接口时,要注意的地方
  3. linux查看软连接实际地址,linux 软连接怎么查看原始地址?
  4. CC1310手册的射频核心介绍
  5. 关于js获取id的函数封装
  6. PRO/E产品设计如何将两个零件合并在一起
  7. 美云智数采购云SRM,助力企业实现数字化转型
  8. 智能中控:开启电动车智能化时代
  9. ACM-–模拟打印–-湘大OJ 1086--菱形--水
  10. selenium模块太强大了,网易云音乐都可下载