【Spring MVC】(二)Controller、View之间的映射与参数传递

简介: 【Spring MVC】(二)Controller、View之间的映射与参数传递

文章目录


Controller配置

控制器Controller

参数传递(View to Controller)

@RequestParam

@RequestMapping

参数传递(Controller to View)

ModelAndView

Model

数据处理


Controller配置


使用SpringMVC,必须配置以下信息:


处理器映射器

<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>

处理器适配器

<bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>

or


注解驱动(如果使用注解来实现Spring MVC,可以不用处理器映射器和处理器适配器)

<mvc:annotation-driven/>


视图解析器(必要)

<bean id="InternalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="prefix" value="/WEB-INF/jsp/"/>
    <property name="suffix" value=".jsp"/>
</bean>


控制器Controller


控制器复杂提供访问应用程序的行为,通常通过接口定义或注解定义两种方法实现。 控制器负责解析用户的请求并将其转换为一个模型。在Spring MVC中一个控制器类可以包含多个方法。


在SpringMVC中,对于Controller的配置方式有很多种:


1.控制器实现方式:实现Controller接口


实现接口Controller定义控制器是较老的办法,缺点是:一个控制器中只有一个方法,如果要多个方法则需要定义多个Controller;定义的方式比较麻烦。


参数传递(View to Controller)


2.使用注解@Controller定义控制器


@Controller注解类型用于声明Spring类的实例是一个控制器(在讲IOC时还提到了另外3个注解);


Spring可以使用扫描机制来找到应用程序中所有基于注解的控制器类,为了保证Spring能找到你的控制器,需要在配置文件中声明组件扫描。

<!-- 自动扫描指定的包,下面所有注解类交给IOC容器管理 -->
<context:component-scan base-package="cn.kgc.kb03.servlet"/>


用注解实现:

@Controller //使用注解定义控制器,注解的类会自动添加到Spring上下文中
    @RequestMapping("/login")  //映射包
    public class LoginServlet{
    Logger log=Logger.getLogger(LoginServlet.class);
    @RequestMapping(value = "/loginServlet") //映射访问路径
    public void login(@RequestParam(value = "name",required = false) String name,
                      @RequestParam(value = "password",required = false) String password){
        System.out.println("这儿是控制器");
        System.out.println(name+","+password);
    }
}


@RequestParam


Controller方法中参数前加@RequestParam进行直接入参,指定其对应的请求参数。


value 参数名


required 是否必需


defaultValue 默认参数名,不推荐使用


@RequestMapping


@RequestMapping注解用于映射url到控制器类或一个特定的处理程序方法,它负责将不同的请求映射到对应的控制器方法上。


1.只注解在方法上面


参考上面的代码,如果@RequestMapping直接注解在方法上面,那么访问路径为:

访问路径:http://localhost:8080/项目名//loginServlet


2.同时注解类与方法


访问路径:http://localhost:8080/项目名/login/loginServlet , 需要先指定类的路径再指定方法的路径。

// 注意这里的映射规则
    @RequestMapping(value = "/turn",method = RequestMethod.POST,params = "userCode")


映射规则


通过请求URL进行映射


通过请求参数进行映射

若选择方法参数直接入参的话,方法入参名必须与请求中参数名保持一致


通过请求方法进行映射

GET

POST


参数传递(Controller to View)


ModelAndView


包含视图信息和模型数据信息


常用方法


添加模型数据

ModelAndView addObject(String attributeName, Object attributeValue)

ModelAndView addAllObjects(Map<String,?> modelMap)


设置视图

void setView(View view)

void setViewName(String viewName)

/**
     * 参数传递:controller to view-(ModelAndView)
     * @param userCode
     * @return
     */
    @RequestMapping(value = "/turn",method = RequestMethod.POST,params = "userCode")
    public ModelAndView hello(@RequestParam String userCode){
        ModelAndView mav=new ModelAndView();
        log.info("登入成功:userCode"+userCode);
        mav.addObject("userCode",userCode);
        mav.setViewName("success");
        return mav;
    }


结果跳转方式:


设置ModelAndView对象,根据View名称,和视图解析器,跳转到指定的页面;


页面 :{视图解析器的前缀} + viewName + {视图解析器的后缀}


Model


除了可以使用ModelAndView对象来返回模型数据之外,还可以使用Spring MVC提供的Model对象来完成模型数据的传递。


数据结构:Map类型


常用方法:添加模型数据

Model.addAttribute(String attributeName,Object attributeValue)

/**
     * 参数传递:controller to view-(Model)
     * @param username
     * @param model
     * @return
     */
    @RequestMapping(value = "/commit",method = {RequestMethod.GET})
    public String index(String username,Model model){
        //Spring MVC会自动实例化一个Model对象用于向视图中传值
        model.addAttribute("username", "username");
        //返回视图位置
        return "index";
    }


数据处理


处理前端传递过来的数据


1.名字规范的数据

@RequestMapping("/hello")
//请求参数名和处理参数名一样的情况下,我们直接接收到前端传递的数据;
//Model主要作用:为了给前端传递我们封装好的参数;
public String hello(String name, Model model){
    System.out.println(name);
    model.addAttribute("aaa",name);
    return "user";
}


2.名字不规范的数据

//请求参数名和处理参数名不一样的情况下
//状况:用户传递的参数名和我们要处理的参数名不一致,需要使用一个注解@RequestParam("username")来进行匹配
@RequestMapping("/hello2")
public String hello2(@RequestParam(value = "username",required = false) String name){
    System.out.println(name);
    return "user";
}


