SpringMVC注解版:读取核心配置类

有的时候真心不喜欢这个世界!!!html

第一步:Servlet容器的初始化

按照以前传统的方式来配置SpringMVC须要在web.xml中配置DispatcherServlet,可是在Servlet3规范和Spring3.1以后新增了一种方式,那就是java和注解的方式进行配置,今天咱们以Spring的最新版本5.2.1.RELEASE来进行一下配置,一块儿来看一下吧!前端

mvc-context-hierarchy.png

在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


第二步:SpringMVC配置

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,这样作是为了扩展。

第三步:编写Controller

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";
    }
}
复制代码

Snap1.jpg

基本上就搞定了!发布一下项目就好了,这里没有使用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("/");

	}

}
复制代码
相关文章
相关标签/搜索