在blog博客系统开发中,在发布留言或评论时,需要把用户输入的Url链接或Email加上超链接,这样可以显的很人性化。
要想自动显示超链接的关键在于如何能正确识别超链接,毫无疑问的,最有效的方法是用正则表达式。正则表达式是由普通字符(例如字符 a 到 z)以及特殊字符(称为元字符)组成的文字模式,描述了一种字符串匹配的模式,可以用来检查一个串是否含有某种子串、将匹配的子串做替换或者从某个串中取出符合某个条件的子串等。.NET基础类库中包含有一个名字空间和一系列可以充分发挥规则表达式威力的类,用它就可以自动探测出文字中的URL链接或Email地址。
Baidu了一下,找到的解决方案都有问题,所以我对其中的一种方法进行了改写,顺利地实现了这个功能,方法如下:
首先,要想在ASP.NET(C#)中使用正则表达式就必须把 System.Text.RegularExpressions 这个命名空间包含进来:using System.Text.RegularExpressions;
\n
下面是一个完整的方法,要实现如题的功能,只要调用这个方法就可以了,
\n
public string Url_Rewrite(string Text)
{
//用正则表达式识别URL超链接
Regex UrlRegex = new Regex(@”(http:\\/\\/([\\w.]+\\/?)\\S*)”, RegexOptions.IgnoreCase | RegexOptions.Compiled);
//进规则查询
//Url
MatchCollection matches = UrlRegex.Matches(Text);
foreach (Match match in matches)
{
Text = Text.Replace(match.Value, string.Format(“<a href=\\”{0}\\” target=\\”_blank\\”>{1}</a>”, match.Value, match.Value));
}
//用正则表达式识别Email地址
Regex EmailRegex = new Regex(@”([a-zA-Z_0-9.-]+\\@[a-zA-Z_0-9.-]+\\.\\w+)”, RegexOptions.IgnoreCase | RegexOptions.Compiled);
matches = EmailRegex.Matches(Text);
foreach (Match match in matches)
{
Text = Text.Replace(match.Value, string.Format(“<a href=mailt{0}>{1}</a>”, match.Value, match.Value));
}
return Text;
}