好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

短网址的简单实现

短网址的简单实现

 短网址,忽然一下子就冒出来的东西,长长的一个URL,提交过去,出来就只有短短的一个URL了,看起来似乎挺神奇,其实简单分析一下,明白其中的原理,也是一件很简单的事情。 

短网址的名称网上叫的有很多种,网址缩短、网址压缩什么什么的,原理说白了就跟您带了一包东西去超市购物,进超市前把东西塞到超市的储物柜,然后拿到一个号码牌,您进超市就不用再背一大包东西了,只需要拿着一个小小的号码牌,出来时再把号码牌还回去,把您的背包拿出来,是一个道理。 

知道原理,我们实现起来就简单了很多,无非就是接收一个URL,然后分配一个号码,当有人读取这个号码时,我们再把对应的URL调出来并重定向,就完事了。 

所以表其实很简单,简单到只需要两个字段,一个自增ID,一个URL地址。 

这里我就不写出详细的代码了,简单的增删改查这种最基本的操作相信大家应该都会。 

那这样我们提交一个URL,得到的URL就类似:http://9520.me/10086 

看起来似乎就完成了,其实不然,我们拿到的自增ID是一个10进制的数字,而我们看到的大多数短网址后面的参数肯定不是全数字的,而是带了字母的,毕竟10进制表示的话,数据量上来后还是会显得有点长,那我们就可以把字母也用上吧,大小写字母加数字,相当于是62进制,那我们还需要再实现一个进制转换的方法来对ID进行压缩,进制转换其实也是很简单的东西,明白原理的随手都可以写出来,不明白的随便搜索一下也能写出来,这里我就把我自己的实现列出来吧,如果大家有更好的实现,不妨留言告诉我。 

 
static string Number = " 0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ " ; /// <summary> /// 压缩ID标识 /// </summary> /// <param name="n"></param> /// <returns></returns> public string Short( long n) { string result = string .Empty; int l = Number.Length; while (n / l >= 1 ) { result = Number[( int )(n % l)] + result; n /= l; } result = Number[( int )n] + result; return result; } /// <summary> /// 还原ID标识 /// </summary> /// <param name="s"></param> /// <returns></returns> public long UnShort( string s) { long result = 0 ; if (s.HasValue()) { s = s.Trim(); int l = s.Length; int m = Number.Length; for ( int x = 0 ; x < l; x++ ) { result += Number.IndexOf(s[l - 1 - x]) * ( long )Math.Pow(m, x); } } return result; }

那我们刚才的URL: http://9520.me/10086 ,经过压缩后就变成了: http://9520.me/2CG ,少了两个字母,当然,数字越大时效果越明显。

 OK,明白了原理后,相信您自己做一个短网址的网站也不难了吧,难的只是有一个短的域名而已了。

要是觉得对您有帮助不妨点一下推荐吧,有什么想法或建议可以留言一起讨论噢~~~

 

分类:  C#

标签:  短网址 ,  网址缩短 ,  网址压缩

作者: Leo_wl

    

出处: http://HdhCmsTestcnblogs测试数据/Leo_wl/

    

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

版权信息

查看更多关于短网址的简单实现的详细内容...

  阅读:43次