當前位置:首頁 » 編程語言 » phpurl中文亂碼

phpurl中文亂碼

發布時間: 2024-05-08 06:25:34

1. php亂碼怎麼辦

PHP中文亂碼一般是字元集問題,編碼主要有下面幾個問題。

一.首先是PHP網頁的編碼

1.php文件本身的編碼與網頁的編碼應匹配

a.如果欲使用gb2312編碼,那麼php要輸出頭:header(「Content-Type: text/html; charset=gb2312"),靜態頁面添加<meta http-equiv="Content-Type" content="text/html; charset=gb2312">,所有文件的編碼格式為ANSI,可用記事本打開,另存為選擇編碼為ANSI,覆蓋源文件。

b.如果欲使用utf-8編碼,那麼php要輸出頭:header(「Content-Type: text/html; charset=utf-8"),靜態頁面添加<meta http-equiv="Content-Type" content="text/html; charset=utf-8">,所有文件的編碼格式為utf-8。保存為utf-8可能會有點麻煩,一般utf-8文件開頭會有BOM,如果使用session就會出問題,可用editplus來保存,在editplus中,工具->參數選擇->文件->UTF-8簽名,選擇總是刪除,再保存就可以去掉BOM信息了。

2.php本身不是Unicode的,所有substr之類的函數得改成mb_substr(需要裝mbstring擴展);或者用iconv轉碼。

二.PHP與Mysql的數據交互

PHP與資料庫的編碼應一致

1.修改mysql配置文件my.ini或my.cnf,mysql最好用utf8編碼

[mysql]
default-character-set=utf8
[mysqld]
default-character-set=utf8
default-storage-engine=MyISAM
在[mysqld]下加入:
default-collation=utf8_bin
init_connect='SET NAMES utf8'

2.在需要做資料庫操作的php程序前加mysql_query("set names '編碼'");,編碼和php編碼一致,如果php編碼是gb2312那mysql編碼就是gb2312,如果是utf-8那mysql編碼就是utf8,這樣插入或檢索數據時就不會出現亂碼了

三.PHP與操作系統相關

Windows和Linux的編碼是不一樣的,在Windows環境下,調用PHP的函數時參數如果是utf-8編碼會出現錯誤,比如move_uploaded_file()、filesize()、readfile()等,這些函數在處理上傳、下載時經常會用到,調用時可能會出現下面的錯誤:

Warning: move_uploaded_file()[function.move-uploaded-file]:failed to open stream: Invalid argument in ...

Warning: move_uploaded_file()[function.move-uploaded-file]:Unable to move '' to '' in ...

Warning: filesize() [function.filesize]: stat failed for ... in ...

Warning: readfile() [function.readfile]: failed to open stream: Invalid argument in ..

在Linux環境下用gb2312編碼雖然不會出現這些錯誤,但保存後的文件名出現亂碼導致無法讀取文件,這時可先將參數轉換成操作系統識別的編碼,編碼轉換可用mb_convert_encoding(字元串,新編碼,原編碼)或iconv(原編碼,新編碼,字元串),這樣處理後保存的文件名就不會出現亂碼,也可以正常讀取文件,實現中文名稱文件的上傳、下載。

其實還有更好的解決方法,徹底與系統脫離,也就不用考慮系統是何編碼。可以生成一個只有字母和數字的序列作為文件名,而將原來帶有中文的名字保存在資料庫中,這樣調用move_uploaded_file()就不會出現問題,下載的時候只需將文件名改為原來帶有中文的名字。實現下載的代碼如下

header("Pragma: public");

header("Expires: 0");

header("Cache-Component: must-revalidate, post-check=0, pre-check=0");

header("Content-type: $file_type");

header("Content-Length: $file_size");

header("Content-Disposition: attachment; filename=\"$file_name\"");

header("Content-Transfer-Encoding: binary");

readfile($file_path);

$file_type是文件的類型,$file_name是原來的名字,$file_path是保存在服務上文件的地址。

2. php 有關utf-8亂碼的問題

伺服器上用了別的編碼,應該是windows的伺服器吧?有可能是GBK或者GB2312編碼。
兩種方法解決此問題。
1、先在本地把所有文件都換成伺服器的編碼,然後再傳上去;此法,你的php編碼需要與伺服器上的資料庫編碼一致,也既有可能是那兩種編碼。
2、修改伺服器上的編碼為utf-8。此方法需要你有足夠的許可權去修改伺服器上apache或者IIS編碼。如果修改編碼成功,你的資料庫也不用換編碼。
如果保持你的網頁編碼不變,那就要修改mysql編碼,即像stjdydayou
所言,執行資料庫數據插入、更改、查詢時,執行一條查詢語句:
mysql_query("set
names
'utf-8'");
之所有用utf-8編碼,是因為你的php編碼目前為utf-8.

3. 中文url編碼、base64編碼,PHP解碼中文部分亂碼

如果兩端伺服器頁面使用的編碼不一致,就會導致亂碼

如你所說,對方伺服器發來的是GBK編碼的內容,如果你本地PHP用的編碼不是GBK就會是亂碼

2種解決方案:

  1. 將頁面編碼更改為GBK(可以通過header('Content-Type:text/html charset=gbk');)

  2. 將GBK編碼轉為當期頁面編碼(假設當前頁面是utf-8),可以使用iconv('gbk','utf-8',$content);其中$content是你經過urldecode、base64解碼後的字元串

4. php中強制下載文件的代碼(解決了IE下中文文件名亂碼問題)

中間遇到一個問題是提交的中文文件名直接放到header里在IE下會變成亂碼,解決方法是將文件名先urlencode一下再放入header,如下。
復制代碼
代碼如下:
<?php
$file_name
=
urlencode($_REQUEST['filename']);
header("Pragma:
public");
header("Expires:
0");
header("Cache-Control:
must-revalidate,
post-check=0,
pre-check=0");
header("Content-Type:
application/force-download");
header('Content-Type:
application/vnd.ms-excel;
charset=utf-8');
header("Content-Transfer-Encoding:
binary");
header('Content-Disposition:
attachment;
filename='.$file_name);
echo
stripslashes($_REQUEST['content']);
?>
解決PHP
Header下載文件在IE文件名中文亂碼有兩種常見的,一種是是把頁面編碼改成utf8,另一種是對中文url進入urlencode編碼就可以解決了。
解決方案一(我的頁面是utf-8編碼):
復制代碼
代碼如下:
$filename
=
"中文.txt";
$ua
=
$_SERVER["HTTP_USER_AGENT"];
$encoded_filename
=
urlencode($filename);
$encoded_filename
=
str_replace("+",
"%20",
$encoded_filename);
header('Content-Type:
application/octet-stream');
if
(preg_match("/MSIE/",
$ua))
{
header('Content-Disposition:
attachment;
filename="'
.
$encoded_filename
.
'"');
}
else
if
(preg_match("/Firefox/",
$ua))
{
header('Content-Disposition:
attachment;
filename*="utf8'''
.
$filename
.
'"');
}
else
{
header('Content-Disposition:
attachment;
filename="'
.
$filename
.
'"');
}
解決方法二
將文件名先urlencode一下再放入header,如下。
代碼如下:
復制代碼
代碼如下:
<?php
$file_name
=
urlencode($_REQUEST['filename']);
header("Pragma:
public");
header("Expires:
0");
header("Cache-Control:
must-revalidate,
post-check=0,
pre-check=0");
header("Content-Type:
application/force-download");
header('Content-Type:
application/vnd.ms-excel;
charset=utf-8');
header("Content-Transfer-Encoding:
binary");
header('Content-Disposition:
attachment;
filename='.$file_name);
echo
stripslashes($_REQUEST['content']);
?>

5. php+mysql鏁版嵁搴撲腑鏂囪繛鎺ヤ貢鐮侊紵set names utf8 涔熶笉琛岋紒

MySQL浼氬嚭鐜頒腑鏂囦貢鐮佺殑鍘熷洜涓嶅栦箮涓嬪垪鍑犵偣錛
1.server鏈韜璁懼畾闂棰橈紝瀹夎呮椂浣跨敤鐨勫瓧絎﹂泦鏄痩atin1
2.table鐨勮緋昏懼畾闂棰(鍖呭惈character涓巆ollation)
3.瀹㈡埛絝紼嬪紡(渚嬪俻hp)鐨勮繛綰胯緋昏懼畾闂棰
姝e傛偍璁懼畾鐨勪竴鏍鳳紝寤鴻浣跨敤UTF8錛屽彲鍏煎逛竴鍒囧瓧絎︺備互涓嬩負瑙e喅鍔炴硶錛
涓銆侀伩鍏嶅壋寤烘暟鎹搴撳強琛ㄥ嚭鐜頒腑鏂囦貢鐮佸拰鏌ョ湅緙栫爜鏂規硶
1銆佸壋寤烘暟鎹搴撶殑鏃跺欙細CREATE DATABASE `test`
CHARACTER SET 'utf8'
COLLATE 'utf8_general_ci';
2銆佸緩琛ㄧ殑鏃跺 CREATE TABLE `database_user` (
`ID` varchar(40) NOT NULL default '',
`UserID` varchar(40) NOT NULL default '',
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
鍗沖緩搴撳拰寤鴻〃鏃墮兘浣跨敤鐩稿悓鐨勭紪鐮佹牸寮忋
浣嗘槸濡傛灉浣犲凡緇忓緩浜嗗簱鍜岃〃鍙浠ラ氳繃浠ヤ笅鏂瑰紡榪涜屾煡璇銆

鎵ц孲ET NAMES utf8鐨勬晥鏋滅瓑鍚屼簬鍚屾椂璁懼畾濡備笅錛
SET character_set_client='utf8';
SET character_set_connection='utf8';
SET character_set_results='utf8';
浜屻侀伩鍏嶅煎叆鏁版嵁鏈変腑鏂囦貢鐮佺殑闂棰
1:灝嗘暟鎹緙栫爜鏍煎紡淇濆瓨涓簎tf-8
璁劇疆榛樿ょ紪鐮佷負utf8錛歴et names utf8;
璁劇疆鏁版嵁搴揹b_name榛樿や負utf8:
ALTER DATABASE `db_name` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
璁劇疆琛╰b_name榛樿ょ紪鐮佷負utf8:
ALTER TABLE `tb_name` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
瀵煎叆錛歀OAD DATA LOCAL INFILE 'C:\\utf8.txt' INTO TABLE yjdb;
2:灝嗘暟鎹緙栫爜鏍煎紡淇濆瓨涓篴nsi(鍗矴BK鎴朑B2312)
璁劇疆榛樿ょ紪鐮佷負gbk錛歴et names gbk;
璁劇疆鏁版嵁搴揹b_name榛樿ょ紪鐮佷負gbk:
ALTER DATABASE `db_name` DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;
璁劇疆琛╰b_name榛樿ょ紪鐮佷負gbk:
ALTER TABLE `tb_name` DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;
瀵煎叆錛歀OAD DATA LOCAL INFILE 'C:\\gbk.txt' INTO TABLE yjdb;
娉錛1.UTF8涓嶈佸煎叆gbk錛実bk涓嶈佸煎叆UTF8;
2.dos涓嬩笉鏀鎸乁TF8鐨勬樉紺;
涓夈佽В鍐崇綉欏典腑涔辯爜鐨勯棶棰
灝嗙綉絝欑紪鐮佽句負 utf-8,榪欐牱鍙浠ュ吋瀹逛笘鐣屼笂鎵鏈夊瓧絎︺傚傛灉緗戠珯宸茬粡榪愪綔浜嗗ソ涔,宸叉湁寰堝氭棫鏁版嵁,涓嶈兘鍐嶆洿鏀圭畝浣撲腑鏂囩殑璁懼畾,閭d箞寤鴻灝嗛〉闈㈢殑緙栫爜璁句負 GBK, GBK涓嶨B2312鐨勫尯鍒灝卞湪浜:GBK鑳芥瘮GB2312鏄劇ず鏇村氱殑瀛楃,瑕佹樉紺虹畝浣撶爜鐨勭箒浣撳瓧,灝卞彧鑳界敤GBK銆
1.緙栬緫/etc/my.cnf銆,鍦╗mysql]孌靛姞鍏default_character_set=utf8;
2.鍦ㄧ紪鍐機onnection URL鏃訛紝鍔犱笂?useUnicode=true&characterEncoding=utf-8鍙;
3.鍦ㄧ綉欏典唬鐮佷腑鍔犱笂涓涓"set names utf8"鎴栬"set names gbk"鐨勬寚浠わ紝鍛婅瘔MySQL榪炵嚎鍐呭歸兘瑕佷嬌鐢╱tf8鎴栬単bk銆
甯屾湜瀵逛綘鏈夋墍甯鍔┿

6. 鎬庢牱瑙e喅PHP涓鏂囦貢鐮侀棶棰

涔辯爜鎸囩殑鏄璁$畻鏈虹郴緇熶笉鑳芥樉紺烘g『鐨勫瓧絎︼紝鑰屾樉紺哄叾浠栨棤鎰忎箟鐨勫瓧絎︽垨絀虹櫧錛屽備竴鍫咥SCII Code銆傛墍鏄劇ず鍑烘潵鐨勬枃瀛楃粺縐頒負涔辯爜銆備貢鐮佹槸鍥犱負鎵浣跨敤鐨勫瓧絎︾殑婧愮爜鍦ㄦ湰鍦拌$畻鏈轟笂浣跨敤浜嗛敊璇鐨勬樉紺哄瓧搴擄紝鎴栧湪鏈鍦拌$畻鏈虹殑瀛楀簱涓鎵句笉鍒扮浉搴斾簬婧愮爜鎵鎸囦唬鐨勫瓧絎︽墍鑷淬
閫氫織鐐硅詫細
涔辯爜灝辨槸浣犳墦寮鐜嬮〉鎴栭偖綆憋紝閲岄潰鐨勫瓧涓嶆槸鍏ㄤ腑鏂囩殑錛岃屾槸涓浜涗貢涓冨叓緋熻帿鍚嶅叾濡欑殑鏃犳剰涔夌殑瀛楃︾粍鍚堝湪涓璧楓備富瑕佹槸璁$畻鏈虹殑瀛楀簱鍑洪敊鎵鑷淬
1涓鑸鍑虹幇鍦ㄧ綉欏碉紝鐢ㄧ綉欏典笂闈㈢殑鏌ョ湅鈥斺旂紪鐮佲斺旂畝浣撲腑鏂囧嵆鍙瑙e喅銆
2 鍑虹幇涔辯爜涓鑸鏄疻indows緋葷粺瀛楀簱鐨勯棶棰橈紝鍙鑳芥槸緋葷粺閿欒鎴栦笉姝e父鍏蟲満閫犳垚鐨勶紝涔熷彲鑳芥槸鏌愪簺杞浠墮渶瑕佷嬌鐢ㄦ搷浣滅郴緇熶互澶栫殑瀛楀簱閫犳垚鐨勩傝В鍐沖姙娉曞緱鐪嬪叿浣撶殑闂棰橈紝涓鑸鎯呭喌涓嬬殑Windows涔辯爜鍙浠ラ氳繃浠ヤ笅涓夌嶆柟娉曡В鍐熾

絎涓縐嶆柟娉曟槸涓嬭澆 瑙e喅Windows XP SP2涔辯爜琛ヤ竵 V1.00 (鍗庡啗杞浠跺洯)

絎浜岀嶆槸瑙e喅Windows緋葷粺閿欒閫犳垚鐨勪貢鐮侀棶棰橈紝閲嶅惎鍚庣敤F8閿嬋媧葷郴緇熻彍鍗曪紝榪涘叆瀹夊叏妯″紡銆傜瓑緋葷粺媯鏌ュ畬姣曪紝紜鐩樻病鏈夊搷搴斿悗鍐嶉噸鏂版e父閫鍑哄苟閲嶆柊鍚鍔ㄨ$畻鏈猴紝姝e父榪涘叆Windows錛屽瓧浣撲竴鑸灝辮兘鑷鍔ㄦ仮澶嶃傝繖鏄鍥犱負Windows鍦ㄨ繘鍏ュ畨鍏ㄦā寮忔椂浼氶噸鏂扮儲寮曞瓧搴撳強鏁寸悊鑿滃崟銆

絎涓夌嶈В鍐蟲柟娉曠敤浜庝慨姝h蔣浠墮犳垚鐨勬敞鍐岃〃涓鍏充簬瀛椾綋閮ㄥ垎璁劇疆鍑洪敊鐨勯棶棰樸傝繍琛屸淩egedit鈥濆惎鍔ㄦ敞鍐岃〃緙栬緫鍣ㄣ傚湪鈥淗KEY_LOCAL_MACHINE\System\CurrentControlSet\Control\fontassoc鈥濋敭涓嬫湁 鈥淎ssociated CharSet鈥濆拰鈥淎ssociated DefaultFonts鈥 涓や釜閿銆傚綋鍑虹幇奼夊瓧涔辯爜鏃訛紝榪欎袱涓閿涓鐨勫唴瀹瑰氨鍙鑳戒笉姝g『鐢氳嚦涓嶅畬鏁淬傚畠浠鐨勬g『鍐呭瑰簲璇ユ槸鈥淎ssociated CharSet鈥濆唴鏈夆滐紙榛樿わ級銆丄NSI錛00錛夈丟B2312錛86錛夈丱EM錛團F錛夈丼YMBOL錛02錛夆濆嚑欏逛覆鍊礆紝閿鍊煎垎鍒涓衡滐紙鏈璁劇疆閿鍊礆級銆乊es銆乊es銆乊es銆丯o鈥濓紝鑰屸淎ssociated DefaultFonts鈥濆唴鏈夆滐紙榛樿わ級銆丄ssocSystemFont銆丗ontPackegeDecorative銆丗ontPackegeDontCare銆丗ontPackegeModern銆丗ontPackegeRoman銆丗ontPackegeScript銆丗ontPackegeSwiss鈥濆嚑欏逛覆鍊礆紝閿鍊煎垎鍒涓衡滐紙鏈璁劇疆閿鍊礆級銆乻imsun.ttf銆佸畫浣撱佸畫浣撱佸畫浣撱佸畫浣撱佸畫浣撱佸畫浣撯濄傞噸鏂板惎鍔ㄧ郴緇熷悗奼夊瓧灝卞簲璇ユ樉紺烘g『浜嗐傚緩璁鎮ㄥ湪淇鏀瑰墠鍏堝囦喚娉ㄥ唽琛錛屼互闃蹭慨鏀歸敊璇浣跨郴緇熷嚭鐜伴棶棰樸

熱點內容
中國移動用什麼服務密碼 發布:2024-05-20 00:52:10 瀏覽:695
make編譯輸出 發布:2024-05-20 00:37:01 瀏覽:67
4200存儲伺服器 發布:2024-05-20 00:20:35 瀏覽:160
解壓小生活 發布:2024-05-20 00:15:03 瀏覽:143
粘土小游戲伺服器ip 發布:2024-05-20 00:14:00 瀏覽:196
魔獸世界如何快速增加伺服器 發布:2024-05-19 23:53:37 瀏覽:694
安卓手機如何轉入蘋果手機內 發布:2024-05-19 23:50:35 瀏覽:405
安卓哪個能安裝血染小鎮 發布:2024-05-19 23:45:57 瀏覽:901
tensorflowmac編譯 發布:2024-05-19 23:28:59 瀏覽:702
sqlmaxvarchar 發布:2024-05-19 23:24:02 瀏覽:703