SpringMVC | SpringMVC中映射器和适配器的两种配置方式

目录

处理器映射器和处理器适配器的配置

1. 基于注解形式实现

2. 基于非注解形式实现


处理器映射器和处理器适配器的配置

SpringMVC中对组件的配置形式主要有两种,注解形式和非注解形式,下面来具体演示介绍这两种方式。

给定需求:展示用户列表

pojo类用户类(User):

public class User {
    private Integer id;
    private String name;
    private String password;

    public User(Integer id, String name, String password) {
        this.id = id;
        this.name = name;
        this.password = password;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", password='" + password + '\'' +
                '}';
    }
}

用户列表页面(userList.jsp):



    数据展示



    <%--c:forEach --%>
    
        <%--var集合--%>
        
用户id 用户名 地址
${users.id} ${users.name} ${users.password}

1. 基于注解形式实现

组件的配置文件(spring-mvc.xml):




    
    
    
    
    
    
    

    
    
    
    
    

    
    

    
    
        
        
    
    

对于处理器映射器和处理器适配器等组件可以显性的声明类全路径,需要注意使用的spring版本,在spring3.1前后使用的类是不同的。

在spring3.1之前使用:

注解映射器:org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping
注解适配器:org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter

在spring3.1之后使用:

注解映射器:org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping
注解适配器:org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter

另外:也可以直接通过读取框架提供的默认的组件。

编写Handler层(UserController.java):

@Controller
public class UserController {

    @RequestMapping("/userlist")
    public ModelAndView userList() {
        ArrayList users = new ArrayList <>();
        users.add(new User(1,"张三","西安"));
        users.add(new User(2,"李四","上海"));
        users.add(new User(3,"王麻子","北京"));

        ModelAndView modelAndView = new ModelAndView();
        //数据填充
        modelAndView.addObject("users",users);//对应前端var
        //指定路径 全路径
        modelAndView.setViewName("userlist");
        return modelAndView;

    }
    @RequestMapping("/usertest")
    @ResponseBody //以JSON数据返回
    public String test() {
        return "Hello";
    }
}

注解使用:

@Controller注解:将类交给容器管理;

@RequestMapping:给定URL,通过URL找到具体处理业务逻辑。

2. 基于非注解形式实现

在各组件的配置文件中,分析映射器和适配器。

组件的配置文件(spring-mvc.xml):



    
    
    
    
​
    
    

    
    
    
        
        
    

处理器适配器类是SimpleControllerHandlerAdapter,通过源码可知,supports是判断当前适配器能不能支持这个handler,要能够被处理器适配器识别的类必须是Controller接口的具体实现类。

SpringMVC | SpringMVC中映射器和适配器的两种配置方式_第1张图片

编写Handler层(User1Controller.java):(要求编写的Handler实现Controller接口

 *
 *基于非注解形式的处理器要能被处理器适配器识别
 *必须实现org.springframework.web.servlet.mvc.Controller接口
 *该接口中的handleRequest需要实现
 **/
public class User1Controller implements Controller {
    @Override
    public ModelAndView handleRequest(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception {
        ArrayList users = new ArrayList<>();
        users.add(new User(1, "张三", "西安"));
        users.add(new User(2, "李四", "上海"));
        users.add(new User(3, "王麻子", "北京"));

        ModelAndView modelAndView = new ModelAndView();
        //数据填充
        modelAndView.addObject("users", users);//对应前端var
        //指定路径 全路径
        modelAndView.setViewName("userList");
        return modelAndView;
    }
}

以上都是学习过程中的总结,如果有错误或者有疑问,欢迎一起交流吖~~

你可能感兴趣的:(SpringMVC,mvc,springmvc,java,intellij,idea)