- 浏览: 584158 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
liuzeyuss:
好文章,顶顶
java 线程死锁的检测 -
ysite:
hugh.wang 写道请问你这个能还原吗?短网址用的是HAS ...
Java版短网址(ShortUrl)的算法 -
lv双:
没有注释,看的费劲
java 线程死锁的检测 -
dgj:
好帖子竟然没人顶...
java 线程死锁的检测 -
天空趋虚:
不好,你这只是记录式的博客,不是分享式的博客,对浏览着不友好. ...
一些技术牛人的博客
Java版短网址(ShortUrl)的算法
- 博客分类:
- javaEE
public class Encript { //十六进制下数字到字符的映射数组 private final static String[] hexDigits = {"0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F"}; /**把inputString加密*/ public static String md5(String inputStr){ return encodeByMD5(inputStr); } /** * 验证输入的密码是否正确 * @param password 真正的密码(加密后的真密码) * @param inputString 输入的字符串 * @return 验证结果,boolean类型 */ public static boolean authenticatePassword(String password,String inputString){ if(password.equals(encodeByMD5(inputString))){ return true; }else{ return false; } } /**对字符串进行MD5编码*/ private static String encodeByMD5(String originString){ if (originString!=null) { try { //创建具有指定算法名称的信息摘要 MessageDigest md5 = MessageDigest.getInstance("MD5"); //使用指定的字节数组对摘要进行最后更新,然后完成摘要计算 byte[] results = md5.digest(originString.getBytes()); //将得到的字节数组变成字符串返回 String result = byteArrayToHexString(results); return result; } catch (Exception e) { e.printStackTrace(); } } return null; } /** * 轮换字节数组为十六进制字符串 * @param b 字节数组 * @return 十六进制字符串 */ private static String byteArrayToHexString(byte[] b){ StringBuffer resultSb = new StringBuffer(); for(int i=0;i<b.length;i++){ resultSb.append(byteToHexString(b[i])); } return resultSb.toString(); } //将一个字节转化成十六进制形式的字符串 private static String byteToHexString(byte b){ int n = b; if(n<0) n=256+n; int d1 = n/16; int d2 = n%16; return hexDigits[d1] + hexDigits[d2]; } }
最近,我的项目中需要用到短网址(ShortUrl)的算法,于是在网上搜索一番,发现有C#的算法,有.Net的算法,有PHP的算法,就是没有找到Java版的短网址(ShortUrl)的算法,很是郁闷。同时还发现有不少网友在发帖求助,怎么实现Java版的短网址(ShortUrl)的算法。干脆一不做,二不休,参考了一下网上比较流行的PHP版短网址(ShortUrl)算法:
http://www.snippetit.com/2009/04/php-short-url-algorithm-implementation/
再根据自己的理解,用Java实现了该短网址(ShortUrl)的算法。(\(^o^)/YES!我还真厉害!)
先来废话一下,是在别人的帖子上看到的,主要是让大家了解一下短网址(ShortUrl)。
时下,短网址应用已经在全国各大微博上开始流行了起来。例如QQ微博的url.cn,新郎的t.cn等。
我们在新浪微博上发布网址的时候,微博会自动判别网址,并将其转换,例如:http://t.cn/hrYnr0。为什么要这样做的,原因我想有这样几点:
1、微博限制字数为140字一条,那么如果我们需要发一些连接上去,但是这个连接非常的长,以至于将近要占用我们内容的一半篇幅,这肯定是不能被允许的,所以短网址应运而生了。
2、短网址可以在我们项目里可以很好的对开放级URL进行管理。有一部分网址可以会涵盖性、暴力、广告等信息,这样我们可以通过用户的举报,完全管理这个连接将不出现在我们的应用中,应为同样的URL通过加密算法之后,得到的地址是一样的。
3、我们可以对一系列的网址进行流量,点击等统计,挖掘出大多数用户的关注点,这样有利于我们对项目的后续工作更好的作出决策。
其实以上三点纯属个人观点,因为在我接下来的部分项目中会应用到,所以就了解了一下,下面先来看看短网址映射算法的理论(网上找到的资料):
① 将长网址用md5算法生成32位签名串,分为4段,,每段8个字符;
② 对这4段循环处理,取每段的8个字符, 将他看成16进制字符串与0x3fffffff(30位1)的位与操作,超过30位的忽略处理;
③ 将每段得到的这30位又分成6段,每5位的数字作为字母表的索引取得特定字符,依次进行获得6位字符串;
④ 这样一个md5字符串可以获得4个6位串,取里面的任意一个就可作为这个长url的短url地址。
很简单的理论,我们并不一定说得到的URL是唯一的,但是我们能够取出4组URL,这样几乎不会出现太大的重复。
下面来看看程序部分:
import util.Encript; public class ShortUrl { public static void main(String[] args) { String url = "http://www.sunchis.com"; for (String string : ShortText(url)) { print(string); } } public static String[] ShortText(String string){ String key = "XuLiang"; //自定义生成MD5加密字符串前的混合KEY String[] chars = new String[]{ //要使用生成URL的字符 "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" }; String hex = Encript.md5(key + string); int hexLen = hex.length(); int subHexLen = hexLen / 8; String[] ShortStr = new String[4]; for (int i = 0; i < subHexLen; i++) { String outChars = ""; int j = i + 1; String subHex = hex.substring(i * 8, j * 8); long idx = Long.valueOf("3FFFFFFF", 16) & Long.valueOf(subHex, 16); for (int k = 0; k < 6; k++) { int index = (int) (Long.valueOf("0000003D", 16) & idx); outChars += chars[index]; idx = idx >> 5; } ShortStr[i] = outChars; } return ShortStr; } private static void print(Object messagr){ System.out.println(messagr); } }
评论
3 楼
ysite
2014-12-05
hugh.wang 写道
请问你这个能还原吗?
短网址用的是HASH算法(md5)怎么能还原呢??
还原的作法应该是在计算出短网址后将短网址和HASH前的原网址一起进行持久化,在需要还原时去持久化里查询出来。。!
2 楼
BabyDuncan
2013-05-30
hugh.wang 写道
请问你这个能还原吗?
我特么的也不知道啊,转载的。
1 楼
hugh.wang
2013-03-19
请问你这个能还原吗?
发表评论
-
一些技术牛人的博客
2011-08-30 13:23 2437High Scalability - Building big ... -
Spring MVC 的请求参数获取的几种方法
2011-07-14 16:11 43928通过@PathVariabl注解获取路径中传递参数 JAVA ... -
Spring mvc与JKaptcha组合生成验证码
2011-07-05 16:40 2959kaptcha 是一个非常实用的验证码生成工具。有了它,你可以 ... -
第一次使用resin的安装和配置问题
2011-03-10 17:18 2994那边要求熟悉tomcat和resin,tomcat倒是很熟悉, ... -
jsp页面跳转的方法
2011-03-10 10:02 11641. RequestDispatcher.forward( ... -
实验看看Servlet之间的跳转(dispatch-forward&sendRedirect)
2011-03-07 14:39 2030首先是dispatch-forward 代码如下: R ... -
读取web.xml文件中数据的三种方法
2011-03-04 14:53 4610一,采用web.xml中的init-param标签 web。x ... -
根据responseServlet生成图片验证码
2011-03-04 13:58 1206代码: package com.babyDuncan.re ... -
通过request的请求获取客户端信息
2011-03-04 11:24 2920代码,可以获得很多信息,我只写了几个,其实可以获得更多的! ... -
firstServlet 写一个最基本的servlet程序
2011-03-04 10:53 3147Servlet代码为: package c ... -
Spring的七大模块简介
2011-02-16 11:38 14537Spring有七大功能模块,分别是Spring Core,AO ... -
Servlet获取客户端ip地址和mac地址
2011-01-24 11:35 36013package com.babyDuncan.java; ... -
Servlet相比CGI的好处
2011-01-17 09:20 15481,Servlet是基于Java语言的,拥有java语言的所有 ... -
include指令简介
2011-01-13 11:56 1111incude指令的形式: < ... -
关于foward和redirect的详细描述(比一般的要详细)
2011-01-10 18:03 1687他们是一个Servet跳向另一个Servlet的方法,但是有所 ... -
实验证明Servlet生命周期
2011-01-10 17:19 1363根据上过一篇日志的内容,测试Servlet生命周期内各个函数的 ... -
Servlet生命周期的简单描述
2011-01-10 17:09 2076完整的Servlet的生命周期的描述: 1,服务器加载Serv ... -
Servlet获取上下文参数以及资源注入
2011-01-10 12:07 1862上下文参数可以理解为全局参数,可以支持多个Servlet来调用 ... -
servlet中web.xml的配置
2011-01-10 10:29 1456servlet的web.xml配置: <serv ... -
对Struts的理解
2011-01-07 10:49 1444对 Struts Struts Struts Struts 的 ...
相关推荐
Java短链接(Short URL)是一种将长网址转化为简短易记的字符串的技术,常用于社交媒体、营销推广等领域。在这个场景中,"java short URL" 指的是使用Java编程语言实现的短链接服务。描述中提到的“可逆算法”是指在...
在IT行业中,短链接服务是一种常见的功能,它能够将冗长的URL转化为简短的、易于分享和记忆的链接。本项目是基于Java技术栈,利用SpringBoot框架、Redis缓存系统、MySQL数据库以及布隆过滤器来实现短链转换。下面...
这个名为"java短链接生成.zip"的压缩包文件提供了一个基于SpringBoot框架的Java实现,用于生成短链接。让我们深入探讨一下这个项目的核心知识点,以及如何利用它来创建和管理短链接。 首先,我们要了解SpringBoot。...
- **字段说明**:常见的字段包括`id`(自增长主键)、`long_url`(原始长网址)、`short_code`(短网址的编码部分)、`create_time`(创建时间)等。 2. **算法设计**: - **编码方式**:常用的编码方式有基数转换法和...
- 定义一个`Url`实体类,包含`id`、`longUrl`(原始长网址)、`shortCode`(短码)等字段,用于存储短网址与长网址的映射。 3. **数据库交互(Data Access)**: - 使用Spring Data JPA进行数据操作,提供`...
总结来说,"short-url"项目是一个基于Java实现的短网址服务,它涉及到了URL处理、哈希映射、数据库操作、分布式服务、API设计等多个IT领域的知识点。通过研究这个项目,不仅可以掌握短网址服务的实现,还能加深对...
2. 部署服务:下载压缩包中的`shorturl.exe`或`shorturl`文件,这是一个预编译的短地址服务程序。在Linux环境下,你可以使用`nohup`或`screen`命令后台运行服务;在Windows环境下,双击执行文件即可启动服务。 3. ...
(临时的) > 解决问题的策略短URL密钥生成算法考虑哈希网址或使用uuid 在问题要求中,键是8个字符内的字符串。 当以base64编码时,64 ^ 8 = 2 ^ 48,即,结果必须在最多48位内表示,以确保非冗余密钥。 因此,判断...
数据库表至少包含两列:`long_url`(长网址)和`short_url`(短网址)。在生成短网址时,可以使用自增ID或其他唯一标识符进行哈希运算,得到一个较短的字符串。 #### 2. URL编码与解码 在处理URL时,必须遵循URL编码...
本项目名为"short-link.rar",其中涉及到的主要技术包括Java编程、MD5哈希算法以及62进制编码,这些都是实现短链接转换的关键组成部分。 首先,MD5(Message-Digest Algorithm 5)是一种广泛使用的哈希函数,它可以...
短链接(Short Link)是指将一个原始的长 URL(Uniform Resource Locator)通过特定的算法或服务转化为一个更短、易于记忆的 URL。短链接通常只包含几个字符,而原始的长 URL 可能会非常长。短链接的原理非常简单,...
这种短UUID通常比标准UUID短得多,更适合在URL、数据库键或者文件名等场景中使用。 使用shortuuid库非常简单。首先,你需要在项目中引入该库。如果你使用的是Maven,可以在pom.xml文件中添加如下依赖: ```xml ...
- **短整型(short)**: 16位整数,范围从-32,768到32,767。 - **整型(int)**: 32位整数,范围从-2^31到2^31-1。 - **长整型(long)**: 64位整数,范围从-2^63到2^63-1。 - **浮点型(float)**: 32位单精度浮点数。 - **...
在IT行业中,"short-url"通常指的是短链接服务,它是一种将长网址转换为较短、易记的网址的技术。这种服务广泛应用于社交媒体、营销活动和数据分析,因为它们提供了更方便的分享方式,并且可以跟踪点击率。在这个...
在IT行业中,短链接服务(Short-URI)是一种常见的网络技术,它主要用于将长的URL转换为较短的形式,方便用户记忆和分享。在给定的"short-uri"项目中,我们可以推测这是一个用Java实现的短链接生成系统。下面,我们...
使用Java的Spring Boot框架,可以轻松地创建HTTP端点,如`POST /shorten`用于缩短URL,`GET /{shortCode}`用于访问短码并重定向。 7. **安全性考虑**:为了避免恶意用户滥用服务,可能需要添加限流策略,如使用滑动...
- **短整型变量赋值**:当尝试给短整型变量赋一个超出其范围的值时,需要进行类型转换。例如,`short s1 = 1; s1 += 1L;`,这里会报错,因为右侧的结果是`long`类型,需要显式转换为`short`类型。 - **正确的赋值...
【描述】:URL缩短服务的核心功能是通过哈希算法或自增ID映射,将原始长URL映射为短码,然后当用户访问这个短码时,服务会将他们重定向到原始的长URL。服务通常还包括统计点击次数、提供自定义短码等功能。 【知识...
- Java的原始数据类型包括:布尔boolean、字节byte、短整型short、整型int、长整型long、字符char、单精度浮点float和双精度浮点double。 8. **同步关键字**: - B选项`synchronized`关键字用于对对象加互斥锁,...
- `GET /short/{shortCode}`: 通过短码获取长 URL,并进行重定向。 **5. 响应式编程** Spring Boot 2.0 引入了对响应式编程的支持,它使用 Project Reactor 作为基础库。响应式编程允许在非阻塞模型下处理 I/O 操作...