PHP读取文件,解决中文乱码UTF-8的方法分析
发布:smiling 来源: PHP粉丝网 添加日期:2022-02-06 09:48:13 浏览: 评论:0
本文实例讲述了PHP读取文件,解决中文乱码UTF-8的方法,分享给大家供大家参考,具体如下:
- $opts = array(
- 'file' => array(
- 'encoding' => "utf-8"
- )
- );
- $opts = array('http' => array('encoding' => 'utf-8'));
- $ctxt = stream_context_create($opts);
- $content = file_get_contents($filePath, FILE_TEXT, $ctxt);
最简单的就是将GF2312→UTF-8
$str = iconv("gb2312", "utf-8", $str);
不管用的
$content = mb_convert_encoding($content, "UTF-8", "auto");
******************************************丑陋的分割线来告诉大家上面的不好的:下面的才是正确的方法···哈哈···**********************************************************
- define('UTF32_BIG_ENDIAN_BOM', chr(0x00) . chr(0x00) . chr(0xFE) . chr(0xFF));
- define('UTF32_LITTLE_ENDIAN_BOM', chr(0xFF) . chr(0xFE) . chr(0x00) . chr(0x00));
- define('UTF16_BIG_ENDIAN_BOM', chr(0xFE) . chr(0xFF));
- define('UTF16_LITTLE_ENDIAN_BOM', chr(0xFF) . chr(0xFE));
- define('UTF8_BOM', chr(0xEF) . chr(0xBB) . chr(0xBF));
- $text = file_get_contents($newPath);
- $first2 = substr($text, 0, 2);
- $first3 = substr($text, 0, 3);
- $first4 = substr($text, 0, 3);
- $encodType = "";
- if ($first3 == UTF8_BOM)
- $encodType = 'UTF-8 BOM';
- else if ($first4 == UTF32_BIG_ENDIAN_BOM)
- $encodType = 'UTF-32BE';
- else if ($first4 == UTF32_LITTLE_ENDIAN_BOM)
- $encodType = 'UTF-32LE';
- else if ($first2 == UTF16_BIG_ENDIAN_BOM)
- $encodType = 'UTF-16BE';
- else if ($first2 == UTF16_LITTLE_ENDIAN_BOM)
- $encodType = 'UTF-16LE';
- $content = file_get_contents($newPath);
- $content = iconv($encodType, "utf-8", $content);
终极版·····
- $text = file_get_contents($filePath);
- //$encodType = mb_detect_encoding($text);
- define('UTF32_BIG_ENDIAN_BOM', chr(0x00) . chr(0x00) . chr(0xFE) . chr(0xFF));
- define('UTF32_LITTLE_ENDIAN_BOM', chr(0xFF) . chr(0xFE) . chr(0x00) . chr(0x00));
- define('UTF16_BIG_ENDIAN_BOM', chr(0xFE) . chr(0xFF));
- define('UTF16_LITTLE_ENDIAN_BOM', chr(0xFF) . chr(0xFE));
- define('UTF8_BOM', chr(0xEF) . chr(0xBB) . chr(0xBF));
- $first2 = substr($text, 0, 2);
- $first3 = substr($text, 0, 3);
- $first4 = substr($text, 0, 3);
- $encodType = "";
- if ($first3 == UTF8_BOM)
- $encodType = 'UTF-8 BOM';
- else if ($first4 == UTF32_BIG_ENDIAN_BOM)
- $encodType = 'UTF-32BE';
- else if ($first4 == UTF32_LITTLE_ENDIAN_BOM)
- $encodType = 'UTF-32LE';
- else if ($first2 == UTF16_BIG_ENDIAN_BOM)
- $encodType = 'UTF-16BE';
- else if ($first2 == UTF16_LITTLE_ENDIAN_BOM)
- $encodType = 'UTF-16LE';
- //下面的判断主要还是判断ANSI编码的·
- if ($encodType == '') {//即默认创建的txt文本-ANSI编码的
- $content = iconv("GBK", "UTF-8", $text);
- } else if ($encodType == 'UTF-8 BOM') {//本来就是UTF-8不用转换
- $content = $text;
- } else {//其他的格式都转化为UTF-8就可以了
- $content = iconv($encodType, "UTF-8", $text);
- }
以上的终极版·可以适应中文操作windows系统建立的ANSI``````````````UTF-8`````````Unicode`````的txt文本。
Tags: PHP读取文件 PHP中文乱码
- 上一篇:php经典趣味算法实例代码
- 下一篇:最后一页
相关文章
- ·PHP几个快速读取大文件例子(2015-04-04)
- ·在php中中文乱码解决方法(2013-11-29)
- ·PHP读MYSQL中文乱码的解决方法(2014-09-11)
- ·php中文乱码问题和MySql出现中文乱码的解决方法(2014-09-11)
- ·PHP Header下载文件在IE文件名中文乱码问题(2014-09-13)
- ·php ord 函数与中文乱码解决方法(2014-09-19)
- ·php生成二维码中文乱码问题解决方法(2014-09-20)
- ·php中文乱码问题解决方法(2014-09-21)
- ·PHP中文文件名输出乱码解决方法(2014-09-21)
- ·解决PHP中文乱码的4项小技巧(2015-04-04)
- ·PHP DOMDocument保存xml时中文出现乱码(2015-04-08)
- ·php中文乱码怎么办如何让浏览器自动识别utf-8(2020-08-27)
- ·解决php接收shell返回的结果中文乱码问题(2020-08-29)
- ·PHP中使用file_get_contents抓取网页中文乱码问题解决方法(2021-05-03)
- ·php生成二维码时出现中文乱码的解决方法(2021-05-03)
- ·PHP中文乱码解决方案(2021-05-15)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)