当前位置:首页 > PHP教程 > php应用 > 列表

php解析xml提示Invalid byte 1 of 1-byte UTF-8 sequence错误的处理方法

发布:smiling 来源: PHP粉丝网  添加日期:2020-07-02 15:43:27 浏览: 评论:0 

在利用php解析xml时提示Invalid byte 1 of 1-byte UTF-8 sequence错误了,这个问题我百度查实说是编码问题,结果我把编码处理一下果然KO了,下面我来分享一下解决办法

错误提示

Invalid byte 1 of 1-byte UTF-8 sequence

原因分析

在中文版的window下java的默认的编码为GBK,也就是所虽然我们标识了要将xml保存为utf-8格式但实际上文件是以GBK格式来保存的,所以这也就是为什么能够我们使用GBK、GB2312编码来生成xml文件能正确的被解析,而以UTF-8格式生成的文件不能被xml解析器所解析的原因。

把xml的encoding属性值UTF-8改为UTF8

org.xml.sax.SAXParseException: Content is not allowed in trailing section

把先要解析和字符串trim()一下即可解决问题。

解决:

1、最简单就是把<?xml version="1.0" encoding="UTF-8"?>改成<?xml version="1.0" encoding="gbk"?>

2、或者把xml打开另存的时候把字符集改为UTF-8后保存

或改程序,代码如下:

  1. SAXReader reader = new SAXReader();   
  2.   org.dom4j.Document document = reader.read("D:\ha.xml");   
  3.   OutputFormat of = new OutputFormat();   
  4.   of.setEncoding("UTF-8"); //改变编码方式   
  5. XMLWriter writer = new XMLWriter(new FileWriter "d:\dom4j.xml"), of);  

Tags: Invalid

分享到: