Java:SpringMvc--基于注解和xml开发

一、概述

1、定义:

SpringMVC是一种基于Java实现MVC模型的轻量级Web框架

2、优点:

使用简单、开发便捷(相比于Servlet)、灵活性强;

基于原生的 Servlet ,通过了功能强大的 前端控制器 DispatcherServlet ,对请求和响应进行统一
处理。

二、基于注解配置

1、导入依赖

    
      org.springframework
      spring-webmvc
      6.0.4
    
    
      jakarta.servlet
      jakarta.servlet-api
      5.0.0
    
    
      com.fasterxml.jackson.core
      jackson-databind
      2.14.2
    

2、创建配置类并且将web.xml替换

配置类,扫描controller包,加载Controller控制器bean,扫描放行的SpringMvcSupport

@Configuration
@ComponentScan({"com.islunatic.controller","com.islunatic.config"})
@EnableWebMvc//开启自动转化为json数据的支持
public class SpringMvcConfig {
}

创建web项目入口配置类,设置拦截路径,解决post请求中文乱码问题  

public class SpringMvcInitConfig extends AbstractAnnotationConfigDispatcherServletInitializer {
    @Override
    protected Class[] getRootConfigClasses() {
        return new Class[]{};
    }
    @Override
    protected Class[] getServletConfigClasses() {
        return new Class[]{SpringMvcConfig.class};
    }
     //设置SpringMVC请求地址拦截规则
    @Override
    protected String[] getServletMappings() {
        return new String[]{"/"};
    }
    //乱码处理
    @Override
    protected Filter[] getServletFilters() {
        CharacterEncodingFilter filter = new CharacterEncodingFilter();
        filter.setEncoding("UTF-8");
        return new Filter[]{filter};
    }
}

上面添加了静态资源,SpringMVC会拦截,需要在SpringConfig的配置类中将静态资源进行放行。

@Configuration
public class SpringMvcSupport extends WebMvcConfigurationSupport {
    @Override
    protected void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("/pages/**").addResourceLocations("/pages/");
        registry.addResourceHandler("/css/**").addResourceLocations("/css/");
        registry.addResourceHandler("/js/**").addResourceLocations("/js/");
        registry.addResourceHandler("/plugins/**").addResourceLocations("/plugins/");
    }
}

 注: getServletMappings方法,设SpringMVC对应的请求映射路径,即SpringMVC拦截哪些请求

gwtServletApplicationContext用来加载SpringMVC环境

getRootApplicationContext用来加载Spring环境

3、编写controller类

@Controller
public class UserController {
    @RequestMapping("/user")
    @ResponseBody
    public String User(){
        System.out.println("user...");
        return "{muddle:spring}";
    }
    @RequestMapping(value = "/save")
    @ResponseBody
    //@RequestBody设置接受json数据
    public String save(@RequestBody User user){
        System.out.println(user);
        return "success";
    }
}
名称 @Controller
类型 类注解
位置 SpringMVC控制器类定义上方
作用 设定SpringMVC的核心控制器bean
名称 @RequestMapping
类型 类注解或方法注解
位置 SpringMVC控制器类或方法定义上方
作用 设置当前控制器方法请求访问路径,即配置映射路径
相关属性 value(默认),请求访问路径
名称 @ResponseBody
类型 类注解或方法注解
位置 SpringMVC控制器类或方法定义上方
作用 设置当前控制器方法响应内容为当前返回值,无需解析。即返回json数据

4、当使用SpringConfig加载Bean的时候排除掉SpringMvc控制的Bean

@Configuration
@ComponentScan(value="com.islunatic",
    [email protected](
    	type = FilterType.ANNOTATION,
        classes = Controller.class
    )
)
public class SpringConfig {
}
  • excludeFilters属性:设置扫描加载bean时,排除的过滤规则

  • classes属性:设置排除的具体注解类,当前设置排除@Controller定义的bean

  • type属性:设置排除规则,当前使用按照bean定义时的注解类型进行排除;其中ANNOTATION:按照注解排除。

名称 @ComponentScan
类型 类注解
位置 类定义上方
作用 设置spring配置类扫描路径,用于加载使用注解格式定义的bean
相关属性 excludeFilters:排除扫描路径中加载的bean,需要指定类别(type)和具体项(classes) includeFilters:加载指定的bean,需要指定类别(type)和具体项(classes)

5、五种参数的类型传递

①普通参数:url地址传参,地址参数名与形参变量名相同,定义形参即可接收参数。

②pojo类型传参:请求参数名与形参对象属性名相同,定义POJO类型形参即可接收参数。

