一.
`string iconv ( string $in_charset , string $out_charset , string $str )`
— 将字符串 str 从 in_charset编码格式 转换到 out_charset编码格式
1.如果你在 参数out_charset 后添加了字符串 **//**TRANSLIT 表示:当一个字符不能被目标字符集所表示时,它可以通过一个或多个形似的字符来近似表达。 2.如果你添加了字符串 //IGNORE,不能以目标字符集表达的字符将被默默丢弃。 否则,str 从第一个无效字符开始截断并导致一个 E_NOTICE。
返回:返回转换后的字符串, 或者在失败时返回 FALSE
缺点:当遇到生僻字符时会被截断,所以需要设置第二个参数为//IGNORE 忽略不能被识别的字符
例如:在转换字符"—"到gb2312时会出错
echo iconv('GBK','gb2312',‘abc-cde’);
安装: 1.如果你使用了最新的 POSIX 兼容系统,则不需要安装其他程序,因为系统提供的 C 语言标准函数库肯定支持 iconv。否则,你必须在系统上安装 » libiconv 函数库 2.自 PHP 5.0.0 起,php配备了这个具有多种实用功能的扩展,来帮助您编写多语言脚本,默认已激活此扩展,默认已激活此扩展,但是它能够在编译时通过 --without-iconv 选项被禁用 选项指令 --with-iconv-dir 用于 PHP 编译时指定 iconv 在系统里的路径,否则会扫描默认路径。 3.PHP 4 用户的注意事项 要激活这个扩展必须在编译时使用 --with-iconv=[DIR] ,或者对于 Windows 用户,可以放置 iconv.dll 于系统 PATH 中,并在 php.ini 中激活 php_iconv.dll。
二 string mb_convert_encoding ( string $str , string $to_encoding [, mixed $from_encoding = mb_internal_encoding() ] ) --------将 string 类型 str 的字符编码从可选的 from_encoding 转换到 to_encoding。 如果没有提供 from_encoding,则会使用内部(internal)编码。
返回值:编码后的 string。
注意:1.使用上面的函数需要先安装先enable mbstring 扩展库,在 php.ini里将; extension=php_mbstring.dll 前面的 ; 去掉 2.mb_convert_encoding 可以指定多种输入编码,它会根据内容自动识别,但是执行效率比iconv差太多 3.发现iconv在转换字符”—”到gb2312时会出错,如果没有ignore参数,所有该字符后面的字符串都无法被保存。不管怎么样,这个”—”都无法转换成功,无法输出。 另外mb_convert_encoding没有这个bug. 4.一般情况下用 iconv,只有当遇到无法确定原编码是何种编码,或者iconv转化后无法正常显示时才用mb_convert_encoding 函数.
函数:
mixed iconv_get_encoding ([ string $type = "all" ] )
— 获取 iconv 扩展的内部配置变量 type 选项 type 的值可以是: all input_encoding output_encoding internal_encoding 返回值: 成功时返回当前内部配置变量的值, 或者在失败时返回 FALSE。 如果省略了 type,或者设置为 "all",iconv_get_encoding() 返回包含所有这些变量的数组。 Array ( [input_encoding] => ISO-8859-1 [output_encoding] => ISO-8859-1 [internal_encoding] => UTF-8 )