高效.NET髒字過濾演算法與應用執行個體

來源:互聯網
上載者:User
本文執行個體講述了高效.NET髒字過濾演算法。分享給大家供大家參考,具體如下:

BadWordsFilter.cs類

using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Collections;using System.Data;namespace WNF{  public class BadWordsFilter  {    private HashSet<string> hash = new HashSet<string>(); //關鍵字    private byte[] fastCheck = new byte[char.MaxValue];    private byte[] fastLength = new byte[char.MaxValue];    private BitArray charCheck = new BitArray(char.MaxValue);    private BitArray endCheck = new BitArray(char.MaxValue);    private int maxWordLength = 0;    private int minWordLength = int.MaxValue;    public BadWordsFilter()    {    }    //初始化關鍵字    public void Init(DataTable badwords)    {      for (int j = 0; j < badwords.Rows.Count; j++)      {        string word = badwords.Rows[j][0].ToString();        maxWordLength = Math.Max(maxWordLength, word.Length);        minWordLength = Math.Min(minWordLength, word.Length);        for (int i = 0; i < 7 && i < word.Length; i++)        {          fastCheck[word[i]] |= (byte)(1 << i);        }        for (int i = 7; i < word.Length; i++)        {          fastCheck[word[i]] |= 0x80;        }        if (word.Length == 1)        {          charCheck[word[0]] = true;        }        else        {          fastLength[word[0]] |= (byte)(1 << (Math.Min(7, word.Length - 2)));          endCheck[word[word.Length - 1]] = true;          hash.Add(word);        }      }    }    public string Filter(string text, string mask)    {      throw new NotImplementedException();    }    //檢查是否有關鍵字    public bool HasBadWord(string text)    {      int index = 0;      while (index < text.Length)      {        int count = 1;        if (index > 0 || (fastCheck[text[index]] & 1) == 0)        {          while (index < text.Length - 1 && (fastCheck[text[++index]] & 1) == 0) ;        }        char begin = text[index];        if (minWordLength == 1 && charCheck[begin])        {          return true;        }        for (int j = 1; j <= Math.Min(maxWordLength, text.Length - index - 1); j++)        {          char current = text[index + j];          if ((fastCheck[current] & 1) == 0)          {            ++count;          }          if ((fastCheck[current] & (1 << Math.Min(j, 7))) == 0)          {            break;          }          if (j + 1 >= minWordLength)          {            if ((fastLength[begin] & (1 << Math.Min(j - 1, 7))) > 0 && endCheck[current])            {              string sub = text.Substring(index, j + 1);              if (hash.Contains(sub))              {                return true;              }            }          }        }        index += count;      }      return false;    }  }}

引用:

string sql = "select keywords from tb_keyword";BadWordsFilter badwordfilter = new BadWordsFilter();//初始化關鍵字badwordfilter.Init(oEtb.GetDataSet(sql).Tables[0]);//檢查是否有存在關鍵字bool a = badwordfilter.HasBadWord(TextBox1.Text);if (a == true){    Page.RegisterClientScriptBlock("a", "<script>alert('該評論含有不合法文字!')</script>");}else{    PingLun();//寫入評論表}

希望本文所述對大家asp.net程式設計有所協助。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.