ASP.NET通過第三方網(wǎng)站Bitly實現(xiàn)短鏈接地址程序
發(fā)微博很久了,或許是我之前沒注意,現(xiàn)在特別關注那個微博中的圖片鏈接和URL鏈接,總給我看不懂但是又那么短的感覺,反正不是我上傳的地址,其實這里使用一個短鏈接服務功能,這里拿出來曬曬。

這里看看是指向淘寶的一個商品頁面,鏈接地址是這樣的 ,但是現(xiàn)在在微博中變成了紅圈表名的那個樣子,似乎看不懂了,而且你點擊之后還是到你原有的頁面。這里就是使用了短鏈接程序服務,包括圖片等等都是這樣,可以縮短url長度。
Bitly 是世界上最流行的短鏈接服務,而且已經免費開放所有功能。點擊訪問官網(wǎng) Bitly.com
下面介紹服務使用步驟:
(1) 到官網(wǎng)注冊獲取相應的APIKey

(2)到Setting頁面獲得Key值

因為只有注冊之后才能使用它相應的服務,所以這里先注冊一個用戶
(3)下載Bitly服務包
下載地址如下: http://urlshortenerhelper.codeplex.com/
(4)新建一個項目,我這里使用VS2010 MVC3項目
新建之后要在VS工程中添加外部引用包,也就是安裝UrlShortener ,剛才下載的文件
(5)在Package Manager Console 命令中安裝UrlShortener ,我這里安裝的是UrlShortener.0.9.1

輸入Install-Package UrlShortener 命令之后 顯示下面的表示安裝成功!
(6) 到上面之后一切OK,接下來就是編碼的事情,代碼非常簡單。
安裝成功之后,項目工程中會有一個文件包 packages ,里面就是一些dll文件,然后會添加兩個dll到工程中。

(7)代碼展示
URL轉化之前必須設置用戶以及剛才獲得Key值
UrlShortener.Settings.UserName = "qingyuan"; UrlShortener.Settings.ApiKey = "R_0daabdbac0fd2b58f097da9f5a1f7917";
應用代碼如下
<p>
@{
string url = UrlShortener.Shorten("http://www.cnblogs.com/qingyuan/");
string image = UrlShortener.Shorten("http://images.cnblogs.com/cnblogs_com/qingyuan/242728/r_qingyuan.jpg");
string localhost = UrlShortener.Shorten("http://127.0.0.1/index.html");
}
<div>
<label>顯示:</label>
<span>
<a href="@url">@url</a>
</span>
</div><br />
<div>
<label>圖片短鏈接:</label>
<span>
<img src="@image" />
</span>
</div><br />
<div>
<label>本機地址:</label>
<span>
<a href="@localhost">@localhost</a>
</span>
</div><br /></p>
展示效果圖如下

這里就達到了短鏈接的效果,相對之前的URL短了很多,而且url已經混淆了。
下面介紹幾個遇到的問題:
(1) 不設置UserName或ApiKey 會出現(xiàn)如下問題

(2) 果如ApiKey的值不正確會出現(xiàn)如下問題

更新獲取短鏈接算法參考代碼
static void Main(string[] args)
{
string url = "http://www.cnblogs.com/qingyuan/asdf/asdf/11/24/UrlShortener.html";
string[] results = ShortUrl(url);
foreach (string item in results)
{
System.Console.WriteLine(item);
}
}
public static string[] ShortUrl(string 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"};
string value = UserMd5(url);
System.Console.WriteLine("MD5加密之后字符串: "+value+"\n字符串長度"+value.Length);
string[] results = new string[value.Length / 8];
for (int i = 0; i < value.Length/8; i++)
{
string tempResult = value.Substring(i*8,8);
long lHexLong = 0x3FFFFFFF & long.Parse(tempResult);
string outchar = "";
for (int j = 0; j < 6; j++)
{
long index = 0x0000003D & lHexLong;
outchar += chars[(int)index];
lHexLong = lHexLong >> 5;
}
results[i] = outchar;
}
return results;
}
static string UserMd5(string str)
{
string key = "qingyuan";
string cl = str+key;
string pwd = "";
MD5 md5 = MD5.Create();
byte[] s = md5.ComputeHash(Encoding.UTF8.GetBytes(str));
for (int i = 0; i < s.Length; i++)
{
pwd = pwd + s[i];
}
return pwd;
}
以上這篇ASP.NET通過第三方網(wǎng)站Bitly實現(xiàn)短鏈接地址程序就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
使用ASP.NET MVC引擎開發(fā)插件系統(tǒng)
這篇文章主要為大家詳細介紹了使用ASP.NET MVC引擎開發(fā)插件系統(tǒng)的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05
asp.net URL中包含中文參數(shù)造成亂碼的解決方法
中文亂碼一直以來是WEB開發(fā)中比較常見的問題之一,對于初學者來說,各種各樣的編碼方式可能會有點不適應,本篇文章并不講述這些編碼,而是把自己遇到的一個小問題以及該問題的解決之法說明一下,希望對大家有用。2010-03-03
在?ASP.NET?Core?中使用?HTTP?標頭傳播詳情
這篇文章主要介紹了在?ASP.NET?Core?中使用?HTTP?標頭傳播詳情,文章通過,我們創(chuàng)建?ServerA、ServiceB?兩個?Web?API?項目展開內容,需要的朋友可以參考一下2022-04-04
asp.net下使用jQuery.AutoComplete完成仿淘寶商品搜索自動完成功能(改進了鍵盤上下選擇體驗)
其實這個已經是個比較常見的功能了,網(wǎng)上也有很多人做過這個了,但是很多都是僅僅做了一些基本的網(wǎng)頁上自動完成功能,沒有與具體的數(shù)據(jù)庫進行聯(lián)動,我今天所介紹這個自動完成的就是我修改的jQuery.AutoComplete+數(shù)據(jù)庫的一個解決方案。2010-05-05
Entity Framework Core對Web項目生成數(shù)據(jù)庫表
這篇文章介紹了Entity Framework Core對Web項目生成數(shù)據(jù)庫表的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03

