Heim >php教程 >php手册 >PHP对HTML编码字符串的处理

PHP对HTML编码字符串的处理

WBOY
WBOYOriginal
2016-06-06 19:55:101026Durchsuche

今天在写一个PHP脚本访问数据库时,发现其中的中文字符串使用了HTML编码方式进行存储的(比如中文字毛对应的HTML编码为#27611;),使得在对该字段进行条件查询时不能进接使用中文进行查询,而要将其转换为编码后再进行条件匹配。 PHP中对可读性字符与HTML编

今天在写一个PHP脚本访问数据库时,发现其中的中文字符串使用了HTML编码方式进行存储的(比如中文字“毛”对应的HTML编码为“毛”),使得在对该字段进行条件查询时不能进接使用中文进行查询,而要将其转换为编码后再进行条件匹配。

        PHP中对可读性字符与HTML编码字符相互转换时需要使用到htmlentitieshtml_entity_decode函数。于是写出如下查询语句,

PHP对HTML编码字符串的处理    $sql = "select id,depart_name,first_name,last_name,local_name,extension,mobile,title ";
PHP对HTML编码字符串的处理    
$sql.= "from pb_extension e, pb_department d  ";
PHP对HTML编码字符串的处理    
$sql.= "where e.depart_id = d.depart_id  ";
PHP对HTML编码字符串的处理    
$sql.= "  and d.plant='".$plant."' ";
PHP对HTML编码字符串的处理    
$sql.= " and (first_name like '%".$HTTP_POST_VARS["q"]."%'";
PHP对HTML编码字符串的处理    
$sql.= " or last_name like '%".$HTTP_POST_VARS["q"]."%'";
PHP对HTML编码字符串的处理    
$sql.= " or local_name like '%".htmlentities($HTTP_POST_VARS["q"])."%'";
PHP对HTML编码字符串的处理    
$sql.= " or extension like '%".$HTTP_POST_VARS["q"]."%'";
PHP对HTML编码字符串的处理    
$sql.= " or mobile like '%".$HTTP_POST_VARS["q"]."%'";
PHP对HTML编码字符串的处理    
$sql.= " or depart_name like '%".$HTTP_POST_VARS["q"]."%'";
PHP对HTML编码字符串的处理    
$sql.= " or title like '%".$HTTP_POST_VARS["q"]."%'";
PHP对HTML编码字符串的处理    
$sql.= "";

并执行。可是怪是却发生了,此语句在SQL Analyzer中可以正确执行并查询出结果,而在IE中很执行这段脚本却提示查询结果为零,这是为什么呢?

        经过仔细检查这段SQL,并查看在IE中的源码,发现了问题的根结所在。查询值经htmlentities函数后转换为HTML编码,此编码中存在着特殊字符&(如第一段中的举例),在IE中这个字符是另有含义的。在IE中一般都是使用“&”来表示这个符号的,导致在IE中看到输出的SQL语句和真正执行的语句是不一样的。

        要解决这个问题就要想个办法不让IE使用“&”表示“&”符号。经过一翻查询,发现使用如下代码可以解决这个问题。

PHP对HTML编码字符串的处理php
PHP对HTML编码字符串的处理  
$trans = get_html_translation_table(HTML_ENTITIES);
PHP对HTML编码字符串的处理  
$trans = array_flip($trans);
PHP对HTML编码字符串的处理  
$encoded = "Hallo &  & Krämer";
PHP对HTML编码字符串的处理  
$original = strtr($encoded, $trans);
PHP对HTML编码字符串的处理  
echo $original;
PHP对HTML编码字符串的处理
?>

执行这段代码,输出的$original变量值为“Hallo & & Krämer”,这正是我想要的结果。

        以上是我在工作中遇到的问题及解决方法,特将其写在我的Blog上,与那些遇到和我相似问题的朋友们一起分享。



 
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Vorheriger Artikel:ubuntu下安装php平台Nächster Artikel:PHP 类与对象