当你看到这里的时候,我不知道你是不是已经看了很多没用的博客?一顿乱干,没解决问题,使用什么URLEncoder.encode()方法啥的。注意:Java 中的URLEncoder.encode()方法和JS中的encodeURI()完全划不上等号!
我的问题:后台从某个接口中查询到一个字段,字段的填充值为一长串url,并且其中还带着中文,这个时候前端拿到url直接取访问页面,在谷歌等浏览器上是正常的,但是如果到了IE,草,又是IEl浏览器,竟然不自动将url中中文转为两个十六进制数字,(即标准ASCII字符,谷歌等浏览器自动转换。)
首先,看看JS的方法encodeURI()定义:
encodeURI() 函数可把字符串作为 URI 进行编码,对以下在 URI 中具有特殊含义的 ASCII 标点符号,encodeURI() 函数是不会进行转义的。
但是URLEncoder.encode()会对特殊字符转义的。
如果你得url中老长了,而且你还不知道在哪个地方出现中文(需要转码),而且你还想像前端的encodeURI()这个函数一样只转码中文。那接下来你得救了。
虽然没有和encodeURI()一样的函数,但是咱们可以写啊,那就开干吧。
直接贴上方法,你肯定看的懂:
public class URLEncodeUtil {
public static String navticeEncode(String url) throws Exception {
String resulUrl= "";
//遍历字符串
for (int i = 0; i < url.length(); i++) {
char charIndex = url.charAt(i);
if (isChinese(charIndex )) {
//如果是中文,则对中文转码
resultURL += URLEncoder.encode(charAt+"","UTF-8");
}else {
resultURL+=charAt;
}
}
return resulUrl;
}
/**
* 是否是中文字符
* @param c
* @return
*/
public static boolean isChinese(char c) {
return String.valueOf(c).matches("[\u4e00-\u9fa5]");
}
}