Browse Source

Use spring.velocity.charset for template encoding

Previously `spring.velocity.charset` only controlled the output encoding
with the templates being loaded with the default encoding. We now
consistently set the same value for both the input and output encodings.

It is still possible to override it to a different value using
`spring.velocity.properties.input.encoding`

Closes gh-3994
pull/4077/merge
Stephane Nicoll 10 years ago
parent
commit
19b5e59234
  1. 1
      spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/velocity/VelocityAutoConfiguration.java
  2. 7
      spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/velocity/VelocityAutoConfigurationTests.java
  3. 2
      spring-boot-docs/src/main/asciidoc/appendix-application-properties.adoc

1
spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/velocity/VelocityAutoConfiguration.java

@ -88,6 +88,7 @@ public class VelocityAutoConfiguration { @@ -88,6 +88,7 @@ public class VelocityAutoConfiguration {
factory.setResourceLoaderPath(this.properties.getResourceLoaderPath());
factory.setPreferFileSystemAccess(this.properties.isPreferFileSystemAccess());
Properties velocityProperties = new Properties();
velocityProperties.setProperty("input.encoding", this.properties.getCharsetName());
velocityProperties.putAll(this.properties.getProperties());
factory.setVelocityProperties(velocityProperties);
}

7
spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/velocity/VelocityAutoConfigurationTests.java

@ -113,6 +113,13 @@ public class VelocityAutoConfigurationTests { @@ -113,6 +113,13 @@ public class VelocityAutoConfigurationTests {
assertThat(response.getContentType(), equalTo("application/json;charset=UTF-8"));
}
@Test
public void customCharset() throws Exception {
registerAndRefreshContext("spring.velocity.charset:ISO-8859-1");
assertThat(this.context.getBean(VelocityConfigurer.class).getVelocityEngine()
.getProperty("input.encoding"), equalTo((Object) "ISO-8859-1"));
}
@Test
public void customPrefix() throws Exception {
registerAndRefreshContext("spring.velocity.prefix:prefix/");

2
spring-boot-docs/src/main/asciidoc/appendix-application-properties.adoc

@ -250,7 +250,7 @@ content into your application; rather pick only the properties that you need. @@ -250,7 +250,7 @@ content into your application; rather pick only the properties that you need.
spring.velocity.allow-session-override=false
spring.velocity.cache=true
spring.velocity.check-template-location=true
spring.velocity.charset=UTF-8
spring.velocity.charset=UTF-8 # charset for input and output encoding
spring.velocity.content-type=text/html
spring.velocity.date-tool-attribute=
spring.velocity.enabled=true # enable MVC view resolution

Loading…
Cancel
Save