首先先理解需求,产品的需求是要求说用户分享一条短链接,从而跳转到下载落地页,下载APP,然后被邀请者就是邀请者的下属用户。
这。。没问题,甘蔗!
首先需要生成用户短连接标识,我这边的话,是采用MD5加密,然后把加密字符串按照8位一组16进制与 0x3FFFFFFF 进行位与运算,然后得到短连接标识。
然后在配置文件中配置长链接的下载地址,还有对应的邀请人ID,短链接标识持久化(以便下次同个ID生成时返回)。
话不多说,上代码:
import java.security.MessageDigest; import java.util.Random; import java.util.UUID; /*** * 生成短连接 * * Created by lhs on 2021/8/31. */ public class ShortUrlGeneratorUtil { // 生成几个短连接地址 private final static int COUNT = 1; // 生成几位短连接地址的签名 public final static int LENGTH = 5; public static void main(String[] args) { String sLongUrl = "http://tool.chinaz.com/tools/dwz.aspx"; // 原始链接 System.out.println("短链接:"+getShortUrl(sLongUrl));//随机取一个作为短链 } /** * 获取短连接地址 * @param url * @return * @return String * @author tyg * @date 2019年1月24日下午2:27:24 */ public static String getShortUrl(String url) { return shortUrl(url)[0]; } /** * 返回4组端地址 * @param url * @return * @return String[] * @author tyg * @date 2019年1月24日下午2:28:36 */ public static String[] shortUrl(String url) { // 可以自定义生成 MD5 加密字符传前的混合 KEY // 要使用生成 URL 的字符 String[] chars = 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" }; // 对传入网址进行 MD5 加密 String hex = md5ByHex(UUID.randomUUID().toString() + url); String[] resUrl = new String[COUNT]; for (int i = 0; i < COUNT; i++) { // 把加密字符按照 8 位一组 16 进制与 0x3FFFFFFF 进行位与运算 String sTempSubString = hex.substring(i * 8, i * 8 + 8); // 这里需要使用 long 型来转换,因为 Inteper .parseInt() 只能处理 31 位 , 首位为符号位 , 如果不用long ,则会越界 long lHexLong = 0x3FFFFFFF & Long.parseLong(sTempSubString, 16); String outChars = ""; for (int j = 0; j < LENGTH; j++) { // 把得到的值与 0x0000003D 进行位与运算,取得字符数组 chars 索引 long index = 0x0000003D & lHexLong; // 把取得的字符相加 outChars += chars[(int) index]; // 每次循环按位右移 5 位 lHexLong = lHexLong >> 5; } // 把字符串存入对应索引的输出数组 resUrl[i] = outChars; } return resUrl; } /** * MD5加密(32位大写) * @param src * @return * @return String * @author tyg * @date 2019年5月7日下午6:31:59 */ public static String md5ByHex(String src) { try { MessageDigest md = MessageDigest.getInstance("MD5"); byte[] b = src.getBytes(); md.reset(); md.update(b); byte[] hash = md.digest(); String hs = ""; String stmp = ""; for (int i = 0; i < hash.length; i++) { stmp = Integer.toHexString(hash[i] & 0xFF); if (stmp.length() == 1) hs = hs + "0" + stmp; else { hs = hs + stmp; } } return hs.toUpperCase(); } catch (Exception e) { return ""; } } }
上述内容都是生成短连接以及长链接之间的关系。
下面讲讲如果使用短链接:
首先,我们生成短连接之后,会返回给客户端,这时候会拼上服务器路径,指向我们路径的重定向地址:上代码:
@AnonymousAccess @ApiOperation(value = "实现重定向,跳转下载页") @RequestMapping("/{shortUrl}") public Object redirects(HttpServletRequest request, ModelAndView mav,@PathVariable("shortUrl") String shortUrl) { String longUrl = ""; //根据重定向回来的短链接进行查询,查询到生成的长链接 ScUserShareUrl entity = shareUrlService.getUserShareUrlByShortUrl(shortUrl); if (entity != null) { longUrl = entity.getLongUrl(); } mav.setViewName("redirect:" + longUrl); return mav; }
拿到长链接之后,再重定向跳转下载落地页了。
然后下载落地页的话,我们的做法是采用在页面上输入手机号码或者邮箱,进行注册,同时绑定上下级用户之间的关系。
至此,该功能已结束!