php过滤ascii控制字符

Posted 网络虫

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php过滤ascii控制字符相关的知识,希望对你有一定的参考价值。

还记得以前在工作中,将爬来的其它网站的数据导到xml。但是会遇到一个问题:即网页会有ascII的控制字符。 一开始以为是别人为了防止采集而加入的,然后发现一个就往过滤表里加一个。直到慢慢发现,他们都是ascii表里的字符。 找到原因了,就好解决了。

 /**
  * 根据ascii码过滤控制字符
  * @param type $string
  */
 public static function special_filter($string)
 {
  if(!$string) return ‘‘;
 
  $new_string = ‘‘;
  for($i =0; isset($string[$i]); $i++)
  {
   $asc_code = ord($string[$i]);	//得到其asc码
   
   //以下代码旨在过滤非法字符
   if($asc_code == 9 || $asc_code == 10 || $asc_code == 13){
    $new_string .= ‘ ‘;
   }
   else if($asc_code > 31 && $asc_code != 127){
    $new_string .= $string[$i];
   }
  }
 
  return trim($new_string);
 }

以上是关于php过滤ascii控制字符的主要内容,如果未能解决你的问题,请参考以下文章

将扩展的 Ascii“表格”代码(例如 ─、┬)从 Php 脚本打印到控制台时出现问题

PHP 正则 空字符 / NUL字符

字符扩展ascii显示PHP

关于ASCII编码(补12号)

PHP——汉字完美转为ASCII码

PHP 代码片段