当前位置: 移动技术网 > IT编程>开发语言>JavaScript > JS使用ActiveXObject实现用户提交表单时屏蔽敏感词功能

JS使用ActiveXObject实现用户提交表单时屏蔽敏感词功能

2017年12月12日  | 移动技术网IT编程  | 我要评论

本例中敏感词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>

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网