java 短链接生成

  1. package shorurl;
    import org.apache.commons.codec.digest.DigestUtils;
    import org.apache.commons.lang.StringUtils;
    publicclassShortUrl{
    privatestaticfinalint BINARY =0x2;
    privatestaticfinalint NUMBER_61 =0x0000003d;
    staticfinalchar[] DIGITS ={'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','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'};
    protectedString shorten(String longUrl){
    String shortUrl = shorten(longUrl,5);
    if(StringUtils.isEmpty(shortUrl)){
    shortUrl = shorten(longUrl,6);
    }
    return shortUrl;
    }
    publicString shorten(String longUrl,int urlLength){
    if(urlLength <0|| urlLength >6){
    thrownewIllegalArgumentException("the length of url must be between 0 and 6");
    }
    String md5Hex =DigestUtils.md5Hex(longUrl);
    // 6 digit binary can indicate 62 letter & number from 0-9a-zA-Z
    int binaryLength = urlLength *6;
    long binaryLengthFixer =Long.valueOf(StringUtils.repeat("1", binaryLength), BINARY);
    for(int i =0; i <4; i++){
    String subString =StringUtils.substring(md5Hex, i *8,(i +1)*8);
    subString =Long.toBinaryString(Long.valueOf(subString,16)& binaryLengthFixer);
    subString =StringUtils.leftPad(subString, binaryLength,"0");
    StringBuilder sbBuilder =newStringBuilder();
    for(int j =0; j < urlLength; j++){
    String subString2 =StringUtils.substring(subString, j *6,(j +1)*6);
    int charIndex =Integer.valueOf(subString2, BINARY)& NUMBER_61;
    sbBuilder.append(DIGITS[charIndex]);
    }
    String shortUrl = sbBuilder.toString();
    return shortUrl;
    }
    returnnull;
    }
    }
     
    

      

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
生成链接可以通过以下几种方式实现: 1. 使用第三方链接服务API,比如新浪微博、腾讯、百度等都有提供链接服务的API,可以通过调用API将长链接转换为链接。 2. 自己实现链接生成算法,将长链接转换为一串字符串,比如将长链接的MD5值作为链接的标识符,再将标识符与链接域名组合成链接。需要注意的是,自己实现的链接算法需要保证生成链接是唯一的,且不易被猜测。 以下是一个使用自己实现的算法生成链接Java示例代码: ```java public class ShortUrlGenerator { private static final String BASE62 = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"; private static final int BASE = 62; public static String generate(String longUrl) { String md5 = DigestUtils.md5Hex(longUrl); String hex = md5.substring(0, 8); long hexLong = Long.parseLong(hex, 16); StringBuilder sb = new StringBuilder(); while (hexLong > 0) { int remainder = (int) (hexLong % BASE); sb.append(BASE62.charAt(remainder)); hexLong /= BASE; } return sb.toString(); } } ``` 使用方法如下: ```java String longUrl = "http://www.example.com/long/url"; String shortUrl = ShortUrlGenerator.generate(longUrl); System.out.println("Short URL: " + shortUrl); ``` 该算法使用MD5将长链接转换为一串16进制字符串,再将该字符串转换为10进制数字,最后将10进制数字转换为62进制字符串作为链接的标识符。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值