亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PHP+MYSQL中文亂碼問(wèn)題

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

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

解決這個(gè)問(wèn)題其實(shí)很簡(jiǎn)單.

1.在建表的時(shí)候設(shè)置編碼類(lèi)型為gb2312_chinese_ci.

2.在PHP頁(yè)面的數(shù)據(jù)庫(kù)連接語(yǔ)句加一行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);

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

相關(guān)資料:

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

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

復(fù)制代碼 代碼如下:

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

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

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

復(fù)制代碼 代碼如下:

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

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

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

這樣安裝mysql時(shí)缺省字符集選為utf8后又帶來(lái)一個(gè)問(wèn)題,我們?cè)赾ommand.exe中進(jìn)入mysql控制臺(tái)后,查詢結(jié)果又成了亂碼,我們可以在查詢前輸入

復(fù)制代碼 代碼如下:

mysql>set names 'gbk';

復(fù)制代碼 代碼如下:

mysql>set names 'gb2312';

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

相關(guān)文章

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

    ThinkPHP防止SQL注入攻擊的方法

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

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

    下面小編就為大家?guī)?lái)一篇centos下file_put_contents()無(wú)法寫(xiě)入文件的原因及解決方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-04-04
  • PHP實(shí)現(xiàn)操作redis的封裝類(lèi)完整實(shí)例

    PHP實(shí)現(xiàn)操作redis的封裝類(lèi)完整實(shí)例

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

    PHP Header用于頁(yè)面跳轉(zhuǎn)時(shí)的幾個(gè)注意事項(xiàng)

    大家都知道header函數(shù)中Location類(lèi)型的標(biāo)頭是一種特殊的header調(diào)用,常用來(lái)實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn),在新手剛學(xué)習(xí)的時(shí)候有些注意事項(xiàng)要注意,下面通過(guò)本文來(lái)詳細(xì)看看吧。
    2016-10-10
  • 自己寫(xiě)的兼容低于PHP 5.5版本的array_column()函數(shù)

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

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

    PHPstorm快捷鍵(分享)

    下面小編就為大家?guī)?lái)一篇PHPstorm快捷鍵(分享)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-07-07
  • php調(diào)整gif動(dòng)畫(huà)圖片尺寸示例代碼分享

    php調(diào)整gif動(dòng)畫(huà)圖片尺寸示例代碼分享

    這篇文章主要介紹了如何使用php調(diào)整gif動(dòng)畫(huà)圖片尺寸,大家可以參考使用
    2013-12-12
  • zen cart新進(jìn)商品的隨機(jī)排序修改方法

    zen cart新進(jìn)商品的隨機(jī)排序修改方法

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

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

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

    Thinkphp結(jié)合AJAX長(zhǎng)輪詢實(shí)現(xiàn)PC與APP推送詳解

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

最新評(píng)論