Files
bl/common/utils/go-sensitive-word-1.3.3

go-sensitive-word

敏感词(敏感词/违禁词/违法词/脏词)检测工具,基于 DFA 算法实现的高性能 Go 敏感词过滤工具框架。

快速接入

安装

go get -u github.com/zmexing/go-sensitive-word@latest

使用

package main

import (
   "fmt"
   sensitive "github.com/zmexing/go-sensitive-word"
   "log"
)

func main() {
   filter, err := sensitive.NewFilter(
      sensitive.StoreOption{Type: sensitive.StoreMemory}, // 基于内存
      sensitive.FilterOption{Type: sensitive.FilterDfa},  // 基于DFA算法
   )

   if err != nil {
      log.Fatalf("敏感词服务启动失败, err:%v", err)
      return
   }

   // 加载敏感词库
   err = filter.LoadDictEmbed(
      sensitive.DictCovid19,
      sensitive.DictOther,
      sensitive.DictReactionary,
      sensitive.DictViolence,
      sensitive.DictPeopleLife,
      sensitive.DictPornography,
      sensitive.DictAdditional,
      sensitive.DictCorruption,
      sensitive.DictTemporaryTencent,
   )
   if err != nil {
      log.Fatalf("加载词库发生了错误, err:%v", err)
      return
   }

   // 动态添加自定义敏感词
   err = filter.Store.AddWord("李世民", "秦始皇")
   if err != nil {
      log.Fatalf("添加敏感词发生了错误, err:%v", err)
      return
   }

   // 动态自定义敏感词白名单
   err = filter.Store.DelWord("武汉海鲜市场", "武汉")
   if err != nil {
      log.Fatalf("删除敏感词发生了错误, err:%v", err)
      return
   }

   sensitiveText := "李世民和老祖秦始皇的是忘年交,他们两个相约一起去武汉海鲜市场玩耍"

   // 是否有敏感词
   res1 := filter.IsSensitive(sensitiveText)
   fmt.Printf("res1: %v \n", res1)

   // 找到一个敏感词
   res2 := filter.FindOne(sensitiveText)
   fmt.Printf("res2: %v \n", res2)

   // 找到所有敏感词
   res3 := filter.FindAll(sensitiveText)
   fmt.Printf("res3: %v \n", res3)

   // 找到所有敏感词及出现次数
   res4 := filter.FindAllCount(sensitiveText)
   fmt.Printf("res4: %v \n", res4)

   // 和谐敏感词
   res5 := filter.Replace(sensitiveText, '*')
   fmt.Printf("res5: %v \n", res5)

   // 过滤铭感词
   res6 := filter.Remove(sensitiveText)
   fmt.Printf("res6: %v \n", res6)
}


// 输出结果
// res1: true
// res2: 李世民
// res3: [李世民 秦始皇]
// res4: map[李世民:1 秦始皇:1]
// res5: ***和老祖***的是忘年交,他们两个相约一起去武汉海鲜市场玩耍
// res6: 和老祖的是忘年交,他们两个相约一起去武汉海鲜市场玩耍 

支持的功能API

方法名 说明
IsSensitive() 判断文本中是否存在敏感词
FindOne() 查找文本中的第一个敏感词
FindAll() 查找文本中所有敏感词(去重)
FindAllCount() 查找所有敏感词及其出现次数
Replace() 替换所有敏感词为指定字符
Remove() 从文本中删除所有敏感词
AddWord() 动态添加敏感词
DelWord() 动态删除敏感词

更多特性

字符串检测

// HasEmail 判断字符串中是否存在邮箱地址
func HasEmail(s string) bool

// MaskEmail 将字符串中存在的邮箱地址替换成 "*"
func MaskEmail(s string) string

// HasURL 判断字符串中是否存在网址
func HasURL(s string) bool

// MaskURL 将字符串中存在的网址替换成 "*"
func MaskURL(s string) string

// HasDigit 判断字符串中是否存在指定个数的数字(大于等于该数字)
func HasDigit(s string, count int) bool

// MaskDigit 将字符串中存在的数字替换成 "*"
func MaskDigit(s string) string

// HasWechatID 判断字符串中是否存在微信号
func HasWechatID(s string) bool

// MaskWechatID 将字符串中存在的微信号替换成 "*"
func MaskWechatID(s string) string

常见问题

参考资料

声明

本项目包含了一些敏感词库,其设计目的是为了解决在互联网环境中可能出现的不适当内容,通过技术手段屏蔽这些敏感词,旨在构建一个更健康、更安全的网络空间。

请注意以下几点:

  1. 项目目的

    • 本项目的初衷是为开发者提供一个工具,帮助他们在各类互联网产品中过滤和屏蔽不适当或敏感的内容,从而营造一个良好的网络生态环境。
  2. 使用限制

    • 本项目中的敏感词库仅供技术研究和实现内容过滤功能之用。
    • 任何个人或组织不得将本项目中的敏感词库用于传播、分享或其他任何可能导致敏感信息扩散的行为。
  3. 责任声明

    • 使用本项目所产生的任何直接或间接后果,均由使用者自行承担。本项目开发者不对因不当使用造成的任何损失或法律后果负责。
  4. 使用规范

    • 请确保在使用本项目时遵守相关法律法规。
    • 禁止将本项目用于任何违法或不正当的用途。

通过下载和使用本项目,即表示您同意并接受上述声明的所有内容。希望本项目能够为您在构建净化网络空间的过程中提供帮助。我们鼓励所有开发者共同努力,营造一个健康、安全的网络环境。