2017-08-01 82 views
0

我想用下面的命令來啓動春季啓動超級罐子:春季啓動Windows 10系統屬性「file.encoding的」

java -jar api-0.0.1.jar -Dfile.encoding=UTF-8 

,但它失敗了以下錯誤:

07:52:54.573 [main] INFO com.example.domain.api.Application - Starting application... 
2017-08-01 07:52:55.071 ERROR 5792 --- [   main] o.s.b.c.FileEncodingApplicationListener : System property 'file.encoding' is currently ' 
Cp1251'. It should be 'UTF-8' (as defined in 'spring.mandatoryFileEncoding'). 
2017-08-01 07:52:55.074 ERROR 5792 --- [   main] o.s.b.c.FileEncodingApplicationListener : Environment variable LANG is 'null'. You could 
use a locale setting that matches encoding='UTF-8'. 
2017-08-01 07:52:55.075 ERROR 5792 --- [   main] o.s.b.c.FileEncodingApplicationListener : Environment variable LC_ALL is 'null'. You cou 
ld use a locale setting that matches encoding='UTF-8'. 
2017-08-01 07:52:55.082 ERROR 5792 --- [   main] o.s.boot.SpringApplication    : Application startup failed 

java.lang.IllegalStateException: The Java Virtual Machine has not been configured to use the desired default character encoding (UTF-8). 
     at org.springframework.boot.context.FileEncodingApplicationListener.onApplicationEvent(FileEncodingApplicationListener.java:74) ~[spring-b 
oot-1.5.6.RELEASE.jar!/:1.5.6.RELEASE] 
     at org.springframework.boot.context.FileEncodingApplicationListener.onApplicationEvent(FileEncodingApplicationListener.java:46) ~[spring-b 
oot-1.5.6.RELEASE.jar!/:1.5.6.RELEASE] 
     at org.springframework.context.event.SimpleApplicationEventMulticaster.invokeListener(SimpleApplicationEventMulticaster.java:167) ~[spring 
-context-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] 
     at org.springframework.context.event.SimpleApplicationEventMulticaster.multicastEvent(SimpleApplicationEventMulticaster.java:139) ~[spring 
-context-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] 
     at org.springframework.context.event.SimpleApplicationEventMulticaster.multicastEvent(SimpleApplicationEventMulticaster.java:122) ~[spring 
-context-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] 
     at org.springframework.boot.context.event.EventPublishingRunListener.environmentPrepared(EventPublishingRunListener.java:74) ~[spring-boot 
-1.5.6.RELEASE.jar!/:1.5.6.RELEASE] 
     at org.springframework.boot.SpringApplicationRunListeners.environmentPrepared(SpringApplicationRunListeners.java:54) ~[spring-boot-1.5.6.R 
ELEASE.jar!/:1.5.6.RELEASE] 
     at org.springframework.boot.SpringApplication.prepareEnvironment(SpringApplication.java:325) [spring-boot-1.5.6.RELEASE.jar!/:1.5.6.RELEAS 
E] 
     at org.springframework.boot.SpringApplication.run(SpringApplication.java:296) [spring-boot-1.5.6.RELEASE.jar!/:1.5.6.RELEASE] 
     at org.springframework.boot.SpringApplication.run(SpringApplication.java:1118) [spring-boot-1.5.6.RELEASE.jar!/:1.5.6.RELEASE] 
     at org.springframework.boot.SpringApplication.run(SpringApplication.java:1107) [spring-boot-1.5.6.RELEASE.jar!/:1.5.6.RELEASE] 
     at com.example.domain.api.Application.main(Application.java:36) [classes!/:0.0.1] 
     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_121] 
     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_121] 
     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_121] 
     at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_121] 
     at org.springframework.boot.loader.MainMethodRunner.run(MainMethodRunner.java:48) [api-0.0.1.jar:0.0.1] 
     at org.springframework.boot.loader.Launcher.launch(Launcher.java:87) [api-0.0.1.jar:0.0.1] 
     at org.springframework.boot.loader.Launcher.launch(Launcher.java:50) [api-0.0.1.jar:0.0.1] 
     at org.springframework.boot.loader.JarLauncher.main(JarLauncher.java:51) [api-0.0.1.jar:0.0.1] 

而且,我在我的Maven的pom.xml以下屬性:

<properties> 
    <java.source.version>1.8</java.source.version> 
    <java.target.version>1.8</java.target.version> 
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> 
    <file.encoding>UTF-8</file.encoding> 
</properties> 

我在做什麼錯誤以及如何正確地推出THI應用程序?

回答

1

Java SE 6支持的兩種編碼集。新java.nio API使用的規範名在很多情況下與java.io和java.lang API中使用的不同。

  • ,如果你是java.nio中的API使用規範名稱,你需要使用:UTF-8
  • ,如果你是java.io和的java.lang API使用規範名稱,您需要使用: UTF8

所以使用-Dfile.encoding=UTF-8-Dfile.encoding=UTF8

+0

我嘗試了所有這些變體:'Java的罐子API-0.0.1.jar' 'Java的罐子API-0.0.1.jar -Dfile.encoding = UTF-8' 'java -jar api-0.0.1.jar -Dfile.encoding = UTF8' 不幸的是沒有人工作 – alexanoid

+1

我發現原因 - 應用程序參數的順序確實重要,現在它的工作原理:'java -Dfile.encoding = UTF-8 -jar api-0.0.1.war' – alexanoid