当你看到这里的时候,我不知道你是不是已经看了很多没用的博客?一顿乱干,没解决问题,使用什么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]");
    }


}