1. 程式人生 > >smartfoxserver擴充套件裡面過濾聊天的不合法字元

smartfoxserver擴充套件裡面過濾聊天的不合法字元

http://blog.csdn.net/yc7369/article/details/35567105

最近做手遊客戶要求加上一個聊天功能,其實嘛,個人覺得這個聊天功能比較雞肋,這部分幾乎已經有tx被壟斷,我們又何苦倘這趟渾水呢,手遊聊天的遊戲其實並不多。

主要原因很簡單:伺服器的負載會增大不少,維護更加麻煩,燒錢,而用這個功能的人也不會太多,也會出現伺服器調控下的各種穿幫。

既然要趟這渾水,那也就沒辦法,聊天系統判斷聊天內容是否包含有不合法字元還是需要的。

使用的是smartfoxserver伺服器擴充套件,因為SFS預設它是UTF-8編碼的,除了英文以外發送過來的字元都是會亂碼的,所以我想了一天想到了下面的方法供大家參考,如果有不對的地方請留言提出!

try {

     String[] keyword = { "操", "fuck", "叼", "cao" };
String content = json.getString("content").trim();

Pattern p = Pattern.compile("\\s*|\t|\r|\n"); //正則表示式
Matcher m = p.matcher(content);
String after = m.replaceAll(""); //把所有上述表示式的東西全部換成空字串

after = MsgTool.gbkToutf8(after); //把所用的字元都全部轉化為UTF-8編碼,這樣就不會出現編碼問題而不能比較

boolean flag = false; // 判斷是否包含遮蔽字元

for (int i = 0; i < keyword.length; i++) {

String kw = MsgTool.gbkToutf8(keyword[i]);

if (after.indexOf(kw) != -1) { //如果包含有的話就返回
flag = true;
break;
}
}

MsgJSONObject msj = MsgJSONObject.instance();

if (flag) {
log.info("有使用者聊天時傳送不合法字元,使用者是:" + user.getName()); //傳送給客戶端說使用者的聊天內容有不合法字元
msj.put("cmd", "chatUnlawful");
sendMessage(user, msj);

} else { //如果沒有就正常傳送

log.info("有使用者聊天,使用者是:" + user.getName());
log.info("聊天內容是:" + content);
msj.put("cmd", "chat");
msj.put("msg", content);
sendMessage(getRoom(user), msj);
}

} catch (Exception e) {
e.printStackTrace();
log.error("讀取聊天內容錯誤");
}

/**編碼轉換,將中文變為UTF-8
* @param chenese 要中文字元
* @return
*/
public static String gbkToutf8(String chinese){
char c[] = chinese.toCharArray();
byte [] fullByte =new byte[3*c.length];
for(int i=0; i<c.length; i++){
int m = (int)c[i];
String word = Integer.toBinaryString(m);

StringBuffer sb = new StringBuffer();
int len = 16 - word.length();
//補零
for(int j=0; j<len; j++){
sb.append("0");
}
sb.append(word);
sb.insert(0, "1110");
sb.insert(8, "10");
sb.insert(16, "10");

String s1 = sb.substring(0, 8);
String s2 = sb.substring(8, 16);
String s3 = sb.substring(16);

byte b0 = Integer.valueOf(s1, 2).byteValue();
byte b1 = Integer.valueOf(s2, 2).byteValue();
byte b2 = Integer.valueOf(s3, 2).byteValue();
byte[] bf = new byte[3];
bf[0] = b0;
fullByte[i*3] = bf[0];
bf[1] = b1;
fullByte[i*3+1] = bf[1];
bf[2] = b2;
fullByte[i*3+2] = bf[2];

}

try {
String fullStr = new String(fullByte, "UTF-8");
return fullStr;
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
log.error("轉換字元編碼錯誤");
return "";
}

}

http://blog.csdn.net/yc7369/article/details/35567105