前言
当你搜到这篇文章,我感觉多半是因为对接了.NET的相关接口。
在C#里面,使用HttpUtility.UrlEncode(xxx); 出来的值,% 后面的字母是小写的;
而在java里面,URLEncoder.encode(xxx, "utf-8"); 出来的值, % 后面的字母是大写的;
正文
加密
将url编码函数加密后的值,% 后面的字母转为小写, 使其与C# 使用
HttpUtility.UrlEncode(xxx)的值一样:
public static String getEncode(String needEncodeStr) throws UnsupportedEncodingException { String encodeStr = URLEncoder.encode(needEncodeStr, "utf-8"); String[] uppercase = new String[0XFF + 1]; String[] lowercase = new String[0XFF + 1]; for (int i = 0; i <= 0XFF; i++) { uppercase[i] = "%" + String.format("%02x", i); lowercase[i] = uppercase[i]; uppercase[i] = uppercase[i].toUpperCase(); } return StringUtils.replaceEach(encodeStr, uppercase, lowercase); // StringUtils.replaceEac :org.apache.commons.lang3.StringUtils; }
测试,可以看到如愿,%后的大写字母已经变成小写,而且是针对特殊的符合转换的那一部分:
public static void main(String[] args) throws UnsupportedEncodingException { String needEncodeStr="https://jcTest.com"; String encodeStr = URLEncoder.encode(needEncodeStr, "utf-8"); System.out.println("正常java的url编码函数加密后:"+encodeStr); String encodeStrNew = getEncode(needEncodeStr); System.out.println("大写字母变小写的处理后:"+encodeStrNew); }
解密
那么如果涉及到url编码函数解密,上面得到的小写字母值,
用java的URLDecoder.decode(xxx,"UTF-8");
String encodeStr="https%3a%2f%2fjcTest.com"; String decode = URLDecoder.decode(encodeStr, "UTF-8"); System.out.println(decode);
测试结果:
可以看到解密的时候,%后面的小写大写并没有什么影响,还是能正常解密。
但是如果你不放心,那么可以先将%后面的小写字母重新转换回大写,再进行解密,也是可以的。
String encodeStr="https%3a%2f%2fjcTest.com"; String decode1 = getDecode(encodeStr); System.out.println(decode1);
public static String getDecode(String encodeStr) throws UnsupportedEncodingException { String[] uppercase = new String[0XFF + 1]; String[] lowercase = new String[0XFF + 1]; for (int i = 0; i <= 0XFF; i++) { uppercase[i] = "%" + String.format("%02x", i); lowercase[i] = uppercase[i]; uppercase[i] = uppercase[i].toUpperCase(); } String s = StringUtils.replaceEach(encodeStr, lowercase, uppercase); return URLDecoder.decode(s,"UTF-8"); }
测试结果: