Web项目部署到服务器日志打印乱码

最近接到了一个老项目改造的需求,这是一个之前在eclipse开发的Web项目,看着确实有点生分,不过这都不是事。一个字,就是干。

问题复盘:

1。首先我从svn上把代码down下来了。需要先安装svn,然后配置在idea中。

 2.编辑项目,看能否成功启动,编译过程中,缺少jsp-api和servlet-api,于是我在classpath中添加了tomcat中的这两个jar。其实我们可以通过以下方式引入。指定jar包的依赖方式为provided已提供。

		<dependency>
			<groupId>javax.servlet</groupId>
			<artifactId>javax.servlet-api</artifactId>
			<version>4.0.1</version>
			<scope>provided</scope>
		</dependency>
		<dependency>
			<groupId>javax.servlet.jsp</groupId>
			<artifactId>jsp-api</artifactId>
			<version>2.2</version>
			<scope>provided</scope>
		</dependency>

maven的集中依赖范围汇总:

3.编译通过,可以开始开发了,开发完成后,我将web项目部署到了Linux tomcat中。在日志打印的过程中出现了乱码。因为同事打包的日志是正常了,我们使用的测试服务器环境是一致的,因此这应该是我们打的war包的区别。

字符乱码的本质是字符在编码解码使用的字符编码格式不一致。

4.通过测试比对我发现乱码通过utf-8和gbk两次编码可以正常显示,因此可以推测是项目编码可能有问题。于是我查看了我idea的项目编码,发现是gbk的格式,于是做了如下修改:

5.但是通过maven打包后部署到服务器上日志还是乱码,我清理了tomcat的缓存(删除work目录的catalina),还是乱码,有点崩溃。仔细发现了在mvn package过程中出现了警告:maven中如果不指定项目编码的话会使用平台默认的编码。此时项目的源文件会使用GBK编码,Linux使用UTF-8解码时会乱码。maven添加编码属性,打包后部署到服务器正常打印中文!

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
	</properties>

[WARNING] Using platform encoding (GBK actually) to copy filtered resources, i.e. build is platform dependent!

编码GBK的不可映射字符

如果这是一个Springboot项目,maven的编码格式默认指定为UTF-8。

//spring-boot-starter-parent pom文件中已指定编码格式。
<properties>
    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    <java.version>1.8</java.version>
    <resource.delimiter>@</resource.delimiter>
    <maven.compiler.source>${java.version}</maven.compiler.source>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.target>${java.version}</maven.compiler.target>
  </properties>

总结

1.首先开发工具设置好项目的编码格式,指定UTF-8。

2.maven中设置好项目的编码格式,指定UTF-8。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值