作為一個程序員,在完成設(shè)計后還要根據(jù)程序的情況以及用戶的反映不斷對程序進(jìn)行改進(jìn),這樣才能不斷地完善自己的作品。筆者在制作完軟件商務(wù)網(wǎng)的論壇后,發(fā)現(xiàn)人們總喜歡在帖子中加上各種有用的URL鏈接或Email地址。而筆者當(dāng)初設(shè)計時沒有考慮到這一點(diǎn),使得這些URL鏈接或Email地址只能以文字的形式而并不是以超鏈接的形式顯示,其它瀏覽帖子的人還必須把這些URL鏈接拷貝到瀏覽器中或把Email地址拷貝到Outlook中才能轉(zhuǎn)到相應(yīng)的鏈接地址或發(fā)送電子郵件到相應(yīng)的Email地址。
發(fā)現(xiàn)這個問題后,筆者即著手進(jìn)行解決。首先是從網(wǎng)上查找有關(guān)這方面的現(xiàn)在代碼,可惜的是,在搜索引擎上反復(fù)查找也沒有發(fā)現(xiàn)這方面的文章。后來一想,干脆自己用ASP.NET編寫一個。
要想自動顯示超鏈接的關(guān)鍵在于如何能正確識別超鏈接,毫無疑問的,最有效的方法是用正則表達(dá)式。正則表達(dá)式是由普通字符(例如字符 a 到 z)以及特殊字符(稱為元字符)組成的文字模式,描述了一種字符串匹配的模式,可以用來檢查一個串是否含有某種子串、將匹配的子串做替換或者從某個串中取出符合某個條件的子串等。.NET基礎(chǔ)類庫中包含有一個名字空間和一系列可以充分發(fā)揮規(guī)則表達(dá)式威力的類,用它就可以自動探測出文字中的URL鏈接或 Email地址。下面具體講講如何用ASP.NET(C#)一步步實(shí)現(xiàn)我們的目的:
首先,要想在ASP.NET(C#)中使用正則表達(dá)式就必須把 System.Text.RegularExpressions 這個命名空間包含進(jìn)來
using System.Text.RegularExpressions;
第二步是用正則表達(dá)式識別URL超鏈接:
復(fù)制代碼 代碼如下:
Regex urlregex = new Regex(@"(http:\/\/([\w.]+\/?)\S*)",
RegexOptions.IgnoreCase|RegexOptions.Compiled);
這里的代碼是用正則表達(dá)式識別Email地址:
復(fù)制代碼 代碼如下:
Regex emailregex = new Regex(@"([a-zA-Z_0-9.-]+\@[a-zA-Z_0-9.-]+\.\w+)",
RegexOptions.IgnoreCase|RegexOptions.Compiled);
第三步,當(dāng)程序已經(jīng)識別出URL超鏈接或Email地址后,必須用〈a href=...〉超鏈接〈/a〉對這些超鏈接進(jìn)行替換,這樣才能把這些文字顯示為鏈接的形式。我這里把它們?nèi)堪诤瘮?shù)中:
private void Button1_Click(object sender, System.EventArgs e)
{
string strContent = InputTextBox.Text;
Regex urlregex = new Regex(@"(http:\/\/([\w.]+\/?)\S*)",
RegexOptions.IgnoreCase| RegexOptions.Compiled);
strContent = urlregex.Replace(strContent,
"〈a href=\"\" target=\"_blank\"〉〈/a〉");
Regex emailregex = new Regex(@"([a-zA-Z_0-9.-]+\@[a-zA-Z_0-9.-]+\.\w+)",
RegexOptions.IgnoreCase| RegexOptions.Compiled);
strContent = emailregex.Replace(strContent, "〈a href=mailto:〉〈/a〉");
lbContent.Text += "〈br〉"+strContent;
}
通過以上幾步,你就可以在網(wǎng)頁上自動顯示超鏈接以及Email地址了
其它網(wǎng)友的補(bǔ)充:
private void button1_click(object sender, system.eventargs e){
string strcontent = inputtextbox.text;
regex urlregex = new regex(@"(http://([w.]+/?)s*)",regexoptions.ignorecase| regexoptions.compiled);
strcontent = urlregex.replace(strcontent,"a href="" target=" rel="external nofollow" _blank">/a>");
regex emailregex = new regex(@"([a-za-z_0-9.-]+@[a-za-z_0-9.-]+.w+)",regexoptions.ignorecase| regexoptions.compiled);
strcontent = emailregex.replace(strcontent, "a href=mailto:>/a>");
lbcontent.text += "br>"+strcontent;}
您可能感興趣的文章:- asp.net下檢測遠(yuǎn)程URL是否存在的三種方法
- asp.net URL中包含中文參數(shù)造成亂碼的解決方法
- asp頁面和Asp.net頁面?zhèn)髦形膮?shù)UrlEncode編碼以及接收解碼
- asp.net獲取當(dāng)前網(wǎng)址url的各種屬性(文件名、參數(shù)、域名 等)的代碼
- asp.net URL編碼與解碼
- Asp.net中Request.Url的各個屬性對應(yīng)的意義介紹
- asp.net獲取URL和IP地址的方法匯總
- Asp.net中獲取應(yīng)用程序完整Url路徑的小例子
- asp.net C#檢查URL是否有效的方法
- ASP.NET獲取URL方法匯總