有的时候真心不喜欢这个世界!!!html
按照以前传统的方式来配置SpringMVC须要在web.xml中配置DispatcherServlet,可是在Servlet3规范和Spring3.1以后新增了一种方式,那就是java和注解的方式进行配置,今天咱们以Spring的最新版本5.2.1.RELEASE来进行一下配置,一块儿来看一下吧!前端
在Web MVC框架中,每一个DispatcherServlet都有本身的WebApplicationContext,它继承了在根WebApplicationContext中已经定义的全部bean。 根WebApplicationContext应该包含应在其余上下文和Servlet实例之间共享的全部基础结构Bean。 这些继承的bean能够在servlet特定的做用域中被覆盖,而且您能够在给定Servlet实例本地定义新的特定于做用域的bean。
复制代码
下面的配置来自域官方文档:java
取消web.xml改用java来配置首先须要有一个入口,下面展现了这个入口,即先建立一个初始化的类GolfingWebAppInitializer ,GolfingWebAppInitializer 类继承了一个名为AbstractAnnotationConfigDispatcherServletInitializer的抽象类,一样这个抽象类实现了org.springframework.web.WebApplicationInitializer接口。
复制代码
public class GolfingWebAppInitializer extends AbstractAnnotationConfigDispatcherServletInitializer {
@Override
protected Class<?>[] getRootConfigClasses() {
// GolfingAppConfig defines beans that would be in root-context.xml
return new Class[] { GolfingAppConfig.class };//Spring框架的核心配置文件
}
@Override
protected Class<?>[] getServletConfigClasses() {
// GolfingWebConfig defines beans that would be in golfing-servlet.xml
return new Class[] { GolfingWebConfig.class };//Spring MVC框架的核心配置文件
}
@Override
protected String[] getServletMappings() {
return new String[] { "/" };
}
}
复制代码
继承AbstractAnnotationConfigDispatcherServletInitializer
须要实现三个方法,其中getServletMappings()
会返回一个路径数组,将一个或多个路径映射到DispatcherServlet上,本例中它映射的是“/”,表示DispatcherServlet会处理全部的请求。web
getServletConfigClasses()
方法要返回一个带有@Configuration
注解的类,这个类将会用来定义DispatcherServlet应用上下文。spring
getRootConfigClasses()
方法要返回一个带有@Configuration
注解的类,这个类将会用来配置原来xml中ContextLoaderListener所建立的应用上下文。api
启动原理:数组
在Servlet3.0环境中容器会查找类路径下的实现了javax.servlet.ServletContainerInitializer
接口的类,找到了就会用它来配置Servlet容器。从这个接口的全限定名称上能够看出它是java标准api的一部分,是在Servlet 3.0之后才添加的。Spring为这个接口提供了一个实现类:bash
package org.springframework.web;
@HandlesTypes({WebApplicationInitializer.class})
public class SpringServletContainerInitializer implements ServletContainerInitializer {
public SpringServletContainerInitializer() {}
}
复制代码
这个实现类又会把配置任务交给WebApplicationInitializer接口的实现类来完成。咱们这里实现的抽象类AbstractAnnotationConfigDispatcherServletInitializer正是WebApplicationInitializer的一个实现类。而咱们的GolfingWebAppInitializer正是AbstractAnnotationConfigDispatcherServletInitializer的一个扩展,因此这样就把配置任务最终交给了咱们自定义的这个配置类GolfingWebAppInitializer。mvc
package com.os;
import com.os.config.SpringMvcConfigurer;
import org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer;
public class GolfingWebAppInitializer extends AbstractAnnotationConfigDispatcherServletInitializer {
@Override
protected Class<?>[] getRootConfigClasses() {
return new Class[0];
}
@Override
protected Class<?>[] getServletConfigClasses() {
return new Class[]{
SpringMvcConfigurer.class/*这个就是SpringMVC的核心配置文件,至关于以前配置果的xml*/
};
}
@Override
protected String[] getServletMappings() {
return new String[] { "/" };//映射的路径
}
}
复制代码
SpringMvcConfigurerapp
package com.os.config;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.ViewResolverRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import org.springframework.web.servlet.view.InternalResourceViewResolver;
@Configuration
@ComponentScan(basePackages = "com.os.**.web")
public class SpringMvcConfigurer implements WebMvcConfigurer {
@Override
public void configureViewResolvers(ViewResolverRegistry registry) {
InternalResourceViewResolver jspViewResolver = new InternalResourceViewResolver();
jspViewResolver.setPrefix("/WEB-INF/jsp/");
jspViewResolver.setSuffix((".jsp"));
registry.viewResolver(jspViewResolver);
}
}
复制代码
WebMvcConfigurer提供了回调方法来供咱们自定义SpringMVC的默认配置。若是是使用@EnableWebMvc注解的话表示启用WebMvcConfigurationSupport类的默认配置。咱们并无使用@EnableWebMvc注解而是实现了WebMvcConfigurer,这样作是为了扩展。
package com.os.web;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
@RequestMapping("/user")
public class IndexController {
@GetMapping("/add")
public String add(){
return "add";
}
}
复制代码
基本上就搞定了!发布一下项目就好了,这里没有使用Tomcat插件的形式进行发布,仍是使用原始的发布方式,这里就不过多说明和配置了,这些东西仍是比较简单的!上述配置和加载SpringMVC的核心配置文件的方式是咱们推荐的方式,可是还有一种能够读取前端控制器的方式,这里简单的记录一下!
package com.hanpang.config;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.ServletRegistration;
import org.springframework.web.WebApplicationInitializer;
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
import org.springframework.web.servlet.DispatcherServlet;
public class HelloWorldInitializer implements WebApplicationInitializer {
@Override
public void onStartup( ServletContext application ) throws ServletException {
System.out.println("开始加载容器");
AnnotationConfigWebApplicationContext ctx = new AnnotationConfigWebApplicationContext();
ctx.register(SpringMvcConfiguration.class);//核心类
ctx.setServletContext(application);
ServletRegistration.Dynamic servlet = application.addServlet("dispatcher", new DispatcherServlet(ctx));
servlet.setLoadOnStartup(2);
servlet.addMapping("/");
}
}
复制代码