本文的目的是介绍springmvc参数接收的详细情况,特别关注springmvc参数接收的相关信息。我们将通过专业的研究、有关数据的分析等多种方式,为您呈现一个全面的了解springmvc参数接收的机
本文的目的是介绍spring mvc 参数接收的详细情况,特别关注springmvc参数接收的相关信息。我们将通过专业的研究、有关数据的分析等多种方式,为您呈现一个全面的了解spring mvc 参数接收的机会,同时也不会遗漏关于Java SSM Spring MVC 三层架构和MVC+SpringMVC的入门案例+请求参数的绑定+常用的注解、JavaEE——SpringMVC(13)--SpringMVC运行流程 在 Spring 的环境下使用 SpringMVC、java之SpringMVC学习(二)使用注解、跳转、重定向、参数接收、Spring MVC ajax提交json 方式的多种方式 (二) 通过参数接收的知识。
本文目录一览:- spring mvc 参数接收(springmvc参数接收)
- Java SSM Spring MVC 三层架构和MVC+SpringMVC的入门案例+请求参数的绑定+常用的注解
- JavaEE——SpringMVC(13)--SpringMVC运行流程 在 Spring 的环境下使用 SpringMVC
- java之SpringMVC学习(二)使用注解、跳转、重定向、参数接收
- Spring MVC ajax提交json 方式的多种方式 (二) 通过参数接收
spring mvc 参数接收(springmvc参数接收)
需要先了解关于http请求的content-type,html 中form表单默认content-type时application/x-www-form-urlencoded(ps:对参数进行编码)。这是参数发送放在请求体中(Form Data). Form Data中的数据以键值对形式发送,后台可以直接解析,主要原因是大多数后端服务器都对content-type为application/x-www-form-urlencoded参数进行了特殊处理放在的键值对的数据结构中,如果map
在使用jquery ajax是默认的content-type是application/x-www-form-urlencoded。而原生的ajax默认使用的content-type是text/plain,text/plain的参数是在request payload中,content-type为application/json是发送的参数也是在request payload中,对于request payload中的数据,后台是不能直接解析的,需要使用数据流来解析
spring mvc接收json字符串
前端
var data = {
name:''zhangsan'',
color:[''blue'',''red'']
};
$.ajax({
url: ''/user/jsonContent'',
type: ''post'',
contentType: ''application/json'',//必须加上
data: JSON.stringify(data),//必须将对象转成字符串
success: function (result) {
},
error: function () {
}
});
针对上面方式发送的数据,通过浏览的控制台,可以看出发出的数据是在request payload中。
后端:
/**
* 使用@RequestBody注解获取json字符串参数
* ps:必须使用@RequestBody
* @param user
* @return
*/
@ResponseBody
@RequestMapping(value = "jsonContent",method = RequestMethod.POST)
public CommonResult testJsonContent(@RequestBody UserVo user){
System.out.println("user:"+JSON.toJSONString(user));
return new CommonResult();
}
重点:对于 Request Payload 请求, 必须加 @RequestBody
才能将请求正文解析到对应的 bean 中
spring mvc接收数组
使用@RequestParam注解来接收数组,如果数组可能为空则可设置required为false来规避参数错误
前端
var data = {
name:''zhangsan'',
resourceIds:[''1'',''2'']
};
$.ajax({
url: ''/user/jsonContent'',
type: ''post'',
data: data,//必须将对象转成字符串
success: function (result) {
},
error: function () {
}
});
后端(list接收):
@ResponseBody
@RequestMapping(value = "/grant",method = RequestMethod.POST)
public CommonResult grant(int id,@RequestParam(value = "resourceIds",required = false) List<String> resourceIds){
CommonResult result = new CommonResult();
if(id<1){
result.setMessage("角色编号参数不正确,无法分配权限");
return result;
}
return result;
}
后端(数组接收):
@ResponseBody
@RequestMapping(value = "/grant",method = RequestMethod.POST)
public CommonResult grant(int id,@RequestParam(value = "resourceIds",required = false) String[] resourceIds){
CommonResult result = new CommonResult();
if(id<1){
result.setMessage("角色编号参数不正确,无法分配权限");
return result;
}
return result;
}
数组参数的单元测试例子:
@Test
public void whenMultipleParameters_thenList() throws Exception {
this.mockMvc.perform(get("/books")
.param("authors", "martin")
.param("authors", "tolkien")
)
.andExpect(status().isOk())
.andExpect(model().attribute("authors", contains("martin","tolkien")));
}
总结:
- 对于 Request Payload 请求, 必须加
@RequestBody
才能将请求正文解析到对应的 bean 中。 - 对于 Form Data 请求,由于多数后端服务器能够自动处理,除了接收数组这样参数,否则基本不需要做特殊处理
Java SSM Spring MVC 三层架构和MVC+SpringMVC的入门案例+请求参数的绑定+常用的注解
第一章:三层架构和MVC
1. 三层架构
1. 咱们开发服务器端程序,一般都基于两种形式,一种C/S架构程序,一种B/S架构程序
2. 使用Java语言基本上都是开发B/S架构的程序,B/S架构又分成了三层架构
3. 三层架构
1. 表现层:WEB层,用来和客户端进行数据交互的。表现层一般会采用MVC的设计模型
2. 业务层:处理公司具体的业务逻辑的
3. 持久层:用来操作数据库的
2. MVC模型
1. MVC全名是Model View Controller 模型视图控制器,每个部分各司其职。
2. Model:数据模型,JavaBean的类,用来进行数据封装。
3. View:指JSP、HTML用来展示数据给用户
4. Controller:用来接收用户的请求,整个流程的控制器。用来进行数据校验等。
第二章:SpringMVC的入门案例
1. SpringMVC的概述
1. SpringMVC的概述
1. 是一种基于Java实现的MVC设计模型的请求驱动类型的轻量级WEB框架。
2. Spring MVC属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里面。Spring 框架提供
了构建 Web 应用程序的全功能 MVC 模块。
3. 使用 Spring 可插入的 MVC 架构,从而在使用Spring进行WEB开发时,可以选择使用Spring的
SpringMVC框架或集成其他MVC开发框架,如Struts1(现在一般不用),Struts2等。
2. SpringMVC在三层架构中的位置
1. 表现层框架
3. SpringMVC的优势
2. SpringMVC的入门程序
1. 创建WEB工程,引入开发的jar包
1. 具体的坐标如下
<!-- 版本锁定 -->
<properties>
<spring.version>5.0.2.RELEASE</spring.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.0</version>
<scope>provided</scope>
</dependency>
</dependencies>
2. 配置核心的控制器(配置DispatcherServlet)
1. 在web.xml配置文件中核心控制器DispatcherServlet
<!-- SpringMVC的核心控制器 -->
<servlet>
<servlet-name>dispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servletclass>
<!-- 配置Servlet的初始化参数,读取springmvc的配置文件,创建spring容器 -->
<init-param>3. 编写springmvc.xml的配置文件
4. 编写index.jsp和HelloController控制器类
1. index.jsp
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<!-- 配置servlet启动时加载对象 -->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>dispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
3. 编写springmvc.xml的配置文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!-- 配置spring创建容器时要扫描的包 -->
<context:component-scan base-package="com.itheima"></context:component-scan>
<!-- 配置视图解析器 -->
<bean id="viewResolver"
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/pages/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
<!-- 配置spring开启注解mvc的支持
<mvc:annotation-driven></mvc:annotation-driven>-->
</beans>
4. 编写index.jsp和HelloController控制器类
1. index.jsp
<body>
<h3>入门案例</h3>
<a href="${ pageContext.request.contextPath }/hello">入门案例</a>
</body>
2. HelloController
package cn.itcast.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
/**
* 控制器
* @author rt
*/
@Controller
public class HelloController {
/**
* 接收请求
* @return
*/
@RequestMapping(path="/hello")
public String sayHello() {
System.out.println("Hello SpringMVC!!");
return "success";
}
}
5. 在WEB-INF目录下创建pages文件夹,编写success.jsp的成功页面
<body>
<h3>入门成功!!</h3>
</body>
6. 启动Tomcat服务器,进行测试
3. 入门案例的执行过程分析
1. 入门案例的执行流程
1. 当启动Tomcat服务器的时候,因为配置了load-on-startup标签,所以会创建DispatcherServlet对象,
就会加载springmvc.xml配置文件
2. 开启了注解扫描,那么HelloController对象就会被创建
3. 从index.jsp发送请求,请求会先到达DispatcherServlet核心控制器,根据配置@RequestMapping注解
找到执行的具体方法
4. 根据执行方法的返回值,再根据配置的视图解析器,去指定的目录下查找指定名称的JSP文件
5. Tomcat服务器渲染页面,做出响应
2. SpringMVC官方提供图形
3. 入门案例中的组件分析
1. 前端控制器(DispatcherServlet)
2. 处理器映射器(HandlerMapping)
3. 处理器(Handler)
4. 处理器适配器(HandlAdapter)
5. 视图解析器(View Resolver)
6. 视图(View