博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
关于 SAXParseException Content is not allowed in Prolog (前言中不允许有内容)
阅读量:5157 次
发布时间:2019-06-13

本文共 845 字,大约阅读时间需要 2 分钟。

解析 XML 文件的时候,如 Mybatis 的 Mapper 文件,有时会出现 org.xml.sax.SAXParseException 前言中不允许有内容 的异常,英文就是 Content is not allowed in Prolog 。导致这个问题通常是两个原因

  1. XML 文件开头出现了空白符或其它字符,比如 <?xml version="1.0" 这种开头有空格或者是 .<?xml version="1.0" 这种出现多余符号的。
  2. 文件编码为 UTF-8 with BOM,即带 BOM 头的 UTF-8 格式,很多时候都是这个原因。

如果是文件编码的问题,使用普通的 IDE 转一下格式就行,转成无 BOM 的。

关于 BOM

字节顺序标记(英语:byte-order mark,BOM)是位于码点U+FEFF的统一码字符的名称

不建议使用带 BOM 的 UTF-8 格式

UTF-8编码过的字节顺序标记则被用来标示它是UTF-8的文件。它只用来标示一个UTF-8的文件,而不用来说明字节顺序。许多视窗程序(包含记事本)会添加字节顺序标记到UTF-8文件。然而,在类Unix系统(大量使用文本文件,用于文件格式,用于进程间通信)中,这种作法则不被建议采用。因为它会妨碍到如解译器脚本开头的Shebang等的一些重要的码的正确处理。它亦会影响到无法识别它的编程语言。如gcc会报告源码档开头有无法识别的字符。而在PHP中,如果没有激活输出缓冲(output buffering),它会使得页面内容开始被送往浏览器(即:用户头文件已被提交),这使PHP脚本无法指定用户头文件(HTTP Header)。字节顺序标记在UTF-8中被表示为序列EF BB BF,对大部分未准备好处理UTF-8的文本编辑器及网页浏览器而言,在ISO-8859-1的环境中则会显示。

转载于:https://www.cnblogs.com/toSeeMyDream/p/9257090.html

你可能感兴趣的文章
暖暖的感动
查看>>
Java中的日期和时间
查看>>
Django基于admin的stark组件创建(一)
查看>>
批处理/DOS命令删除文件夹下某类型的文件
查看>>
模板 - 数学 - 矩阵快速幂
查看>>
优秀的持久层框架Mybatis,连接数据库快人一步
查看>>
PAT L2-016 愿天下有情人都是失散多年的兄妹
查看>>
抛弃IIS,利用FastCGI让Asp.net与Nginx在一起
查看>>
C. Tanya and Toys_模拟
查看>>
IIS7 如何设置读取、脚本和可执行文件的执行权限
查看>>
今日早上出来还是阴天
查看>>
听说本周五要进行一个小测试,公司对员工的考核
查看>>
查询删除的表的信息
查看>>
oracle 配置 ACL 使用数据库发送WebServic请求时需要
查看>>
每日冲刺报告——Day2(Java-Team)
查看>>
ffplay.exe操作方式
查看>>
TestNG
查看>>
[算法]复杂链表的复制
查看>>
【LeetCode】437. Path Sum III
查看>>
求最近点对算法分析 closest pair algorithm
查看>>