Java中和encodeURI()功能相同的转码类

本文介绍了一种解决IE浏览器不自动编码URL中中文字符的问题,通过自定义Java方法模仿前端encodeURI()函数行为,仅对中文进行编码,避免了全量URL编码带来的额外工作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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


}

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值