杨中科 ASP.NETCore WebAPI 控制器及返回值、参数问题

控制器及返回值

控制器类

1、ControllerBase与Controller
webapi的controller 继承自 ControllerBase
在这里插入图片描述
webmvc 继承自controller
在这里插入图片描述
controller 继承自controllerbase
在这里插入图片描述

2、控制器类可以不显式地继承自任何类
还是需要添加特性
在这里插入图片描述

运行:
在这里插入图片描述

Action方法的异步

1、Action方法既可以同步也可以异步。
2、异步Action方法的名字一般不需要以Async结尾。
3、Web API中Action方法的返回值如果是普通数据类型,那么返回值就会默认被序列化为Json格式。
4、Web API中的Action方法的返回值同样支持IActionResult类型,不包含类型信息,因此Swagger等无法推断出类型,所以推荐用ActionResult,它支持类型转换,从而用起来更简单。

示例:
在这里插入图片描述
运行结果:
在这里插入图片描述
普通类型 序列化为格式
首先创建一个Person类
在这里插入图片描述
在这里插入图片描述
运行结果:
在这里插入图片描述
普通抛出异常方式,会在客户端直接显示异常信息。这是很不友好的
在这里插入图片描述
运行结果:
在这里插入图片描述
希望返回404
将返回值改为IActionResult
在这里插入图片描述
运行结果:
在这里插入图片描述
也可添加泛型
在这里插入图片描述
【总结:】
如果你的返回类型只有一种类型,那么直接使用哪一种类型得返回类型即可,若有多种则可以使用IAcitonResult

Asp.Net Core Web API Action 方法参数

add 方法使用[HTTPGET]默认的是querystring的方式传递
在这里插入图片描述
思考如何手动指定数据来自于querystring 还是路径还是来自请求体

捕捉URL占位符

1、在[HttpGet]、[HttpPost]等中使用占位符,比如[schoolName},捕捉路径中的内容,从而供Action方法的参数使用。
Students/GetAll/school/MIT/class/A001
[HttpGet(“school/schoolNamel/class (classNol”)]
2、捕捉的值会被自动赋值给Action中同名的参数如果名字不一致,可以用[FromRoute(Name=“名字”)]
3、演示混用
在这里插入图片描述
运行结果:
在这里插入图片描述

名字不同时:
在这里插入图片描述
运行结果:
在这里插入图片描述
HttpPost 方式
在这里插入图片描述
运行结果
在这里插入图片描述

捕捉QUERYSTRING的值

1、使用[FromQuery]来获取QueryString中的值。如果名字一致,只要为参数添加[FromQuery]即可;而如果名字不一致[FromQuery(Name = 名字)]。
在这里插入图片描述

2、QueryString和Route可以混用

JSON 报文体

1、Web API的开发模式下,Json格式的请求体是主流
2、只要声明一个模型类和Json请求的格式一致即可。
3、也是可以把从URL获取参数、从请求报文体获取数据等这些混合使用。
[HttpPost(“classld/(classld)”)]
public ActionResult AddNew(long classldStudentModel s)
4、一定要设定请求头中的Content-Type为application/json,而且数据必须是合法的json格式

复杂参数类型,可以用类的方式
在这里插入图片描述
请求方式相对应即可(2声明一个模型类和Json请求的格式一致即可)
在这里插入图片描述
混合使用
在这里插入图片描述
运行结果:
在这里插入图片描述

在这里插入图片描述
一定要设定请求头中的Content-Type为application/json,而且数据必须是合法的json格式
在这里插入图片描述

其他方式

Web API中很少用的方式:
1、从Content-Type为multipart/form-data的请求中获取数据的[FromForm]
2、从请求报文头中获取值的[FromHeader].

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
swagger的小问题,其实还是获取的浏览器端的 user_agent

  • 19
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值