为什么文章要添加内链?
1.有利于读者
我写内链文章的最初动机是让读者在我的博客获得更好的阅读体验,并获得更多的价值。如果我的读者访问了我的一篇文章,发现不仅仅回答他需要的答案,还提供了更多相关内容的信息,让他们能在更多的相关主题去扩展阅读,他们迟早会喜欢并满意我的博客。让读者满意就是我们的目标,读者他们满意了,通常就会再次回访(这让你的博客变得有”粘性”)并和他们的朋友分享。
2.搜索引擎优化(SEO)
另外一个在你的博客相互链接文章的重要原因就是,搜索引擎在查看博客中链接的时候,既能找到内容,又能有利于建立博客索引和提高博客内容的排名。从其他外部博客建立的链接价值最高,能够提高你在搜索引擎的排名,内链虽然效果没这么好,但是也是对排名有帮助的。
3.提升页面浏览量
在文章中增加链接能够提高读者访问其他页面内容的机会,这带来许多好处,首先它可以帮助您获得更多的访问者,如果你正在运行某种 CPM(按访问人次收费)广告,这是非常受益的。其次大量内链给你的博客浏览者创造了一个博客内容丰富的印象。我发现,当有人在你的博客上看到一个以上的页面时,他们更容易记住它,订阅它,评论它,并成为一个经常和忠实的读者。
而这三个好处看起来显得作用不明显,但是当你拥有大量内容的时候,它所能带来的好处就是无法估量的。所以建议你从博客建立的时候就开始构建内链到站内的其他文章,慢慢地这些内链积累下来的好处将会产生非常明显的好处。
当然还有更多好处,请自行百度知,说着说着有点跑偏主题了,我们主要说用C#怎么实现此功能,话不多说,上干货!!
第一种办法:(string src指文本字符, IList keys 指要匹配的关键词库集合)
{
Regex reg = new Regex(@"(?i)(?:^|(?<!<a\b(?>[^<>]*))>)(?>[^<>]*)(?:<|$)");
int length = 0;
string temp = string.Empty;
return reg.Replace(src, delegate (Match m)
{
temp = m.Value;
length = temp.Length;
for (int i = 0; i < keys.Count; i++)
{
string keyWordName = Regex.Escape(keys[i].KeyName);
string keyWordUrl = Regex.Escape(keys[i].PCUrl);
temp = Regex.Replace(temp, @"(?is)^((?:(?:(?!" + keyWordName + @"|</?a\b).)*<a\b(?:(?!</?a\b).)*</a>)*(?:(?!" + keyWordName +
@"|</?a\b).)*)(?<tag>" + keyWordName + @")",
@"$1<a href=""" + keyWordUrl + @""" target=""_blank"" title=""${tag}"">${tag}</a>");
if (length != temp.Length)
{
keys.Remove(keys[i]);
}
length = temp.Length;
}
return temp;
});
}
第二种办法:(这是我自己能想到的办法)
/// 一键匹配内链,只替换第一个匹配到的字符
/// </summary>
/// <param name="content">要匹配的文本字符</param>
/// <param name="type">判断类型是否是"编辑"</param>
/// <returns></returns>
[HttpPost]
[ValidateInput(false)]
public async Task<ActionResult> ContentReplace(string content, string type)
{
try
{
if (type == "edit")
{
content = WebHelper.ReplaceStrHref(content);
}
if (string.IsNullOrEmpty(content))
{
return Content("请输入文本信息");
}
var list = await bll.GetAllList();
if (list != null)
{
#region 第二种办法
// 第一次
Regex reg = null;
int n = -1;
Dictionary<string, string> dic = new Dictionary<string, string>();
for (int i = 0; i < list.Count; i++)
{
if (Regex.Match(content, list[i].KeyName).Success)
{
string pattern = $"<a href=\"{list[i].PCUrl}\" target=\"_blank\">{list[i].KeyName}</a>";
reg = new Regex(list[i].KeyName);
content = reg.Replace(content, pattern, 1);
if (Regex.Match(content, pattern).Success)
{
//如果当前关键字链接信息成功,将当前的文本链接信息提取出来添加到字典中(dic),并以唯一标识符代替文本链接信息作为占位符。
reg = new Regex(pattern);
n++;
content = reg.Replace(content, "{" + n + "}", 1);
dic.Add("{" + n + "}", pattern);
}
}
}
//将匹配到的文本链接信息format
if (dic.Count != 0)
{
int m = -1;
foreach (string key in dic.Keys)
{
m++;
if (content.Contains("{" + m + "}"))
{
content = content.Replace("{" + m + "}", dic[key]);
}
}
}
#endregion
content = WebHelper.RemoveStrImgAlt(content);
return Content(content);
}
else
{
throw new Exception("关键字库中没有数据,检查集合是否抛异常了");
}
}
catch (Exception ex)
{
throw ex;
}
}
此处也贴出上面WebHelper中的两个方法:(关于作用方法都有注释)
/// 移除文本字符的a标签
/// </summary>
public static string ReplaceStrHref(string content)
{
var r = new Regex(@"<a\s+(?:(?!</a>).)*?>|</a>", RegexOptions.IgnoreCase);
Match m;
for (m = r.Match(content); m.Success; m = m.NextMatch())
{
content = content.Replace(m.Groups[0].ToString(), "");
}
return content;
}
/// <summary>
/// 移除字符文本Img里面Alt关键字包裹的内链
/// </summary>
public static string RemoveStrImgAlt(string content)
{
Regex rg2 = new Regex("(?<=alt=\"<a[^<]*)</a>\"");
if (rg2.Match(content).Success)
{
content = rg2.Replace(content, "");
}
Regex rg = new Regex("(?<=alt=\")<a href=\"[^>]*>");
if (rg.Match(content).Success)
{
content = rg.Replace(content, "");
}
return content;
}