Java实现短链接生成

本文围绕短链接实现展开,介绍了将长URL映射为短URL的思路。包括使用Redis的hash或key - value保存长短URL映射关系,借鉴新浪短链接算法生成短URL,以及通过解密接口还原长连接。还提及了短链接简单方便、节约带宽、更安全等好处。

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

问题:

短链接在生活中无处不见,比如:
image.png
如何实现呢?

思路:

将长的url(“https://blog.csdn.net/weixin_43505211?spm=1000.2115.3001.5343”)映射成短的url(https://blog.csdn.net/c4xV4F),后面一般是6为字符串,并不强制只是6位,可以自定义.

1. 如何保存短Url和长Url的映射关系?

可以使用redis的hash,当然也可以使用redis的key-value去实现,使用redis的hash结构呢,能将相同业务的短链接放到一个Key里面去管理.

2. 如何生成短Url?

一借鉴流传的新浪短链接算法,短Url实现算法思路:

  1. 将长网址的md5生成32位签名串,分为4段,每段8个字节;
  2. 对这四段循环处理,取8个字节,将他看成16进制串与0x3fffffff(30位1)与作,即超过30位的忽略处理:
  3. 这30位分成6段,每5位的数字作为字母表的索引取得特定字符,次进行获得6位字符串;(可自定义位数)
  4. 总的md5串可以获得4个6位串;取里面的任意一个就可作为这个长url的短urL地址;如果万一出现重复可以换一个,自行组逻辑

3.如何还原长连接?

可以开一个用于解密的接口,将Redis中的缓存的真实的URL返回.

新浪短链接算法代码:

/**
* @author: lzy
* @create: 2023-04-26 22:01
* @Description: 短链接生成工具
*/

public class ShortUrlUtil {
 
    // 下面的字符,可以随便打乱,安全性更高
    private static final char[] BASE_62_ARRAY = {
        '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',
        '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'
    };
    public static String shortUrl(String url){
        String md5Url= DigestUtil.md5Hex(url);
        String[] resultUrl=new String[4];
        for (int i=0; i< 4;i++){
            //1.将长网址的md5生成32位签名串,分为4段,每段8个字节;
            String subStr = md5Url.substring(i * 8, i * 8 + 8);
            //2.对这四段循环处理,取8个字节,将他看成16进制串与0x3fffffff(30位1)与作,即超过30位的忽略处理:
            long hexLong= 0x3FFFFFFF & Long.parseLong(subStr, 16);
            StringBuilder outChars= new StringBuilder();
            //3.这30位分成6段,每5位的数字作为字母表的索引取得特定字符,次进行获得6位字符串;
            for (int j = 0; j < 6; j++) {
                long index = 0x0000003D & hexLong;
                outChars.append(BASE_62_ARRAY[(int) index]);
                hexLong = hexLong >> 5;
            }
            resultUrl[i]=outChars.toString();
        }
        //总的md5串可以获得4个6位串;取里面的任意一个就可作为这个长url的短urL地址;如果万一出现重复可以换一个,自行组逻辑
        return resultUrl[new Random().nextInt(4)];
    }
}

好处

  1. 简单方便,利与推广
  2. 有助于带宽节约和高并发
  3. 防止尾巴参数泄密,更安全
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码码哈哈0.0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值