VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
当前位置:
首页 > temp > python入门教程 >
  • 【问题管理】-- restTemplate请求get方式中url包含+、空格、%、_等特殊符号

在实际项目中,我们经常会遇到get方式进行参数传递,而前端到后台,后台调用第三方接口API,这里往往涉及到很多编码转换的场景,前后端编码方式不一致,tomcat服务端编码设置远程API接口编码不一致,多种方式都有可能在url传输的过程中涉及到传递的参数(尤其是特殊字符)在url请求上转换不一致导致请求异常或者请求到不想要的东西。这里就需要我们使用如下方式进行特殊字符的转换:

1.转义特殊字符

将特殊字符进行编码转义替换:

这里一般是采用后端接口Vo层set方法进行replaceAll替换特殊字符,转义替换为不能被浏览器转换的编码格式:

复制代码
+ (URL 中+号表示空格) ——>   %2B   
空格 (URL中的空格可以用+号或者编码) ——>   %20 
/ (分隔目录和子目录) ——>  %2F     
? (分隔实际的URL和参数) ——>  %3F     
% (指定特殊字符) ——>  %25     
# (表示书签) ——>  %23     
& (URL中指定的参数间的分隔符)——>  %26     
= (URL中指定参数的值)——>  %3D
复制代码

注:

HTTP协议中 + 号转译为 %2B
HTTPS协议中 + 号转译为 %20

2.使用POST方式进行提交

使用post进行restTemplate方式进行url参数方式提交,避免url在编码上的转换

3.sql语句中使用escape

escape语句如下,表示/后面的%不再作为转义字符,而是当做'%'这个字符来进行匹配:

select username from gg_user where username like '%xiao/%%' escape '/';

具体escape用法可以查看另一篇博文:

sql语句中escape的用法

 

https://www.xin3721.com/Articletsql/sql35212.html


出  处:https://www.cnblogs.com/yif0118/p/15646468.html


相关教程