c# 網(wǎng)址壓縮簡(jiǎn)單實(shí)現(xiàn)短網(wǎng)址
更新時(shí)間:2012年12月16日 10:29:35 作者:
短網(wǎng)址,忽然一下子就冒出來(lái)的東西,長(zhǎng)長(zhǎng)的一個(gè)URL,提交過(guò)去,出來(lái)就只有短短的一個(gè)URL了,看起來(lái)似乎挺神奇,其實(shí)簡(jiǎn)單分析一下,明白其中的原理,也是一件很簡(jiǎn)單的事情,需要的朋友可以了解下
短網(wǎng)址,忽然一下子就冒出來(lái)的東西,長(zhǎng)長(zhǎng)的一個(gè)URL,提交過(guò)去,出來(lái)就只有短短的一個(gè)URL了,看起來(lái)似乎挺神奇,其實(shí)簡(jiǎn)單分析一下,明白其中的原理,也是一件很簡(jiǎn)單的事情。
短網(wǎng)址的名稱網(wǎng)上叫的有很多種,網(wǎng)址縮短、網(wǎng)址壓縮什么什么的,原理說(shuō)白了就跟您帶了一包東西去超市購(gòu)物,進(jìn)超市前把東西塞到超市的儲(chǔ)物柜,然后拿到一個(gè)號(hào)碼牌,您進(jìn)超市就不用再背一大包東西了,只需要拿著一個(gè)小小的號(hào)碼牌,出來(lái)時(shí)再把號(hào)碼牌還回去,把您的背包拿出來(lái),是一個(gè)道理。
知道原理,我們實(shí)現(xiàn)起來(lái)就簡(jiǎn)單了很多,無(wú)非就是接收一個(gè)URL,然后分配一個(gè)號(hào)碼,當(dāng)有人讀取這個(gè)號(hào)碼時(shí),我們?cè)侔褜?duì)應(yīng)的URL調(diào)出來(lái)并重定向,就完事了。
所以表其實(shí)很簡(jiǎn)單,簡(jiǎn)單到只需要兩個(gè)字段,一個(gè)自增ID,一個(gè)URL地址。
這里我就不寫(xiě)出詳細(xì)的代碼了,簡(jiǎn)單的增刪改查這種最基本的操作相信大家應(yīng)該都會(huì)。
那這樣我們提交一個(gè)URL,得到的URL就類(lèi)似:http://9520.me/10086
看起來(lái)似乎就完成了,其實(shí)不然,我們拿到的自增ID是一個(gè)10進(jìn)制的數(shù)字,而我們看到的大多數(shù)短網(wǎng)址后面的參數(shù)肯定不是全數(shù)字的,而是帶了字母的,畢竟10進(jìn)制表示的話,數(shù)據(jù)量上來(lái)后還是會(huì)顯得有點(diǎn)長(zhǎng),那我們就可以把字母也用上吧,大小寫(xiě)字母加數(shù)字,相當(dāng)于是62進(jìn)制,那我們還需要再實(shí)現(xiàn)一個(gè)進(jìn)制轉(zhuǎn)換的方法來(lái)對(duì)ID進(jìn)行壓縮,進(jìn)制轉(zhuǎn)換其實(shí)也是很簡(jiǎn)單的東西,明白原理的隨手都可以寫(xiě)出來(lái),不明白的隨便搜索一下也能寫(xiě)出來(lái),這里我就把我自己的實(shí)現(xiàn)列出來(lái)吧,如果大家有更好的實(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)過(guò)壓縮后就變成了:http://9520.me/2CG,少了兩個(gè)字母,當(dāng)然,數(shù)字越大時(shí)效果越明顯。
OK,明白了原理后,相信您自己做一個(gè)短網(wǎng)址的網(wǎng)站也不難了吧,難的只是有一個(gè)短的域名而已了。
要是覺(jué)得對(duì)您有幫助不妨點(diǎn)一下推薦吧,有什么想法或建議可以留言一起討論噢~~~
短網(wǎng)址的名稱網(wǎng)上叫的有很多種,網(wǎng)址縮短、網(wǎng)址壓縮什么什么的,原理說(shuō)白了就跟您帶了一包東西去超市購(gòu)物,進(jìn)超市前把東西塞到超市的儲(chǔ)物柜,然后拿到一個(gè)號(hào)碼牌,您進(jìn)超市就不用再背一大包東西了,只需要拿著一個(gè)小小的號(hào)碼牌,出來(lái)時(shí)再把號(hào)碼牌還回去,把您的背包拿出來(lái),是一個(gè)道理。
知道原理,我們實(shí)現(xiàn)起來(lái)就簡(jiǎn)單了很多,無(wú)非就是接收一個(gè)URL,然后分配一個(gè)號(hào)碼,當(dāng)有人讀取這個(gè)號(hào)碼時(shí),我們?cè)侔褜?duì)應(yīng)的URL調(diào)出來(lái)并重定向,就完事了。
所以表其實(shí)很簡(jiǎn)單,簡(jiǎn)單到只需要兩個(gè)字段,一個(gè)自增ID,一個(gè)URL地址。
這里我就不寫(xiě)出詳細(xì)的代碼了,簡(jiǎn)單的增刪改查這種最基本的操作相信大家應(yīng)該都會(huì)。
那這樣我們提交一個(gè)URL,得到的URL就類(lèi)似:http://9520.me/10086
看起來(lái)似乎就完成了,其實(shí)不然,我們拿到的自增ID是一個(gè)10進(jìn)制的數(shù)字,而我們看到的大多數(shù)短網(wǎng)址后面的參數(shù)肯定不是全數(shù)字的,而是帶了字母的,畢竟10進(jìn)制表示的話,數(shù)據(jù)量上來(lái)后還是會(huì)顯得有點(diǎn)長(zhǎng),那我們就可以把字母也用上吧,大小寫(xiě)字母加數(shù)字,相當(dāng)于是62進(jìn)制,那我們還需要再實(shí)現(xiàn)一個(gè)進(jìn)制轉(zhuǎn)換的方法來(lái)對(duì)ID進(jìn)行壓縮,進(jìn)制轉(zhuǎn)換其實(shí)也是很簡(jiǎn)單的東西,明白原理的隨手都可以寫(xiě)出來(lái),不明白的隨便搜索一下也能寫(xiě)出來(lái),這里我就把我自己的實(shí)現(xiàn)列出來(lái)吧,如果大家有更好的實(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)過(guò)壓縮后就變成了:http://9520.me/2CG,少了兩個(gè)字母,當(dāng)然,數(shù)字越大時(shí)效果越明顯。
OK,明白了原理后,相信您自己做一個(gè)短網(wǎng)址的網(wǎng)站也不難了吧,難的只是有一個(gè)短的域名而已了。
要是覺(jué)得對(duì)您有幫助不妨點(diǎn)一下推薦吧,有什么想法或建議可以留言一起討論噢~~~
相關(guān)文章
windows下C#定時(shí)管理器框架Task.MainForm詳解
這篇文章主要為大家詳細(xì)介紹了windows下C#定時(shí)管理器框架Task.MainForm的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06Unity3D使用陀螺儀控制節(jié)點(diǎn)旋轉(zhuǎn)
這篇文章主要為大家詳細(xì)介紹了Unity3D使用陀螺儀控制節(jié)點(diǎn)旋轉(zhuǎn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-11-11C# SQLite序列操作實(shí)現(xiàn)方法詳解
這篇文章主要介紹了C# SQLite序列操作實(shí)現(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了C#實(shí)現(xiàn)SQLite序列操作的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-07-07C# WinForm程序設(shè)計(jì)簡(jiǎn)單計(jì)算器
這篇文章主要為大家詳細(xì)介紹了C# WinForm程序設(shè)計(jì)簡(jiǎn)單計(jì)算器,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02c#菜單動(dòng)態(tài)合并的實(shí)現(xiàn)方法
這篇文章主要介紹了c#菜單動(dòng)態(tài)合并的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10