• Java前后端分离项目生成二维码链接带中文参数遇到的问题及解决办法


    遇到的问题

    最近项目做二维码分享链接过程中遇到了个小问题,使用Java后端生成二维码链接时,当拼接的参数中带有中文,使用手机浏览器扫码正常,但是用微信扫码,url中的中文被和谐掉了,导致页面显示有问题。

    解决办法

    解决方案首先想到的就是url编码以及转码,即后端将url进行编码,然后在前端进行解码。下面分享一种网上找到的博主的解决办法,留作备忘。

    • 后端创建编码工具类 UriEncoder(核心方法如下)
    public static String encodeURIComponent(String input)
        {
            if (null == input || "".equals(input.trim()))
            {
                return input;
            }
    
            int l = input.length();
            StringBuilder o = new StringBuilder(l * 3);
            try
            {
                for (int i = 0; i < l; i++ )
                {
                    String e = input.substring(i, i + 1);
                    if (ALLOWED_CHARS.indexOf(e) == -1)
                    {
                        byte[] b = e.getBytes("utf-8");
                        o.append(getHex(b));
                        continue;
                    }
                    o.append(e);
                }
                return o.toString();
            }
            catch (UnsupportedEncodingException e)
            {
                e.printStackTrace();
            }
            return input;
        }
    
        private static String getHex(byte buf[])
        {
            StringBuilder o = new StringBuilder(buf.length * 3);
            for (int i = 0; i < buf.length; i++ )
            {
                int n = (int)buf[i] & 0xff;
                o.append("%");
                if (n < 0x10)
                {
                    o.append("0");
                }
                o.append(Long.toString(n, 16).toUpperCase());
            }
            return o.toString();
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 在项目拼url链接中使用(示例)
    String act_name_encode = UriEncoder.encodeURIComponent(act_name);
    
    • 1
    • 前端解析链接(不需要解码)uniapp 解析示例
    let routes = getCurrentPages(); // 获取当前打开过的页面路由数组
    
    //如果是H5,则需要curPage.$route.query(H5中的curPage.options为undefined)
    let curParam = routes[routes.length - 1].options || routes[routes.length - 1].$route.query; //获取路由参数
    //获取参数
    let param = [];
    for (let key in curParam) {
        param.push(curParam[key]);
    }
    let act_name = param[0];
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
  • 相关阅读:
    推特的算法规则你知道多少?
    sql查询之模糊查询
    Python in Visual Studio Code 2023年11月发布
    PTA 7-77 查找指定字符
    linux进程概念(下)
    第一次接触web前端开发
    C# 静态构造函数未执行 .net core框架
    【Redis】字符串sds
    [SUCTF 2019]Pythonginx
    【Java八股文总结】之JVM
  • 原文地址:https://blog.csdn.net/Jason_We/article/details/126324294