.Net集成敏感詞組件的步驟
ToolGood.Words
首先我們要使用的開源組件是 ToolGood.Words

通過簡單的了解,我們可以知道它可以針對敏感詞及其拼音、跳詞等變形進行檢測,在實際的應用場景中能滿足大部分的需求。
具體的用法在這里不做過多的介紹,接下來我們需要做的事情是如何在現(xiàn)有代碼中快速且方便的情況下接入敏感詞組件。很顯然,如果我們按照組件寫的示例去操作,會發(fā)現(xiàn)需要在現(xiàn)有的代碼中進行大量重構(gòu)的操作,這顯然會累垮 VS 。熟悉水弟的朋友首先就會想到使用 AOP 的方式去優(yōu)化處理。
ValidationAttribute
我們先定義兩個簡單的模型來綁定輸入?yún)?shù),一個是只要輸入含有敏感詞就會報錯,一個是只要輸入含有敏感詞就會把相關(guān)的字符串替換為 * ,代碼如下:
public class MinganCheckInput
{
[MinGanCheck]
public string Text { get; set; }
}
public class MinganReplaceInput
{
[MinGanReplace]
public string Text { get; set; }
}
其中 [MinGanCheck] 和 [MinGanReplace] 是我們定義的特性標記,將其繼承 ValidationAttribute,就和我們常用的 [Required] 一樣方便,哪里敏感點哪里。
/// <summary>
/// 敏感詞檢查的特性,一匹配就拋異常
/// </summary>
[AttributeUsage(AttributeTargets.Property)]
public class MinGanCheck : ValidationAttribute
{
protected override ValidationResult IsValid(object value, ValidationContext validationContext)
{
throw new NotImplementedException();
}
}
/// <summary>
/// 敏感詞替換
/// </summary>
[AttributeUsage(AttributeTargets.Property)]
public class MinGanReplace : ValidationAttribute
{
protected override ValidationResult IsValid(object value, ValidationContext validationContext)
{
return ValidationResult.Success;
}
}
接下來就是實現(xiàn) ValidationAttribute 的功能,如果看過水弟寫過的 aop 文章,這時候就不會直接在校驗的方法中直接引入 ToolGood.Words ,這樣會帶來很大的耦合,也不便于我們替換為其他的敏感詞組件或服務。所以我們只要再多一層抽象就可以了。
// 檢查
protected override ValidationResult IsValid(object value, ValidationContext validationContext)
{
return validationContext.GetService<IMinGanCheckValidator>().IsValid(value, validationContext);
}
// 替換
protected override ValidationResult IsValid(object value, ValidationContext validationContext)
{
validationContext.GetService<IMinGanReplaceValidator>().IsValid(value, validationContext);
return ValidationResult.Success;
}
接著我們分別實現(xiàn) IMinGanCheckValidator 和 IMinGanReplaceValidator 的功能,也即檢查和替換功能。
// 檢查
public class MinGanCheckValidator : IMinGanCheckValidator
{
public ValidationResult IsValid(object value, ValidationContext validationContext)
{
if (value is string v)
{
if (!String.IsNullOrEmpty(v))
{
// 文字檢查
if (MinGanProvider.Instance.IllegalWordsSearch.ContainsAny(v))
{
return new ValidationResult("存在敏感詞", new[] { validationContext.MemberName });
}
// 檢查拼音
if (MinGanProvider.Instance.IllegalWordsSearch.ContainsAny(WordsHelper.GetPinyin(v)))
{
return new ValidationResult("存在敏感詞",new []{ validationContext.MemberName });
}
// todo:其他變種
}
}
return ValidationResult.Success;
}
}
//替換
public class MinGanReplaceValidator : IMinGanReplaceValidator
{
public void Replace(object value, ValidationContext validationContext)
{
if (value is string v)
{
if (!String.IsNullOrEmpty(v))
{
v = MinGanProvider.Instance.IllegalWordsSearch.Replace(v);
SetPropertyByName(validationContext.ObjectInstance,validationContext.MemberName, v);
}
}
}
static bool SetPropertyByName(Object obj, string name, Object value)
{
var type = obj.GetType();
var prop = type.GetProperty(name, BindingFlags.Public | BindingFlags.Instance);
if (null == prop || !prop.CanWrite) return false;
prop.SetValue(obj, value, null);
return true;
}
}
其中 MinGanProvider.Instance.IllegalWordsSearch 是 ToolGood.Words 中的檢測類單例,這里不詳細展開。這樣我們就有一個大概能用的敏感詞檢測組件了,然而在實際過程中,我們還需要對敏感詞進行管理,特別是需要實時更新敏感詞。
敏感詞熱重載
以 json 配置文件存放敏感詞為例,只需要配置熱重載就行了。
首先是 Program.cs 文件中讓 json 配置文件熱重載。
public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureAppConfiguration((builderContext, config) =>
{
config.AddJsonFile("IllegalKeywords.json", optional: false, reloadOnChange: true);// 配置可熱重載
})
.ConfigureWebHostDefaults(webBuilder => { webBuilder.UseStartup<Startup>(); });
最后是在 Startup.cs 中文件處理重載事件。
ChangeToken.OnChange(() => Configuration.GetReloadToken(), () =>
{
// 敏感詞重載
var keys= Configuration.GetSection("IllegalKeywords").Get<List<string>>();
if (keys!=null&&keys.Any())
{
var allKeys = new List<string>();
foreach (var k in keys)
{
allKeys.Add(k); // 增加詞匯
allKeys.Add(WordsHelper.ToTraditionalChinese(k)); // 增加繁體
allKeys.Add(WordsHelper.GetPinyin(k)); // 增加拼音
}
IllegalWordsSearch.SetKeywords(allKeys);
}
});
效果


