.Net集成敏感詞組件的步驟

 更新時間:2021年05月13日 16:35:01   作者:張蘅水  
現如今大部分服務都會有用戶輸入,為了服務的正常運行,很多時候不得不針對輸入進行敏感詞的檢測、替換。如果人工做這樣的工作,不僅效率低,成本也高。水弟在這里寫了一個讓小編姐姐都覺得快的敏感詞組件接入示例,不需要依賴第三方服務,只需兩分鐘即可享受清爽文字。

ToolGood.Words

首先我們要使用的開源組件是 ToolGood.Words

通過簡單的了解,我們可以知道它可以針對敏感詞及其拼音、跳詞等變形進行檢測,在實際的應用場景中能滿足大部分的需求。
具體的用法在這里不做過多的介紹,接下來我們需要做的事情是如何在現有代碼中快速且方便的情況下接入敏感詞組件。很顯然,如果我們按照組件寫的示例去操作,會發現需要在現有的代碼中進行大量重構的操作,這顯然會累垮 VS 。熟悉水弟的朋友首先就會想到使用 AOP 的方式去優化處理。

ValidationAttribute

我們先定義兩個簡單的模型來綁定輸入參數,一個是只要輸入含有敏感詞就會報錯,一個是只要輸入含有敏感詞就會把相關的字符串替換為 * ,代碼如下:

    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;
        }
    }

接下來就是實現 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;
        }

接著我們分別實現 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);
            }
            });

效果

結語

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

以上就是.Net集成敏感詞組件的步驟的詳細內容,更多關于.Net集成敏感詞組件的資料請關注腳本之家其它相關文章!

相關文章

  • .Net Core 之 Ubuntu 14.04 部署過程(圖文詳解)

    .Net Core 之 Ubuntu 14.04 部署過程(圖文詳解)

    本篇文章主要介紹了.Net Core 之 Ubuntu 14.04 部署過程(圖文詳解),有興趣的可以了解一下。
    2016-11-11
  • .Net 調用存儲過程取到return的返回值

    .Net 調用存儲過程取到return的返回值

    存儲過程只能返回 int 類型,如果返回一個字符串 ,將會報類型轉化錯誤,下面以示例介紹下如何取到return的值,需要的朋友可以參考下
    2014-08-08
  • Asp.net 基于Cookie簡易的權限判斷

    Asp.net 基于Cookie簡易的權限判斷

    基于Cookie簡易的權限判斷代碼,需要的朋友可以參考下。
    2010-01-01
  • asp.net基于JWT的web api身份驗證及跨域調用實踐

    asp.net基于JWT的web api身份驗證及跨域調用實踐

    這篇文章主要介紹了asp.net基于JWT的web api身份驗證及跨域調用實踐,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-07-07
  • ASP.NET中保護自定義的服務器控件

    ASP.NET中保護自定義的服務器控件

    本文提供了針對自定義服務器控件的用戶和開發人員的基本安全準則。適合初學者,希望對你有幫助,一起來看。
    2015-10-10
  • asp.net的cms 核心代碼篇

    asp.net的cms 核心代碼篇

    第一篇:我簡略描述了一下我的cms標簽所表示的含義;anCMS(c#版)第一篇綁定數據;第二篇:我將展示了標簽背后真正運行的代碼,本文將介紹asp.net的cms 核心代碼篇
    2012-12-12
  • GridView的CheckBox列選擇及多參數傳遞三步搞定

    GridView的CheckBox列選擇及多參數傳遞三步搞定

    GridView的CheckBox列選擇及多參數傳遞三步實現:GridView的列設置/全選的Js處理/后臺對所選值的獲取,操作步驟很詳細,有利于新手學習,感興趣的朋友可以了解下啊
    2013-01-01
  • asp.net 上傳大文件解決方案

    asp.net 上傳大文件解決方案

    asp.net 上傳大文件解決方案...
    2007-04-04
  • .net微信服務號發送紅包

    .net微信服務號發送紅包

    這篇文章主要為大家詳細介紹了.net微信服務號發送紅包的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • ASP.NET對大文件上傳的解決方案

    ASP.NET對大文件上傳的解決方案

    在ASP.NET 開發的過程中,最大的問題就在于上傳大文件時讓開發者尤為的頭疼,而且,上傳時無法方便的做到多線程的操控和上傳進度的顯示。筆者在此給大家推薦一款簡單易用的上傳組件,從而快速便捷得解決了 ASP.NET 中的大文件上傳問題。
    2015-08-08

最新評論

精品国内自产拍在线观看