Taurus.MVC WebAPI 入门开发教程5:控制器安全校验属性【HttpGet、HttpPost】【Ack】【Token】【MicroService】。
系列目录
1、Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行。
2、Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World。
3、Taurus.MVC WebAPI 入门开发教程3:路由类型和路由映射。
4、Taurus.MVC WebAPI 入门开发教程4:控制器方法及参数定义、获取及基础校验属性【Require】。
5、Taurus.MVC WebAPI 入门开发教程5:控制器安全校验属性【HttpGet、HttpPost】【Ack】【Token】【MicroService】。
6、Taurus.MVC WebAPI 入门开发教程6:全局控制器DefaultController与全局事件。
7、Taurus.MVC WebAPI 入门开发教程7:业务逻辑基类LogicBase的使用。
8、Taurus.MVC WebAPI 入门开发教程8:WebAPI文档与自动化测试。
后续还有两个系列:
1、Taurus.MVC 微服务 入门开发教程系列。 2、Taurus.MVC Web应用 入门开发教程系列。
前言:
本系列还有几篇,抓紧时间写完,本篇介绍控制器各安全校验属性的使用。
1、Http请求方式属性:【HttpGet】【HttpPost】【HttpHead】【HttpPut】【HttpDelete】
作用:
可限制该方法允许的请求类型,允许标识多个。 如果方法没有标记,即默认允许所有请求类型。
对于控制器的方法,只需要标识上对应的属性标签,示例使用:
public class MSController : Controller
{
/// <summary>
/// Get or Post 测试
/// </summary>
/// <param name="msg">post 消息</param>
/// <param name="file" type="file">file</param>
[HttpGet]
[HttpPost]
public void Hello(string msg, System.Web.HttpPostedFile file)
{
//MicroService.Const.HeaderKey
if (file != null)
{
file.SaveAs(file.FileName);
}
if (Request.UrlReferrer != null)
{
Write("From : " + Request.UrlReferrer.ToString() + "\r\n");
}
Write("MicroService : " + MicroService.Config.AppRunUrl + Request.Url.LocalPath + " : " + Request.HttpMethod + " : " + msg ?? "Hello" + MicroService.Config.ServerName);
}
}
说明:
仅允许Get或Post两种请求方式。
2、安全控制属性:【Ack】
作用:
1、实现自定义:控制请求频率。 2、实现自定义:黑名单过滤。 3、实现自定义:过滤无效的攻击请求。
该标识通常要求发起请求者在请求头传递ack=xxx值,以便API获取该值并进行分析判断。
示例使用:
public class MSController : Controller
{
public override bool CheckAck()
{
string ack = Query<string>("ack");
//1、IP黑名单判断。
//2、重复请求判断:检测该标识是否请求过了。
//3、IP请求频繁检测:判断是否攻击请求。
return 判断后的结果,false禁止继续执行,true则继续;
}
/// <summary>
/// Get or Post 测试
/// </summary>
/// <param name="msg">post 消息</param>
/// <param name="file" type="file">file</param>
[HttpGet]
[HttpPost]
[Ack]
public void Hello(string msg, System.Web.HttpPostedFile file)
{
//MicroService.Const.HeaderKey
if (file != null)
{
file.SaveAs(file.FileName);
}
if (Request.UrlReferrer != null)
{
Write("From : " + Request.UrlReferrer.ToString() + "\r\n");
}
Write("MicroService : " + MicroService.Config.AppRunUrl + Request.Url.LocalPath + " : " + Request.HttpMethod + " : " + msg ?? "Hello" + MicroService.Config.ServerName);
}
}
该标识可以标识在方法,或者类属性上,对于标识上Ack的方法,会触发CheckAck方法。
作用区域:
1、局部控制器内生效:重载CheckAck方法即可。 2、全局生效:在全局控制器DefaultController中的全局事件CheckAck方法实现。
对于安全的处理代码,框架没有提供,有需要可自己实现。
3、账号授权属性:【Token】
作用:
作为账号登陆后,传递账号信息用于校验与获取信息使用。
该标识通常要求发起请求者在请求头传递token=xxx值,以便API获取该值并进行分析判断。
示例:
public class MSController : Controller
{
public override bool CheckToken()
{
string token = Query<string>("token");
//进行安全验证
return base.CheckToken();
}
/// <summary>
/// Get or Post 测试
/// </summary>
/// <param name="msg">post 消息</param>
/// <param name="file" type="file">file</param>
[HttpGet]
[HttpPost]
[Token]
public void Hello(string msg, System.Web.HttpPostedFile file)
{
//MicroService.Const.HeaderKey
if (file != null)
{
file.SaveAs(file.FileName);
}
if (Request.UrlReferrer != null)
{
Write("From : " + Request.UrlReferrer.ToString() + "\r\n");
}
Write("MicroService : " + MicroService.Config.AppRunUrl + Request.Url.LocalPath + " : " + Request.HttpMethod + " : " + msg ?? "Hello" + MicroService.Config.ServerName);
}
}
用法和Ack一样,仅是作用不同。
作用区域:
1、局部控制器内生效:重载CheckToken方法即可。 2、全局生效:在全局控制器DefaultController中的全局事件CheckToken方法实现。
框架内部有提供实现,但是不建议使用,如有需要可以参考源码使用。
参考源码在:https://github.com/cyq1162/Taurus.MVC/blob/master/Taurus.Core/Extend/AuthController.cs
4、微服务通讯安全属性:【MicroService】
作用:
用于校验微服务间的调用权限验证,避免直接请求。
使用方式和【Ack】【Token】一样,也有对应的方法:
public class MSController : Controller
{
public override bool CheckMicroService()
{
string key = Query<string>(MicroService.Const.HeaderKey);
//进行安全验证
return ...
}
/// <summary>
/// Get or Post 测试
/// </summary>
/// <param name="msg">post 消息</param>
/// <param name="file" type="file">file</param>
[HttpGet]
[HttpPost]
[MicroService]
public void Hello(string msg, System.Web.HttpPostedFile file)
{
//MicroService.Const.HeaderKey
if (file != null)
{
file.SaveAs(file.FileName);
}
if (Request.UrlReferrer != null)
{
Write("From : " + Request.UrlReferrer.ToString() + "\r\n");
}
Write("MicroService : " + MicroService.Config.AppRunUrl + Request.Url.LocalPath + " : " + Request.HttpMethod + " : " + msg ?? "Hello" + MicroService.Config.ServerName);
}
}
作用区域:
1、局部控制器内生效:重载CheckMicroService方法即可。 2、全局生效:在全局控制器DefaultController中的全局事件CheckMicroService方法实现。
该属性的使用,在Taurus.MVC 微服务框架系列的安全篇中,会另外提到。
总结:
本篇介绍各属性在控制器中的基本使用,各属性都可以在各控制器类或方法中使用。
对于需要全局统一管控处理的,在全局控制中处理,可以见下一篇都得,全局的DefaultController。
Taurus.MVC WebAPI 入门开发教程5:控制器安全校验属性【HttpGet、HttpPost】【Ack】【Token】【MicroService】。的更多相关文章
- Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World。
系列目录 1.Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...
- Taurus.MVC WebAPI 入门开发教程4:控制器方法及参数定义、获取及基础校验属性【Require】。
系列目录 1.Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...
- Taurus.MVC WebAPI 入门开发教程6:全局控制器DefaultController与全局事件。
系列目录 1.Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...
- Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行(含系列目录)。
前言: Taurus.MVC 微服务版本已经发布了:Taurus.MVC V3.0.3 微服务开源框架发布:让.NET 架构在大并发的演进过程更简单. 以前都是框架发布时写点相关功能点的文章,没有形成 ...
- Taurus.MVC WebAPI 入门开发教程3:路由类型和路由映射。
系列目录 1.Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...
- Taurus.MVC WebAPI 入门开发教程8:WebAPI文档与自动化测试。
系列目录 1.Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...
- Taurus.MVC 微服务框架 入门开发教程:项目集成:4、默认安全认证与自定义安全认证。
系列目录: 本系列分为项目集成.项目部署.架构演进三个方向,后续会根据情况调整文章目录. 本系列第一篇:Taurus.MVC V3.0.3 微服务开源框架发布:让.NET 架构在大并发的演进过程更简单 ...
- Taurus.MVC 微服务框架 入门开发教程:项目集成:6、微服务间的调用方式:Rpc.StartTaskAsync。
系统目录: 本系列分为项目集成.项目部署.架构演进三个方向,后续会根据情况调整文章目录. 开源地址:https://github.com/cyq1162/Taurus.MVC 本系列第一篇:Tauru ...
- Taurus.MVC 微服务框架 入门开发教程:项目部署:7、微服务节点的监控与告警。
系统目录: 本系列分为项目集成.项目部署.架构演进三个方向,后续会根据情况调整文章目录. 开源地址:https://github.com/cyq1162/Taurus.MVC 本系列第一篇:Tauru ...
随机推荐
- 第06组Alpha冲刺(3/6)
目录 1.1 基本情况 1.2 冲刺概况汇报 1.郝雷明 2.鲍凌函 3.曾丽莉 4. 曹兰英 5. 方梓涵 6.董翔云 7.杜筱 8.黄少丹 9. 詹鑫冰 10.吴沅静 1.3 冲刺成果展示 1.1 ...
- 很好用的vscode 插件 Open PHP/HTML/JS In Browser 让php文件直接在浏览器打开
p { font-size: 25px } <body> <h1>安装插件</h1> <img src="https://img2020.cnblo ...
- 《Unix 网络编程》08:基本UDP套接字编程
基本UDP套接字编程 系列文章导航:<Unix 网络编程>笔记 UDP 概述 流程图 recvfrom 和 sendto #include <sys/socket.h> ssi ...
- 关于『进击的Markdown』:第四弹
关于『进击的Markdown』:第四弹 建议缩放90%食用 美人鱼(Mermaid)悄悄的来,又悄悄的走,挥一挥匕首,不留一个活口 又是漫漫画图路... 女士们先生们,大家好! 我们要接受Markd ...
- IDEA找不到类但实际存在的问题解决
不知道某天开始Idea就开始抽风了. 现象: 一个service的接口类,就在同一个包下,但总是找不到,编辑器一直标红 编译可以通过 说明类本身应该是没什么问题的.问题是怎么重新编译重新reload ...
- ElasticSearch6.4.2
做一个简单的API记录 1.依赖为6.4.2 比较老的版本 2.指定ES集群,可接多个Put(); Setting setting=Setting.builder().put("clust ...
- Mac Book安装Windows发烫的问题
Mac Book安装Windows后,电脑发烫,风扇一直高速旋转.针对此问题百度搜索了一下, 大多数人说更改电源选项,由"平衡"模式改为"节能"模式,亲身体验了 ...
- vue基本原理
当一个Vue实例创建时,Vue会遍历data中的属性,用Object.defineProperty(vue3.0使用proxy)将它们转为getter/setter,并且在内部追踪相关依赖,在属性被访 ...
- Python:一个闹钟
随着一个<霍格沃茨:一段校史>风格的大字(呃,这字好像并不大--)标题的出现,无聊的我没事干,又开始整活了~ 之前我做的程序,一个使用了Tkinter库,一个则是Pygame,总之都是带有 ...
- Consider defining a bean of type 'redis.clients.jedis.JedisPool' in your configuration.
报错信息 原因是没有Jedispool没有注入 import com.fasterxml.jackson.annotation.JsonAutoDetect; import com.fasterxml ...