美文网首页
实战-长短链接转换

实战-长短链接转换

作者: 红色的飞猪 | 来源:发表于2019-03-06 13:44 被阅读0次

需求背景

在业务中开发过程中多次遇到了长短链接转换的需求,类似如下背景。

  1. 分享需求(剪切板);参数过多,不适于用户提现,需要长转短,短转长。(类似天猫在微信分享)
  2. 广告需求;广告的落地页是广告主提供,但是有些广告主的页面竟然不支持https,业务中会将所有http强转https。解决方案:先将广告主的落地页,转为短连接,短连接重定向广告主落地页。
  3. 二维码分享需求; 链接参数过长,二维码过于密集,在有些设备上无法识别。

解决方案

解决方案的整体思路很简单: 长转短-短转长

  1. 懒人的办法,找开放的api。
采用百度api,
https://dwz.cn/console/apidoc 

测试效果稳定。但是因为外网权限以及app发起短连接调用后端完全无感知,所以弃用。

  1. 重造轮子

请求流程

image

在左图中,不同的需求对短连接的有效期要求不同,因此临时性短链接不进行入库。
右图中,根据短连接区分type,来确认是否需要查库。
整个流程中,核心就是短连接的生成算法。

代码实现(主要是短连接生成逻辑 ,核心代码网上都是这一个)

private static final String[] DICTS = new String[]{
            "a", "b", "c", "d", "e", "f", "g", "h",
            "i", "j", "k", "l", "m", "n", "o", "p",
            "q", "r", "s", "t", "u", "v", "w", "x",
            "y", "z", "0", "1", "2", "3", "4", "5",
            "6", "7", "8", "9", "A", "B", "C", "D",
            "E", "F", "G", "H", "I", "J", "K", "L",
            "M", "N", "O", "P", "Q", "R", "S", "T",
            "U", "V", "W", "X", "Y", "Z"
    };

    private static final String SECRET_KEY = "juejinim";

    public static String[] genShortUrl(String url) {
        //对传入网址进行base64和MD5加密
        String base64 = Base64.encode(SECRET_KEY + url);
        String hexUrl = Md5Util.MD5Encode(base64);
        String[] resUrl = new String[4];
        for (int i = 0; i < 4; i++) {
            //把加密字符按照8位一组16进制与0x3FFFFFFF(2^30)进行位与运算
            long hexLong = 0x3FFFFFFF & Long.parseLong(hexUrl.substring(i * 8, i * 8 + 8), 16);
            String outChars = "";
            for (int j = 0; j < 6; j++) {
                //把得到的值与0x0000003D(62,数组的长度是62)进行位与运算,取得字符数组DICTS索引
                int index = (int) (0x0000003D & hexLong);
                //把取得的字符相加
                outChars += DICTS[index];
                //每次循环按位右移5位
                hexLong = hexLong >> 5;
            }
            //把字符串存入对应索引的输出数组
            resUrl[i] = outChars;
        }
        return resUrl;
    }

上面的处理思路就是:
1. 短码的构成字母+数字,因此构造了DICTS。
2. 剩下的问题就是计算索引的问题。
3. 计算索引--长url转化为Number型。
4. 长URL转化为NUmber型--可以直接Md5转化为字符+数字,然后转化为数字。

相关文章

  • 实战-长短链接转换

    需求背景 在业务中开发过程中多次遇到了长短链接转换的需求,类似如下背景。 分享需求(剪切板);参数过多,不适于用户...

  • 长短链接转换

    你有没有遇到过这样的情况? 上网的时候,发现有意思的网站想分享给他人,但是复制链接,发送之后,会发现...

  • 长短链接

    长连接的概念 HTTP 的请求是在 TCP 连接的基础上发送的,而 TCP链接分为长连接和短连接。 长连接:HTT...

  • 《Vue.js实战》学习笔记 -时间转换指令

    Vue.js实战 时间转换指令

  • freeCodeCamp 旅途10 - 算法实战

    项目实战:回文检查器 项目实战:罗马数字转换器 项目实战:凯撒密码 项目实战:电话号码验证器 项目实战:收银机

  • Java

    Since Oct.3rd,2016 注释 数据类型的转换 自动转换Java 开发实战经典 强制转换Java 开发...

  • R语言长短数据转换

    R数据格式转换tidyr包:reshape2的替代者,功能更纯粹R 学习笔记:tidyr 包整理数据的利器 gat...

  • JavaScript相等操作符(==)

    参考:链接1链接2链接3 两组操作符 相等:==(先转换再比较)全等:===(仅比较不转换) 相等(==)规则 B...

  • TF-IDF算法原理介绍

    参考文章链接1 参考文章链接2 TF-IDF算法代码实战

  • scala隐式转换

    双刃剑,可以简化代码,但是会增加维护成本 实战 隐式转换切面封装 隐式类转换

网友评论

      本文标题:实战-长短链接转换

      本文链接:https://www.haomeiwen.com/subject/ugptpqtx.html