欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP+MYSQL中文亂碼問題

 更新時間:2015年07月01日 10:45:16   投稿:hebedich  
這篇文章主要匯總介紹了幾種解決PHP+MYSQL中文亂碼問題的方法,十分的實用,有需要的小伙伴可以參考下。

從MySQL 4.1開始引入多語言的支持,但是用PHP插入的中文會出現(xiàn)亂碼.無論用什么編碼也不行.

解決這個問題其實很簡單.

1.在建表的時候設置編碼類型為gb2312_chinese_ci.

2.在PHP頁面的數(shù)據(jù)庫連接語句加一行mysql_query("SET NAMES 'gb2312'",$link); 例如

$db_host="localhost"; 
$db_user="root"; 
$db_password="password"; 
$db_name="test";

$link=mysql_connect($db_host,$db_user,$db_password);
mysql_query("SET NAMES 'gb2312'",$link); 
$db=mysql_select_db($db_name,$link); 
$query="select * from user"; 
$result=mysql_query($query);

寫入頁面和讀取頁面都加入這行.這樣在MYSQL里面的中文就能正常顯示了.

相關資料:

從MySQL 4.1開始引入多語言的支持,而且一些特性已經超過了其他的數(shù)據(jù)庫系統(tǒng)。
MySQL4.1的字符集支持(Character Set Support)有兩個方面:字符集(Characterset)和排序方式(Collation)。對于字符集的支持細化到四個層次:服務器 (server),數(shù)據(jù)庫(database),數(shù)據(jù)表(table)和連接(connection)。
查看系統(tǒng)的字符集和排序方式的設定可以通過下面的兩條命令:!

mysql> show variables like 'character_set_%';
+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | latin1 |
| character_set_connection | latin1 |
| character_set_database | latin1 |
| character_set_results | latin1 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
7 rows in set (0.00 sec)
mysql> show variables like 'collation_%';
+----------------------+-------------------+
| Variable_name | Value |
+----------------------+-------------------+
| collation_connection | latin1_swedish_ci |
| collation_database | latin1_swedish_ci |
| collation_server | latin1_swedish_ci |
+----------------------+-------------------+
3 rows in set (0.00 sec)

上面列出的值就是系統(tǒng)的默認值。(很奇怪系統(tǒng)怎么默認是latin1的瑞典語排序方式)...
當我們按照原來的方式通過PHP存取MySQL數(shù)據(jù)庫時,就算設置了表的默認字符集為utf8并且通過UTF-8編碼發(fā)送查詢,你會發(fā)現(xiàn)存入數(shù)據(jù)庫的仍然是亂碼。問題就出在這個connection連接層上。解決方法是在發(fā)送查詢前執(zhí)行一下下面這句:
set names 'utf8';
它相當于下面的四句指令:

復制代碼 代碼如下:

set character_set_client = utf8;
set character_set_results = utf8;
set character_set_connection = utf8;
set collation_connection = utf8_general_ci

由于默認網頁提交的查詢是gb2312(表單頁面meta里可以看到),而mysql默認將其當作utf8(可以查到此時的 character_set_client=utf8),所以必然亂碼。同理,mysql返回的結果是已經轉換成 character_set_results編碼的(與表的編碼無關),同樣默認是utf8,而網頁頁面把它當gb2312處理,所以必然有標題等由數(shù)據(jù) 庫讀出的字段是亂碼而其他php部分文字不亂碼的現(xiàn)象。

解決(by 一劍飄雪):
安裝mysql5.0時要選utf8字符集(在用phpmyadmin創(chuàng)建數(shù)據(jù)庫和字段時就不需要在整理中選utf8字符集了),并在php建立連接后發(fā)送

復制代碼 代碼如下:

$link = mysql_connect('localhost', 'root', 'root');
mysql_query("SET NAMES 'utf8'",$link);

這時我們在網頁中看到的還是亂碼但已不是????了,查看網頁源文件,已完全正常。用記事本打開php源文件,別存為utf8編碼,再刷新網頁,全部搞定了。
或者,當然還是要安裝時仍要utf8安裝,在php中發(fā)送set names 'gb2312',同時php文件存為記事本默認的ansi,也能正確顯示中文.

