博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
敏感字符过滤算法
阅读量:5076 次
发布时间:2019-06-12

本文共 1287 字,大约阅读时间需要 4 分钟。

package com.lala.teamtoneback.code.common.util;

import java.util.ArrayList;

import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* 算法思路:把敏感词的第一个字符取出来,作为比较对象。
* 遍历整个字符串,如果发现字符跟敏感词第一个字符相同,
* 就从字符串取出跟关键词相同长度的子串比较,如果相同就替换
* @author Administrator
*
*/
public class WordFilter {
private static Map<Character,List<String>> wordListToMap(List<String> sensitiveWordList){
Map<Character,List<String>> result=new HashMap<Character,List<String>>();
for (String s:sensitiveWordList){
char c=s.charAt(0);
List<String> strs=result.get(c);
if (strs==null){
strs=new ArrayList<String>();
result.put(c,strs);
}
strs.add(s);
}
return result;
}
public static String filter(String src,List<String> sensitiveWordList){
Map<Character,List<String>> wordMap=wordListToMap(sensitiveWordList);
StringBuilder strb=new StringBuilder();
String temp="";
for (int i=0;i<src.length();i++){
char c=src.charAt(i);
String find=null;
if (wordMap.containsKey(c)){
List<String> words=wordMap.get(c);
for (String s:words){
temp=src.substring(i,(s.length()<=(src.length()-i))?i+s.length():i);
if (s.equals(temp)){
find=s;
break;
}
}
}
if (find!=null){
strb.append("****");
i+=(find.length()-1);
} else {
strb.append(c);
}
}
return strb.toString();
}
}

转载于:https://www.cnblogs.com/zengdingxin/p/3183939.html

你可能感兴趣的文章
Http请求 post get
查看>>
JavaScript&jQuery.表达式与运算符
查看>>
JavaScript&jQuery.对象.属性
查看>>
为优雅,简洁而使用$_
查看>>
file_get_post实现post请求
查看>>
SpringBoot入门 (五) 数据库访问之spring data jpa
查看>>
JavaScript基础笔记(六)BOM
查看>>
千万不要点我
查看>>
navcat mysql 设置主表的外键
查看>>
button
查看>>
import && require 的区别
查看>>
哈夫曼树与哈夫曼码
查看>>
第二次冲刺02
查看>>
章节十五、7- 配置文件-Console Logging
查看>>
44.Android MD5Util
查看>>
网摘-获取屏幕dc并且将其画面显示在窗体中
查看>>
eclipse maven工程中src/main/resources目录下创建的文件夹是包图标的解决方法
查看>>
类变量,实例变量
查看>>
chrony软件使用说明
查看>>
表单(三):select
查看>>