Spring实战4之SpringMVC篇

一、一个请求的过程
这里写图片描述

二、搭建SpringMVC
1.配置DispatcherServlet
(1)使用Java配置DispatcherServlet
在旧版本中,DispatcherServlet之类的servlet一般在web.xml文件中配置,该文件一般会打包进最后的war包种;但是Spring 3引入了注解,可以在servlet容器中使用Java配置DispatcherServlet,具体的代码列举如下:

public class SpittrWebAppInitializer  
        extends AbstractAnnotationConfigDispatcherServletInitializer {  
    @Override  
    protected Class<?>[] getRootConfigClasses() { //根容器  
        return new Class<?>[] { RootConfig.class };  
    }  

    @Override  
    protected Class<?>[] getServletConfigClasses() { //Spring mvc容器  
        return new Class<?>[] { WebConfig.class };  
    }  

    @Override  
    protected String[] getServletMappings() { //DispatcherServlet映射,从"/"开始  
        return new String[] { "/" };  
    }  
}  

(2)AbstractAnnotationConfigDispatcherServletInitializer类分析
AbstractAnnotationConfigDispatcherServletInitializer创建了DispatcherServlet和ContextLoaderListener:
DispatcherServlet仅加载web组件之类的beans,例如controllers(控制器)、view resolvers(视图解析器)和处理器映射(handler mappings);而希望ContextLoaderListener加载应用中的其他类型的beans——例如业务逻辑组件、数据库操作组件等等。
getServletConfigClasses()返回的配置类定义了Spring MVC应用容器中的beans;getRootConfigClasses()返回的配置类定义了Spring应用根容器中的beans。【书中没有说的】:Spring MVC容器是根容器的子容器,子容器可以看到根容器中定义的beans,反之不行。

2.启用SpringMVC
(1)使用Java配置启用SpringMVC
原来我们一般在xml文件中使用元素启动注解驱动的Spring MVC特性。
现在可以使用Java配置启用SpringMVC,具体的代码列举如下:

@Configuration  
@EnableWebMvc  
@ComponentScan(value="org.test.spittr.web")  
public class WebConfig extends WebMvcConfigurerAdapter{  
    @Bean  
    public ViewResolver viewResolver() { //配置JSP视图解析器  
        InternalResourceViewResolver resolver = new InternalResourceViewResolver();  
        resolver.setPrefix("/WEB-INF/views/");  
        resolver.setSuffix(".jsp");  
        //可以在JSP页面中通过${}访问beans  
        resolver.setExposeContextBeansAsAttributes(true);  
        return resolver;  
    }  

    @Override  
    public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {  
        configurer.enable(); //配置静态文件处理  
    }  
}  

3.配置RootConfig

@Configuration  
@ComponentScan(basePackages = {value="org.test.spittr"},  
        excludeFilters = {@ComponentScan.Filter(type = FilterType.ANNOTATION, value = EnableWebMvc.class)})  
public class RootConfig {  
} 

三、编写一个控制器

@Controller  
@RequestMapping("/spittles")  //定义类级别的请求
public class SpittleController { 
    @Autowired   
    private SpittleRepository spittleRepository;  

    @RequestMapping(method = RequestMethod.GET)  
    public String spittles(Model model) {  
        model.addAttribute(  
                spittleRepository.findSpittles(Long.MAX_VALUE, 20));  
        return "spittles";  
    }  

     /**
     * 客户端给控制器的handler以查询参数方式传入参数
     */
    @RequestMapping(method = RequestMethod.GET)  
    public List<Spittle> spittles(  
            @RequestParam(value = "max", defaultValue = MAX_LONG_AS_STRING) long max,  
            @RequestParam(value = "count", defaultValue = "20") int count) {  
        return spittleRepository.findSpittles(max, count);  
    }  

    /**
     * 客户端给控制器的handler以路径参数方式传入参数,@PathVariable注解的参数
     * 应该和@RequestMapping注解中的占位符名称完全相同;
     * 如果函数参数也和占位符名称相同,则可以省略@PathVariable注解的参数
     */
    @RequestMapping(value = "/{spittleId}", method = RequestMethod.GET)  
    public String showSpittle(  
            @PathVariable("spittleId") long spittleId,  
            Model model) {  
        model.addAttribute(spittleRepository.findOne(spittleId));  
        return "spittle";  
    }

    /**
     * 客户端给控制器的handler以表单参数方式传入参数
     * redirect:重定向
     */ 
    @RequestMapping(value = "/register", method = RequestMethod.POST)  
    public String processRegistration(Spitter spitter) {  
        spitterRepository.save(spitter);  
        return "redirect:/spitter/" + spitter.getUsername();  
    }  

    /**
     * 在Spittr类的定义中规定验证条件后,需要在控制器的处理方法中应用验证条件
     */
    @RequestMapping(value = "/register", method = RequestMethod.POST)  
    public String processRegistration(  
            @Valid Spitter spitter,  
            Errors errors) {  
        if (errors.hasErrors()) {  
            return "registerForm";  
        }  
        spitterRepository.save(spitter);  
        return "redirect:/spitter/" + spitter.getUsername();  
    }    
}  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值