PHP對HTML編碼字串的處理

來源:互聯網
上載者:User
今天在寫一個PHP指令碼訪問資料庫時,發現其中的中文字串使用了HTML編碼方式進行儲存的(比如中文字“毛”對應的HTML編碼為“毛”),使得在對該欄位進行條件查詢時不能進接使用中文進行查詢,而要將其轉換為編碼後再進行條件匹配。

PHP中對可讀性字元與HTML編碼字元相互轉換時需要使用到htmlentities和html_entity_decode函數。於是寫出如下查詢語句,

$sql="selectid,depart_name,first_name,last_name,local_name,extension,mobile,title ";$sql.="frompb_extensione,pb_departmentd ";$sql.="wheree.depart_id=d.depart_id ";$sql.="andd.plant='".$plant."' ";$sql.="and(first_namelike'%".$HTTP_POST_VARS["q"]."%'";$sql.="orlast_namelike'%".$HTTP_POST_VARS["q"]."%'";$sql.="orlocal_namelike'%".htmlentities($HTTP_POST_VARS["q"])."%'";$sql.="orextensionlike'%".$HTTP_POST_VARS["q"]."%'";$sql.="ormobilelike'%".$HTTP_POST_VARS["q"]."%'";$sql.="ordepart_namelike'%".$HTTP_POST_VARS["q"]."%'";$sql.="ortitlelike'%".$HTTP_POST_VARS["q"]."%'";$sql.=") ";

並執行。可是怪是卻發生了,此語句在SQL Analyzer中可以正確執行並查詢出結果,而在IE中很執行這段指令碼卻提示查詢結果為零,這是為什麼呢?

經過仔細檢查這段SQL,並查看在IE中的源碼,發現了問題的根結所在。查詢值經htmlentities函數後轉換為HTML編碼,此編碼中存在著特殊字元&(如第一段中的舉例),在IE中這個字元是另有含義的。在IE中一般都是使用“&”來表示這個符號的,導致在IE中看到輸出的SQL語句和真正執行的語句是不一樣的。

要解決這個問題就要想個辦法不讓IE使用“&”表示“&”符號。經過一翻查詢,發現使用如下代碼可以解決這個問題。

<?php$trans=get_html_translation_table(HTML_ENTITIES);$trans=array_flip($trans);$encoded="Hallo&amp;&lt;Frau&gt;&amp;Kr&auml;mer";$original=strtr($encoded,$trans);echo$original;?>

執行這段代碼,輸出的$original變數值為“Hallo & <Frau> & Krämer”,這正是我想要的結果。

以上是我在工作中遇到的問題及解決方案,特將其寫在我的Blog上,與那些遇到和我相似問題的朋友們一起分享。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.