JS使用ActiveXObject实现用户提交表单时屏蔽敏感词功能
程序员文章站
2022-03-21 14:55:02
本例中敏感词ciku.txt放在c盘根目录下,采用的activexobject插件获取本地文件内容。使用此插件不需网上下插件,直接用如下js代码即可。
浏览器需修改int...
本例中敏感词ciku.txt放在c盘根目录下,采用的activexobject插件获取本地文件内容。使用此插件不需网上下插件,直接用如下js代码即可。
浏览器需修改interner安全选项的级别,启用activex才能获取到代码中的activexobject插件。如下图所示:
js代码实现如下:
<script type="text/javascript"> // -------------- 全局变量,用来判断文本域中是否包含脏词,默认为false,即不包含脏词------- var isdirty = false; //使用activex读取本地文件获取dirtyword词库 function readfile(){ //var forreading = 1; var fso = new activexobject("scripting.filesystemobject"); openf = fso.opentextfile("c:\\ciku.txt", 1); var cikustr= openf.readall(); return cikustr; } /* * 提交表单的主方法 * 在提交表单的时候对内容进行过滤并在文本域显示过滤后的内容 */ function submitform1() { var messagevalue=document.getelementbyid("message").value; var cikustr=readfile(); var cikuarr= new array(); //定义数组,存储敏感词 cikuarr=cikustr.split(" "); //敏感字符分割 for (var i=0;i<cikuarr.length;i++){ var flag=cikuarr[i]; if(messagevalue.indexof(flag)>=0){ //查找文本域中是否包含敏感字符,是则替换 filterword(messagevalue); var ifs=confirm("你的留言中含有不恰当的词语,系统已自动为你修改,是否继续提交?"); break; }else{ //无敏感字符,直接提交表单 document.getelementbyid("message_board").submit(); break; } } if(ifs){ //用户点击确定,则提交表单 document.getelementbyid("message_board").submit(); } } /* * 对传进来的messagevalue过滤并返回新内容 */ function filterword(messagevalue){ // 根据文本域的id获取文本域对象内容 var cikustr=readfile(); var cikuarr= new array(); //定义数组,存储敏感词 cikuarr=cikustr.split(" "); //敏感字符分割到数组内 for (var i=0;i<cikuarr.length;i++){ messagevalue=filteroneword(messagevalue,cikuarr[i]);//filteroneword函数每次替换一个字符,需循环调用 } document.getelementbyid("message").value=messagevalue; //将替换后的内容显示到文本域中 } /* * 这个函数用来过滤单个词语, 如果messagevalue中含有onedirtyword, 则用"**"替换这个onedirtyword * messagevalue --- 要过滤的语句 */ function filteroneword(messagevalue,onedirtyword){ var str=messagevalue.replace(new regexp(onedirtyword,'g'),"**"); return str; } </script>
表单部分代码:
<body> <form name="message_board" id="message_board" action="aaa.html"> <textarea name="message" id="message" cols="50" rows="10"> "this is you post messsage" ——phpdream </textarea><br/> <input type="button" value="提交留言" id="submitmessage" onclick="submitform1()"/> </form> </body>