本文主要跟大家分享php編碼轉換亂碼如何解決,結合文字和程式碼,希望能幫助大家。
iconv詳解:
iconv — 字串依要求的字元編碼來轉換
# iconv有bug ,碰到一些生僻字就會無法轉換,當然了配置第二個參數時,可以稍微彌補一下預設缺陷,不至於無法轉換是截斷,用法如下
iconv(“UTF-8″, ”GB2312//IGNORE”,$data) ;
這樣碰到生僻字轉換失敗時,它就會忽略失敗,繼續轉換下面的內容。
iconvstring iconv ( string $in_charset , string $out_charset , string $str ) 第一个参数:内容原的编码 第二个参数:目标编码 第三个参数:要转的字符串 函数返回字符串<?php$instr = ‘测试’;// GBK转UTF-8$outstr = iconv(‘GBK’,'UTF-8′,$instr); ?>
傳回值
傳回轉換後的字串, 或是失敗時傳回 FALSE。
mb_convert_encoding詳解:
為了確保轉換的成功率,我們可以用另一個轉換函數
#mb_convert_encoding,這個函數效率不是很高,另外這個函數還可以省略第三個參數,自動辨識內容編碼,不過最好不要用,影響效率,還需要注意的時,mb_convert_encoding和iconv參數順序不一樣,一定要注意。
附兩個函數簡單的用法:
mb_convert_encoding string mb_convert_encoding ( string $str , string $to_encoding [, mixed $from_encoding ] ) 第一个参数:要处理的字符串 第二个参数:目标编码 第三个参数:内容原编码,它可以是一个 array 也可以是逗号分隔的枚举列表<?php$instr = '测试'; // GBK转UTF-8$outstr = mb_convert_encoding($instr,'UTF-8','GBK',); $str = mb_convert_encoding($instr, "UCS-2LE", "JIS, eucjp-win, sjis-win");?>
#個人建議碰到轉碼問題時採用mb_convert_encoding比較保險。
mb_convert_variables
#mb_convert_variables — 轉換一個或多個變數的字元編碼
mb_convert_variables ( $to_encoding , $from_encoding , &$vars [, mixed &$... ] )
將變數vars 的編碼從from_encoding 轉換成編碼to_encoding。
mb_convert_variables() 会拼接变量数组或对象中的字符串来检测编码,因为短字符串的检测往往会失败。因此,不能在一个数组或对象中混合使用编码。
to_encoding 将 string 转换成这个编码。 from_encoding 可以指定为一个 array 或者逗号分隔的 string,它将尝试根据 from-coding 来检测编码。 当省略了 from_encoding,将使用 detect_order。 vars 是要转换的变量的引用。 参数可以接受 String、Array 和 Object 的类型。 mb_convert_variables() 假设所有的参数都具有同样的编码。 额外的 vars。
返回值 : 成功时返回转换前的字符编码,失败时返回 FALSE。
实例:<?php/* 转换变量 $post1、$post2 编码为内部(internal)编码 */$interenc = mb_internal_encoding();$inputenc = mb_convert_variables($interenc, "ASCII,UTF-8,SJIS-win", $post1, $post2);?>
mb_internal_encoding
mb_internal_encoding — 設定/取得內部字元編碼
mixed mb_internal_encoding ([ string $encoding = mb_internal_encoding() ] )
参数 : encoding 字符编码名称使用于 HTTP 输入字符编码转换、HTTP 输出字符编码转换、mbstring 模块系列函数字符编码转换的默认编码。 返回值 : 如果设置了 encoding,则成功时返回 TRUE, 或者在失败时返回 FALSE。 In this case, the character encoding for multibyte regex is NOT changed. 如果省略了 encoding,则返回当前的字符编码名称。
<?php/* 设置内部字符编码为 UTF-8 */mb_internal_encoding("UTF-8");/* 显示当前的内部字符编码*/echo mb_internal_encoding();?>
r mb_detect_encoding詳解:
#########mb_detect_encoding — ###偵測字元的編碼#######string mb_detect_encoding ( string $str [, mixed $encoding_list = mb_detect_order() [, bool $strict = false ]] )
1
检测字符串 str 的编码。
参数 str 待检查的字符串。 encoding_list 是一个字符编码列表。 编码顺序可以由数组或者逗号分隔的列表字符串指定。 如果省略了 encoding_list 将会使用 detect_order。strict strict 指定了是否严格地检测编码。 默认是 FALSE。 返回值 检测到的字符编码,或者无法检测指定字符串的编码时返回 FALSE。
字符串编码未知的情况下对字符串进行编码:
1、无论字符串编码是什么,均转换为gbk
function getSafeStr($str){ $s1 = iconv('utf-8','gbk//IGNORE',$str); $s0 = iconv('gbk','utf-8//IGNORE',$s1); if($s0 == $str){ return $s1; }else{ return $str; } }
2、无论字符串编码是什么,均转换为utf-8
function getSafeStr($str){ $s1 = iconv('gbk','utf-8//IGNORE',$str); $s0 = iconv('utf-8','gbk//IGNORE',$s1); if($s0 == $str){ return $s1; }else{ return $str; } }
获取字符串编码方法:
function getcode($str){ $s1 = iconv('utf-8','gbk//IGNORE',$str); $s0 = iconv('gbk','utf-8//IGNORE',$s1); if($s0 == $str){ return 'utf-8'; }else{ return 'gbk'; } }
以上是php編碼轉換亂碼如何解決的詳細內容。更多資訊請關注PHP中文網其他相關文章!