但總不能每次連接時都發(fā)送一次SET NAMES 'utf8'吧,如何徹底解決還沒找到方法。

這樣安裝mysql時缺省字符集選為utf8后又帶來一個問題,我們在command.exe中進入mysql控制臺后,查詢結果又成了亂碼,我們可以在查詢前輸入

復制代碼 代碼如下:

mysql>set names 'gbk';

復制代碼 代碼如下:

mysql>set names 'gb2312';

相當于告訴mysql客戶端在使用gb2312字符集,結果就正確了,gb2312為GBK的子集.

相關文章

  • ThinkPHP防止SQL注入攻擊的方法

    ThinkPHP防止SQL注入攻擊的方法

    在ThinkPHP中,參數(shù)綁定是一種安全的方式,用于處理用戶輸入,特別是在構建數(shù)據(jù)庫查詢時,參數(shù)綁定可以防止SQL注入攻擊,所以本文將給大家介紹了ThinkPHP防止SQL注入攻擊的方法,需要的朋友可以參考下
    2023-12-12
  • centos下file_put_contents()無法寫入文件的原因及解決方法

    centos下file_put_contents()無法寫入文件的原因及解決方法

    下面小編就為大家?guī)硪黄猚entos下file_put_contents()無法寫入文件的原因及解決方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • PHP實現(xiàn)操作redis的封裝類完整實例

    PHP實現(xiàn)操作redis的封裝類完整實例

    這篇文章主要介紹了PHP實現(xiàn)操作redis的封裝類,以完整實例形式較為詳細的分析了PHP操作redis的自定義類及其相關使用方法,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-11-11
  • PHP Header用于頁面跳轉時的幾個注意事項

    PHP Header用于頁面跳轉時的幾個注意事項

    大家都知道header函數(shù)中Location類型的標頭是一種特殊的header調用,常用來實現(xiàn)頁面跳轉,在新手剛學習的時候有些注意事項要注意,下面通過本文來詳細看看吧。
    2016-10-10
  • 自己寫的兼容低于PHP 5.5版本的array_column()函數(shù)

    自己寫的兼容低于PHP 5.5版本的array_column()函數(shù)

    這篇文章主要介紹了自己寫的兼容低于PHP 5.5版本的array_column()函數(shù),array_column是PHP 5.5新增函數(shù),有時在低版本中也可能要用到,需要的朋友可以參考下
    2014-10-10
  • PHPstorm快捷鍵(分享)

    PHPstorm快捷鍵(分享)

    下面小編就為大家?guī)硪黄狿HPstorm快捷鍵(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • php調整gif動畫圖片尺寸示例代碼分享

    php調整gif動畫圖片尺寸示例代碼分享

    這篇文章主要介紹了如何使用php調整gif動畫圖片尺寸,大家可以參考使用
    2013-12-12
  • zen cart新進商品的隨機排序修改方法

    zen cart新進商品的隨機排序修改方法

    由于新進商品的數(shù)量可能比頁面上能顯示的數(shù)量多,所以采用的是隨機顯示的方式。如果想改為按時間順序顯示,可以按照radnows提供的 方法修改。(記住使用文件替代)
    2010-09-09
  • PHP實現(xiàn)數(shù)組遞歸轉義的方法

    PHP實現(xiàn)數(shù)組遞歸轉義的方法

    這篇文章主要介紹了PHP實現(xiàn)數(shù)組遞歸轉義的方法,包含了數(shù)組的遞歸調用與字符串的轉義方法,需要的朋友可以參考下
    2014-08-08
  • Thinkphp結合AJAX長輪詢實現(xiàn)PC與APP推送詳解

    Thinkphp結合AJAX長輪詢實現(xiàn)PC與APP推送詳解

    這篇文章主要給大家介紹了關于Thinkphp結合AJAX長輪詢實現(xiàn)PC與APP推送的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起看看吧。
    2017-07-07

最新評論