結(jié)語
看到這里,可能有些人已經(jīng)罵罵咧咧退出網(wǎng)站,說好的兩分鐘,光是看文章和復制代碼都需要十幾分鐘。所以為了滿足伸手黨的需求,我寫了一個簡單的示例,只要把對應文件和代碼復制到代碼就可以使用了,真的不超過2分鐘就能實現(xiàn)敏感詞檢測。
項目地址:https://github.com/jonechenug/ToolGood.Words.Sample

以上就是.Net集成敏感詞組件的步驟的詳細內(nèi)容,更多關(guān)于.Net集成敏感詞組件的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
.NetCore利用BlockingCollection實現(xiàn)簡易消息隊列
這篇文章主要介紹了.NetCore利用BlockingCollection實現(xiàn)簡易消息隊列,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09
asp.net 文件路徑之獲得虛擬目錄的網(wǎng)站的根目錄
asp.net下獲取文件路徑常用代碼,獲得虛擬目錄的網(wǎng)站的根目錄2012-10-10
Visual Studio 2017 community安裝配置方法圖文教程
這篇文章主要為大家詳細介紹了Visual Studio 2017 community安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-09-09
在?Net7.0?環(huán)境下如何使用?RestSharp?發(fā)送?Http(FromBody和FromForm)請求
這篇文章主要介紹了在?Net7.0?環(huán)境下使用?RestSharp?發(fā)送?Http(FromBody和FromForm)請求,今天,我就兩個小的知識點,就是通過使用?RestSharp?訪問?WebAPI,提交?FromBody?和?FromForm?兩種方式的數(shù)據(jù),還是有些區(qū)別的,本文結(jié)合實例代碼介紹的非常詳細,需要的朋友參考下吧2023-09-09
.NET Core 微信小程序退款步驟——(統(tǒng)一退款)
這篇文章主要介紹了.NET Core 微信小程序退款步驟——(統(tǒng)一退款),本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-09-09
asp.net表單提交時防重復提交并執(zhí)行前臺的JS驗證
今天遇到這樣的一個情況,就是用戶重復提交。當然這個不能怪用戶,只能怪.NET或者服務器反應遲鈍,下面有個不錯的教程,大家可以參考下2013-10-10

