c# 網(wǎng)址壓縮簡單實(shí)現(xiàn)短網(wǎng)址
更新時(shí)間:2012年12月16日 10:29:35 作者:
短網(wǎng)址,忽然一下子就冒出來的東西,長長的一個(gè)URL,提交過去,出來就只有短短的一個(gè)URL了,看起來似乎挺神奇,其實(shí)簡單分析一下,明白其中的原理,也是一件很簡單的事情,需要的朋友可以了解下
短網(wǎng)址,忽然一下子就冒出來的東西,長長的一個(gè)URL,提交過去,出來就只有短短的一個(gè)URL了,看起來似乎挺神奇,其實(shí)簡單分析一下,明白其中的原理,也是一件很簡單的事情。
短網(wǎng)址的名稱網(wǎng)上叫的有很多種,網(wǎng)址縮短、網(wǎng)址壓縮什么什么的,原理說白了就跟您帶了一包東西去超市購物,進(jìn)超市前把東西塞到超市的儲(chǔ)物柜,然后拿到一個(gè)號(hào)碼牌,您進(jìn)超市就不用再背一大包東西了,只需要拿著一個(gè)小小的號(hào)碼牌,出來時(shí)再把號(hào)碼牌還回去,把您的背包拿出來,是一個(gè)道理。
知道原理,我們實(shí)現(xiàn)起來就簡單了很多,無非就是接收一個(gè)URL,然后分配一個(gè)號(hào)碼,當(dāng)有人讀取這個(gè)號(hào)碼時(shí),我們?cè)侔褜?duì)應(yīng)的URL調(diào)出來并重定向,就完事了。
所以表其實(shí)很簡單,簡單到只需要兩個(gè)字段,一個(gè)自增ID,一個(gè)URL地址。
這里我就不寫出詳細(xì)的代碼了,簡單的增刪改查這種最基本的操作相信大家應(yīng)該都會(huì)。
那這樣我們提交一個(gè)URL,得到的URL就類似:http://9520.me/10086
看起來似乎就完成了,其實(shí)不然,我們拿到的自增ID是一個(gè)10進(jìn)制的數(shù)字,而我們看到的大多數(shù)短網(wǎng)址后面的參數(shù)肯定不是全數(shù)字的,而是帶了字母的,畢竟10進(jìn)制表示的話,數(shù)據(jù)量上來后還是會(huì)顯得有點(diǎn)長,那我們就可以把字母也用上吧,大小寫字母加數(shù)字,相當(dāng)于是62進(jìn)制,那我們還需要再實(shí)現(xiàn)一個(gè)進(jìn)制轉(zhuǎn)換的方法來對(duì)ID進(jìn)行壓縮,進(jìn)制轉(zhuǎn)換其實(shí)也是很簡單的東西,明白原理的隨手都可以寫出來,不明白的隨便搜索一下也能寫出來,這里我就把我自己的實(shí)現(xiàn)列出來吧,如果大家有更好的實(shí)現(xiàn),不妨留言告訴我。
static string Number = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
/// <summary>
/// 壓縮ID標(biāo)識(shí)
/// </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標(biāo)識(shí)
/// </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,經(jīng)過壓縮后就變成了:http://9520.me/2CG,少了兩個(gè)字母,當(dāng)然,數(shù)字越大時(shí)效果越明顯。
OK,明白了原理后,相信您自己做一個(gè)短網(wǎng)址的網(wǎng)站也不難了吧,難的只是有一個(gè)短的域名而已了。
要是覺得對(duì)您有幫助不妨點(diǎn)一下推薦吧,有什么想法或建議可以留言一起討論噢~~~
短網(wǎng)址的名稱網(wǎng)上叫的有很多種,網(wǎng)址縮短、網(wǎng)址壓縮什么什么的,原理說白了就跟您帶了一包東西去超市購物,進(jìn)超市前把東西塞到超市的儲(chǔ)物柜,然后拿到一個(gè)號(hào)碼牌,您進(jìn)超市就不用再背一大包東西了,只需要拿著一個(gè)小小的號(hào)碼牌,出來時(shí)再把號(hào)碼牌還回去,把您的背包拿出來,是一個(gè)道理。
知道原理,我們實(shí)現(xiàn)起來就簡單了很多,無非就是接收一個(gè)URL,然后分配一個(gè)號(hào)碼,當(dāng)有人讀取這個(gè)號(hào)碼時(shí),我們?cè)侔褜?duì)應(yīng)的URL調(diào)出來并重定向,就完事了。
所以表其實(shí)很簡單,簡單到只需要兩個(gè)字段,一個(gè)自增ID,一個(gè)URL地址。
這里我就不寫出詳細(xì)的代碼了,簡單的增刪改查這種最基本的操作相信大家應(yīng)該都會(huì)。
那這樣我們提交一個(gè)URL,得到的URL就類似:http://9520.me/10086
看起來似乎就完成了,其實(shí)不然,我們拿到的自增ID是一個(gè)10進(jìn)制的數(shù)字,而我們看到的大多數(shù)短網(wǎng)址后面的參數(shù)肯定不是全數(shù)字的,而是帶了字母的,畢竟10進(jìn)制表示的話,數(shù)據(jù)量上來后還是會(huì)顯得有點(diǎn)長,那我們就可以把字母也用上吧,大小寫字母加數(shù)字,相當(dāng)于是62進(jìn)制,那我們還需要再實(shí)現(xiàn)一個(gè)進(jìn)制轉(zhuǎn)換的方法來對(duì)ID進(jìn)行壓縮,進(jìn)制轉(zhuǎn)換其實(shí)也是很簡單的東西,明白原理的隨手都可以寫出來,不明白的隨便搜索一下也能寫出來,這里我就把我自己的實(shí)現(xiàn)列出來吧,如果大家有更好的實(shí)現(xiàn),不妨留言告訴我。
復(fù)制代碼 代碼如下:
static string Number = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
/// <summary>
/// 壓縮ID標(biāo)識(shí)
/// </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標(biāo)識(shí)
/// </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,經(jīng)過壓縮后就變成了:http://9520.me/2CG,少了兩個(gè)字母,當(dāng)然,數(shù)字越大時(shí)效果越明顯。
OK,明白了原理后,相信您自己做一個(gè)短網(wǎng)址的網(wǎng)站也不難了吧,難的只是有一個(gè)短的域名而已了。
要是覺得對(duì)您有幫助不妨點(diǎn)一下推薦吧,有什么想法或建議可以留言一起討論噢~~~
相關(guān)文章
可替代log4j日志的c#簡單日志類隊(duì)列實(shí)現(xiàn)類代碼分享
簡單日志類隊(duì)列實(shí)現(xiàn)??砂刺熘茉履甏笮》指钗募???珊唵翁娲鷏og4j2013-12-12
C# List實(shí)現(xiàn)行轉(zhuǎn)列的通用方案
本篇通過行轉(zhuǎn)列引出了System.Linq.Dynamic,并且介紹了過濾功能,具有很好的參考價(jià)值。下面跟著小編一起來看下吧2017-03-03
C#?SetWindowPos函數(shù)實(shí)例詳解
在C#中,SetWindowPos函數(shù)用于設(shè)置窗口的位置和大小,這篇文章主要介紹了C#?SetWindowPos函數(shù)實(shí)例詳解,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2024-03-03
C#使用OpenCvSharp實(shí)現(xiàn)圖像校正
這篇文章主要為大家詳細(xì)介紹了C#如何使用OpenCvSharp實(shí)現(xiàn)圖像校正功能,文中的示例代碼簡潔易懂,具有一定的學(xué)習(xí)價(jià)值,需要的小伙伴可以參考下2023-11-11