③嵌套pojo类型传参:请求参数名与形参对象属性名相同,按照对象层次结构关系即可接收嵌套POJO属性参数

注意:请求参数key的名称要和POJO中属性的名称一致,否则无法封装

④数组类型传参:请求参数名与形参对象属性名相同且请求参数多个,定义数组类型即可接收参数

注意:同名请求参数可以直接映射到对应名称的形参数组对象中

⑤集合类型传参:请求参数名与形参集合对象名相同且请求参数为多个,@RequestParam绑定参数关系

注意:同名请求参数可以使用@RequestParam注解映射到对应名称的集合对象中作为数据

名称 @RequestParam
类型 形参注解
位置 SpringMVC控制器方法形参定义前面
作用 绑定请求参数与处理器方法形参间的关系
相关参数 required:是否为必传参数 defaultValue:参数默认值

6、JSON数据传输参数

SpringMvc使用jackson来处理json数据,使用@EnableWebMvc开启json数据类型自动转换,使用@RequestBody注解将外部传递的json数组数据映射到形参的集合对象中作为数据。

名称 @EnableWebMvc
类型 配置类注解
位置 SpringMVC配置类定义上方
作用 开启SpringMVC多项辅助功能
名称 @RequestBody
类型 形参注解
位置 SpringMVC控制器方法形参定义前面
作用 将请求中请求体所包含的数据传递给请求参数,此注解一个处理器方法只能使用一次
名称 @ResponseBody
类型 方法\类注解
位置 SpringMVC控制器方法定义上方和控制类上
作用 设置当前控制器返回值作为响应体, 写在类上,该类的所有方法都有该注解功能
相关属性 pattern:指定日期时间格式字符串

@RequestBody与@RequestParam区别:

@RequestParam 用于接收url地址传参,表单传参
@RequestBody 用于接收json数据

 三、基于xml配置

1、配置web.xml


  teacity
  
  
  
    encoding
    org.springframework.web.filter.CharacterEncodingFilter
    
    
      encoding
      UTF-8
    
    
    
      forceEncoding
      true
    
  
  
  
    encoding
    /*
  
  
  
    contextConfigLocation
    classpath:applicationContext.xml
  
  
  
        
    org.springframework.web.context.ContextLoaderListener
  
  
  
  
    springmvc
    org.springframework.web.servlet.DispatcherServlet
    
      
      contextConfigLocation
      
      classpath:springmvc-config.xml
    
    
    1
  
  
    springmvc
    
    /
  
  
    index.html
  

2、配置springmvc-config.xml及视图解析器类型

2.1基于InternalResourceView(转发视图)视图解析器

当控制器方法中所设置的视图名称以 "forward:" 为前缀时,创建 InternalResourceView 视图,此时的视 图名称不会被SpringMVC 配置文件中所配置的视图解析器解析,而是会将前缀 "forward:" 去掉,剩余部 分作为最终路径通过转发的方式实现跳转。


	
	

    
    

	
	
    
    
	
	
	
	
	
	
    
	
		
		
		
		
	
	
		
		
		
	
@RequestMapping("/view/forward")
    public String testInternalResourceView(){
        return "forward:/index";
    }

2.2基于ThymeleafView视图解析器

当控制器方法中所设置的视图名称没有任何前缀时,此时的视图名称会被SpringMVC配置文件中所配置 的视图解析器解析,视图名称拼接视图前缀和视图后缀所得到的最终路径,会通过转发的方式实现跳转。



    
    
    
    
    
    
    
    
        
        
        
            
                
                    
                        
                        
                        
                        
                        
                        
                    
                
            
        
    
@RequestMapping("/view/thymeleaf")
    public String testThymeleafView(){
        return "success";
}

2.3基于RedirectView(重定向视图)视图解析器

当控制器方法中所设置的视图名称以 "redirect:" 为前缀时,创建 RedirectView 视图,此时的视图名称不 会被SpringMVC 配置文件中所配置的视图解析器解析,而是会将前缀 "redirect:" 去掉,剩余分作为最终路径通过重定向的方式实现跳转。


    
    
    
    
    
    
    
    
    
        
    

@RequestMapping("/view/redirect")
    public String testRedirectView(){
        return "redirect:/index";
}

3、视图控制器

当控制器方法中,仅仅用来实现页面跳转,即只需要设置视图名称时,可以将处理器方法使用 view-controller标签进行表示。
    
    
    

注意:当SpringMVC中设置任何一个view-controller时,其他控制器中的请求映射将全部失效,此时需 要在SpringMVC的核心配置文件中设置开启mvc注解驱动的标签:

     
    

你可能感兴趣的:(Spring,SpringMVC,Mybatis,java,servlet,spring)