Add ViewResolver docs
This commit is contained in:
parent
3bc37ddde0
commit
b56bd0a10c
|
@ -519,6 +519,66 @@ For more detail look at the
|
||||||
[`ManagementServerProperties`](https://github.com/spring-projects/spring-boot/blob/master/spring-boot-actuator/src/main/java/org/springframework/boot/actuate/properties/ManagementServerProperties.java?source=c)
|
[`ManagementServerProperties`](https://github.com/spring-projects/spring-boot/blob/master/spring-boot-actuator/src/main/java/org/springframework/boot/actuate/properties/ManagementServerProperties.java?source=c)
|
||||||
source code.
|
source code.
|
||||||
|
|
||||||
|
## Customize ViewResolvers
|
||||||
|
|
||||||
|
A `ViewResolver` is a core components of Spring MVC, translating view
|
||||||
|
names in `@Controllers` to actual `View` implementations. Note that
|
||||||
|
`ViewResolvers` are mainly used in UI applications, rather than
|
||||||
|
REST-style services (a `View` is not used to render a
|
||||||
|
`@ResponseBody`). There are many implementations of `ViewResolver` to
|
||||||
|
choose from, and Spring on its own is not opinionated about which ones
|
||||||
|
you should use. Spring Boot, on the other hand, installs one or two
|
||||||
|
for you depending on what it finds on the classpath and in the
|
||||||
|
application context. The `DispatcherServlet` uses all the resolvers it
|
||||||
|
finds in the application context, trying each one in turn until it
|
||||||
|
gets a result, so if you are adding your own you have to be aware of
|
||||||
|
the order and in which position your resolver is added.
|
||||||
|
|
||||||
|
`WebMvcAutoConfiguration` adds the following `ViewResolvers` to your
|
||||||
|
context:
|
||||||
|
|
||||||
|
* An `InternalResourceViewResolver` with bean id
|
||||||
|
"defaultViewResolver". This one locates physical resources that can be
|
||||||
|
rendered using the `DefaultServlet` (e.g. static resources and JSP
|
||||||
|
pages if you are using those). It applies a prefix and a suffix to the
|
||||||
|
view name and then looks for a physical resource with that path in the
|
||||||
|
servlet context (defaults are both empty, but accessible for external
|
||||||
|
configuration via `spring.view.prefix` and `spring.view.suffix`). It
|
||||||
|
can be overridden by providing a bean of the same type.
|
||||||
|
|
||||||
|
* A `BeanNameViewResolver` with id "beanNameViewResolver". This is a
|
||||||
|
useful member of the view resolver chain and will pick up any beans
|
||||||
|
with the same name as the `View` being resolved. It can be overridden
|
||||||
|
by providing a bean of the same type, but it's unlikely you will need
|
||||||
|
to do that.
|
||||||
|
|
||||||
|
* A `ContentNegotiatingViewResolver` with id "viewResolver" is only
|
||||||
|
added if there *are* actually beans of type `View` present. This is a
|
||||||
|
"master" resolver, delegating to all the others and attempting to find
|
||||||
|
a match to the "Accept" HTTP header sent by the client. There is a
|
||||||
|
useful
|
||||||
|
[blog about `ContentNegotiatingViewResolver`](https://spring.io/blog/2013/06/03/content-negotiation-using-views)
|
||||||
|
that you might like to study to learn more, and also look at the
|
||||||
|
source code for detail.
|
||||||
|
|
||||||
|
Be careful not to define your own `ViewResolver` with id
|
||||||
|
"viewResolver" (like the `ContentNegotiatingViewResolver`) otherwise,
|
||||||
|
in that case, your bean will be ovewritten, not the other way round.
|
||||||
|
|
||||||
|
* If you use Thymeleaf you will also have a `ThymeleafViewResolver`
|
||||||
|
with id "thymeleafViewResolver". It looks for resources by surrounding
|
||||||
|
the view name with a prefix and suffix (externalized to
|
||||||
|
`spring.thymeleaf.prefix` and `spring.thymeleaf.suffix`, defaults
|
||||||
|
"classpath:/templates/" and ".html" respectively). It can be
|
||||||
|
overridden by providing a bean of the same name.
|
||||||
|
|
||||||
|
Checkout
|
||||||
|
[`WebMvcAutoConfiguration`](https://github.com/spring-projects/spring-boot/blob/master/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/web/WebMvcAutoConfiguration.java?source=c)
|
||||||
|
and
|
||||||
|
[`ThymeleafAutoConfiguration`](https://github.com/spring-projects/spring-boot/blob/master/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/thymeleaf/ThymeleafAutoConfiguration.java?source=c)
|
||||||
|
source code for more detail.
|
||||||
|
|
||||||
|
|
||||||
## Customize "Whitelabel" Error Page
|
## Customize "Whitelabel" Error Page
|
||||||
|
|
||||||
The Actuator installs a "whitelabel" error page that you will see in
|
The Actuator installs a "whitelabel" error page that you will see in
|
||||||
|
|
|
@ -20,6 +20,7 @@ import java.util.Collections;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
|
import org.junit.Ignore;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.springframework.beans.factory.BeanCreationException;
|
import org.springframework.beans.factory.BeanCreationException;
|
||||||
import org.springframework.boot.autoconfigure.PropertyPlaceholderAutoConfiguration;
|
import org.springframework.boot.autoconfigure.PropertyPlaceholderAutoConfiguration;
|
||||||
|
@ -93,6 +94,16 @@ public class ThymeleafAutoConfigurationTests {
|
||||||
this.context.refresh();
|
this.context.refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Ignore("Fix this for gh-424")
|
||||||
|
public void templateLocationEmpty() throws Exception {
|
||||||
|
EnvironmentTestUtils.addEnvironment(this.context,
|
||||||
|
"spring.thymeleaf.prefix:classpath:/templates/empty-directory/");
|
||||||
|
this.context.register(ThymeleafAutoConfiguration.class,
|
||||||
|
PropertyPlaceholderAutoConfiguration.class);
|
||||||
|
this.context.refresh();
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void createLayoutFromConfigClass() throws Exception {
|
public void createLayoutFromConfigClass() throws Exception {
|
||||||
AnnotationConfigWebApplicationContext context = new AnnotationConfigWebApplicationContext();
|
AnnotationConfigWebApplicationContext context = new AnnotationConfigWebApplicationContext();
|
||||||
|
|
|
@ -1,13 +0,0 @@
|
||||||
<?xml version="1.0" encoding="ISO-8859-1" ?>
|
|
||||||
<!DOCTYPE tiles-definitions PUBLIC
|
|
||||||
"-//Apache Software Foundation//DTD Tiles Configuration 2.1//EN"
|
|
||||||
"http://tiles.apache.org/dtds/tiles-config_2_1.dtd">
|
|
||||||
<tiles-definitions>
|
|
||||||
<definition name="*" template="layout">
|
|
||||||
<put-attribute name="content" value="content/{1}" />
|
|
||||||
<put-attribute name="title" value="title/{1}" />
|
|
||||||
</definition>
|
|
||||||
|
|
||||||
<definition name="content/*" template="{1} :: content" />
|
|
||||||
<definition name="title/*" template="{1} :: title" />
|
|
||||||
</tiles-definitions>
|
|
Loading…
Reference in New Issue