前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Error:(1, 1) java: 非法字符: '\ufeff'

Error:(1, 1) java: 非法字符: '\ufeff'

作者头像
用户2146693
发布2019-08-08 11:45:43
3.8K0
发布2019-08-08 11:45:43
举报
文章被收录于专栏:架构师进阶架构师进阶

utf-8+bom比utf-8多了三个字节前缀:0xEF0xBB0xBF,有这三个字节前缀的文本或字符串,程序可以自动判断它为utf-8格式,并按照utf-8格式来解析文本或字符串。

前言

开发过程中,在启动Spring Boot的时候,遇到这样的问题:

Error:(1, 1) java: 非法字符: '\ufeff'

运行mvn compile也是报同样的错误。感觉好奇怪啊,仔细看看对应的行没啥问题啊。我用的工具是IntelliJ IDEA 2016.3(64),同样的代码在Eclipse中是没问题的,Spring Boot正常启动。

问题

在启动服务的时候报错

这里写图片描述
这里写图片描述

解决方案

下载个文本工具,我用的是Notepad++.打开刚刚出问题的文件看右下角:

这里写图片描述
这里写图片描述

提示当前编码格式是UTF-8-BOM。菜单栏中也可以看。

这里写图片描述
这里写图片描述

把当前的内容全部剪切,在菜单栏切换编码格式。

这里写图片描述
这里写图片描述

格式切换完后,把内容粘贴一下就OK。

这里写图片描述
这里写图片描述

扩展

UTF-8 不需要 BOM,尽管 Unicode 标准允许在 UTF-8 中使用 BOM。 所以不含 BOM 的 UTF-8 才是标准形式,在 UTF-8 文件中放置 BOM 主要是微软的习惯(顺便提一下:把带有 BOM 的小端序 UTF-16 称作「Unicode」而又不详细说明,这也是微软的习惯)。 BOM(byte order mark)是为 UTF-16 和 UTF-32 准备的,用于标记字节序(byte order)。微软在 UTF-8 中使用 BOM 是因为这样可以把 UTF-8 和 ASCII 等编码明确区分开,但这样的文件在 Windows 之外的操作系统里会带来问题。

参考

UTF8最好不要带BOM,附许多经典评论

「带 BOM 的 UTF-8」和「无 BOM 的 UTF-8」有什么区别?网页代码一般使用哪个?

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 问题
  • 解决方案
  • 扩展
  • 参考
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档