3.传递对象


尽量规范的编程:提交表单的数据和对象的属性名一致

//如何传递一个对象
//要求:提交表单的数据和对象的属性名一致;参数直接使用对象即可;否则按照上面方式处理
//http://localhost:8080/mvc04/hello3?id=1&username=Theshy&password=123456;
@RequestMapping("/hello3")
public String hello3(User user,Model model){
    System.out.println(user);
    model.addAttribute("user",user);
    return "user";
}


目录
打赏
0
0
0
0
89
分享
相关文章
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestParam
本文介绍了 `@RequestParam` 注解的使用方法及其与 `@PathVariable` 的区别。`@RequestParam` 用于从请求中获取参数值(如 GET 请求的 URL 参数或 POST 请求的表单数据),而 `@PathVariable` 用于从 URL 模板中提取参数。文章通过示例代码详细说明了 `@RequestParam` 的常用属性,如 `required` 和 `defaultValue`,并展示了如何用实体类封装大量表单参数以简化处理流程。最后,结合 Postman 测试工具验证了接口的功能。
24 0
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestParam
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestBody
`@RequestBody` 是 Spring 框架中的注解,用于将 HTTP 请求体中的 JSON 数据自动映射为 Java 对象。例如,前端通过 POST 请求发送包含 `username` 和 `password` 的 JSON 数据,后端可通过带有 `@RequestBody` 注解的方法参数接收并处理。此注解适用于传递复杂对象的场景,简化了数据解析过程。与表单提交不同,它主要用于接收 JSON 格式的实体数据。
27 0
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@PathVariable
`@PathVariable` 是 Spring Boot 中用于从 URL 中提取参数的注解,支持 RESTful 风格接口开发。例如,通过 `@GetMapping(&quot;/user/{id}&quot;)` 可以将 URL 中的 `{id}` 参数自动映射到方法参数中。若参数名不一致,可通过 `@PathVariable(&quot;自定义名&quot;)` 指定绑定关系。此外,还支持多参数占位符,如 `/user/{id}/{name}`,分别映射到方法中的多个参数。运行项目后,访问指定 URL 即可验证参数是否正确接收。
20 0
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestMapping
@RequestMapping 是 Spring MVC 中用于请求地址映射的注解,可作用于类或方法上。类级别定义控制器父路径,方法级别进一步指定处理逻辑。常用属性包括 value(请求地址)、method(请求类型,如 GET/POST 等,默认 GET)和 produces(返回内容类型)。例如:`@RequestMapping(value = &quot;/test&quot;, produces = &quot;application/json; charset=UTF-8&quot;)`。此外,针对不同请求方式还有简化注解,如 @GetMapping、@PostMapping 等。
24 0
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RestController
本文主要介绍 Spring Boot 中 MVC 开发常用的几个注解及其使用方式,包括 `@RestController`、`@RequestMapping`、`@PathVariable`、`@RequestParam` 和 `@RequestBody`。其中重点讲解了 `@RestController` 注解的构成与特点:它是 `@Controller` 和 `@ResponseBody` 的结合体,适用于返回 JSON 数据的场景。文章还指出,在需要模板渲染(如 Thymeleaf)而非前后端分离的情况下,应使用 `@Controller` 而非 `@RestController`
17 0
对Spring、SpringMVC、MyBatis框架的介绍与解释
Spring 框架提供了全面的基础设施支持,Spring MVC 专注于 Web 层的开发,而 MyBatis 则是一个高效的持久层框架。这三个框架结合使用,可以显著提升 Java 企业级应用的开发效率和质量。通过理解它们的核心特性和使用方法,开发者可以更好地构建和维护复杂的应用程序。
150 29
步步深入SpringMvc DispatcherServlet源码掌握springmvc全流程原理
通过对 `DispatcherServlet`源码的深入剖析,我们了解了SpringMVC请求处理的全流程。`DispatcherServlet`作为前端控制器,负责请求的接收和分发,处理器映射和适配负责将请求分派到具体的处理器方法,视图解析器负责生成和渲染视图。理解这些核心组件及其交互原理,有助于开发者更好地使用和扩展SpringMVC框架。
77 4
Spring MVC中的请求映射:@RequestMapping注解深度解析
在Spring MVC框架中,`@RequestMapping`注解是实现请求映射的关键,它将HTTP请求映射到相应的处理器方法上。本文将深入探讨`@RequestMapping`注解的工作原理、使用方法以及最佳实践,为开发者提供一份详尽的技术干货。
326 2
Spring Boot中使用MapStruct进行对象映射
本文介绍如何在Spring Boot项目中使用MapStruct进行对象映射,探讨其性能高效、类型安全及易于集成等优势,并详细说明添加MapStruct依赖的步骤。
105 0
SSM:SpringMVC
本文介绍了SpringMVC的依赖配置、请求参数处理、注解开发、JSON处理、拦截器、文件上传下载以及相关注意事项。首先,需要在`pom.xml`中添加必要的依赖,包括Servlet、JSTL、Spring Web MVC等。接着,在`web.xml`中配置DispatcherServlet,并设置Spring MVC的相关配置,如组件扫描、默认Servlet处理器等。然后,通过`@RequestMapping`等注解处理请求参数,使用`@ResponseBody`返回JSON数据。此外,还介绍了如何创建和配置拦截器、文件上传下载的功能,并强调了JSP文件的放置位置,避免404错误。