1. 请求
postman
postman是一款功能强大的网页调试与发送网页http请求的chorme插件
作用:常用于进行接口测试
简单参数
原始方式
在原始的web程序中,获取请求参数,需要通过httpserveletrequest对象手动获取。@requestmapping("/simpleparam") public string simpleparam(httpservletrequest request){ string name = request.getparameter("name"); string agestr = request.getparameter("age"); int age = integer.parseint(agestr); system.out.println(name + " : " + age); return "ok"; }
postman调试:
http://localhost:8080/simpleparam?name=tom&age=10
springboot方式
@requestmapping("/simpleparam") public string simpleparam(string name,integer age){ system.out.println(name + " : " + age); return "ok"; }
如果方法形参名称与请求参数名称不匹配,可以使用
@requestparam
完成映射**requestparam
中的required属性默认是true,代表该请求参数必须传递,如果不传递将报错。如果该参数想要设置可选的,可以将required属性设置为false **@requestmapping("/simpleparam") public string simpleparam(@requestparam(name="username")string name,integer age){ system.out.println(name + " : " + age); return "ok"; }
实体参数
简单实体对象
请求参数名与形参对象属性名相同,定义pojo接收即可复杂实体对象
请求参数名与形参对象属性名相同,按照对象层次结构关系即可接收嵌套pojo属性参数
数据集合参数
数组参数
请求参数名与形参组名称相同且请求参数为多个,定义数组类型即可接收参数
请求参数名与形参中数组变量名相同,可以直接使用数组封装
@requestmapping("/arrayparam") public string arrayparam(string[] hobby){ system.out.println(arrays.tostring(hobby)); return "ok"; }
集合参数
请求参数名与形参集合名称相同且请求参数为多个,
@requestparam
绑定参数关系请求求参数名与形参中集合变量名相同,通过@requestparam 绑定参数关系
@requestmapping("/listparam") public string listparam(@requestparam list<string> hobby){ system.out.println(hobby); return "ok"; }
日期参数
使用@datetimeformat
注解完成日期参数格式转换
@requestmapping("/dateparam") public string dataparam(@datetimeformat(pattern="yyyy-mm-dd hh:mm:ss")localdatetime updatetime){ system.out.println(updatetime); return "ok"; }
json参数
json数据键名与形参对象属性名相同,定义pojo类型形参即可接收参数,需要使用 @requestbody
标识
@requestmapping("/jsonparam") public string jsonparam(@requestbody user user){ system.out.println(user); return "ok"; }
路径参数
通过请求url直接传递参数,使用{…}来标识该路径参数,需要使用 @pathvaribale
获取路径参数
@requestmapping("/path/{id}/{name}") public string pathparam(@pathvariable integer id,@pathvariable string name){ system.out.println(id+" : " + name); return "ok"; }
2. 响应
- @responsebody
- 类型:方法注解、类注解
- 位置:controller方法上/类上
- 作用:将方法返回值直接响应,如果返回值是 实体对象/集合,将会转换为json格式响应
- 说明:@restcontroller=@controller+@responsebody
统一响应结果
public class result{ //响应码,1代表成功;0代表失败 private integer code; //提示信息 private string msg; //返回的数据 private object data; //... }
3. 分层解耦
三层架构
- controller:控制层,接收前端发送的请求,对请求进行处理,并响应数据。
- service:业务逻辑层,处理具体的业务逻辑。
- dao:数据访问层(data access object)(持久层),负责数据访问操作,包括数据的增删查改。
分层解耦
- 内聚:软件中各个功能模块内部的功能联系。
- 耦合:衡量软件中各个层/模块之间的依赖、关联的程度。
- 软件设计原则:高内聚低耦合。
- 控制反转inversion of control,简称ioc。对象的创建控制权由程序自身转移到外部(容器),这种思想称为控制反转。
- 依赖注入dependency injection,简称di。容器为应用程序提供运行时,所以来的资源,称之为依赖注入。
- bean对象ioc容器中创建、管理的对象,称之为bean
ioc & di入门
service层及dao层的实现类,交给ioc容器管理
@component //交给ioc容器管理 public class empdao implements empdao{...} @component //交给ioc容器管理 public class empservicea implements empservice{...}
controller及service注入运行时,依赖的对象。
@component public class empservicea implements empservice{ @autowired //依赖注入 private empdao empdao; } @restcontroller public class empcontroller { @autowired //依赖注入 private empservice empservice; }
ioc详解
bean的声明要把某个对象交给ioc容器,需要在对应的类上加上如下注解之一:
注解 说明 位置 @component 声明bean的基础注解 不属于以下三类时,用此注解 @controller @component的衍生注解 标注在控制器类上 @service @component的衍生注解 标注在业务类上 @repository @component的衍生注解 标注在数据访问类上(由于与mybatis整合,用的少) 注意事项
- 声明bean的时候,可以通过value属性指定bean的名字,如果美欧指定,默认为类名首字母小写
- 使用以上四个注解都可以声明bean,但是在springboot继承web开发中,声明控制器bean只能用@controller
bean组件扫描
- 前面声明bean的四大注解,想要生效, 还需要被组件扫描注解
componentscan
扫描。 @componentscan
注解虽然没有显式配置,但是实际上以及包含了启动类声明注解@springbootapplication
中,默认扫描的范围是启动类所在包及其子包。
- 前面声明bean的四大注解,想要生效, 还需要被组件扫描注解
di详解
bean注入
@autowired
注解,默认是按照类型进行,如果存在多个相同类型的bean,将会报出如下错误:通过以下几种方案来解决:
@primary
@primary @service public class empservicea implements empservice{}
@qualifier
@restcontroller public class empcontroller{ @autowired @qualifier("empservicea") private empservice empservice; }
@resource
@restcontroller public class empcontroller{ @resource(name="empservicea") private empservice empservice; }
@resource
与@autowired
区别@autowired
是spring框架提供的注解,而@resource
是jdk提供的注解。@autowired
默认是按照类型注入,而@resource
默认是按照名称注入。
总结
到此这篇关于springboot web请求响应的文章就介绍到这了,更多相关springboot web请求响应内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论