PasteTemplate序列的接口权限控制使用的都是一套逻辑

包括不限于PasteSpider,PasteTimer,PasteTicker等

大致逻辑一致,具体的细节可能会根据项目做一些调整!

实现

项目中使用的是过滤器实现的RoleAttribute:ActionFilterAttribute

查找源代码大概看到如下代码

    /// <summary>
/// 这里的权限筛选器
/// </summary>
public class RoleAttribute : ActionFilterAttribute
{
/// <summary>
/// 权限
/// </summary>
private string _role { set; get; } /// <summary>
/// 角色
/// </summary>
private string _model { get; set; } /// <summary>
///
/// </summary>
private readonly ModelHelper _appCache; /// <summary>
///
/// </summary>
/// <param name="appcache"></param>
/// <param name="Model"></param>
/// <param name="Role"></param>
public RoleAttribute(
ModelHelper appcache,
string Model = default,
string Role = default
)
{
_role = Role;
_model = Model;
_appCache = appcache;
} /// <summary>
///
/// </summary>
/// <param name="context"></param>
/// <exception cref="SmartToolException"></exception>
public override void OnActionExecuting(ActionExecutingContext context)
{
var needauth = true;
foreach (var item in context.Filters)
{
// Console.WriteLine(item.ToString()); 可以看看有多少过滤器被注入了
if (item is AllowAnonymousAttribute)
{
needauth = false;
break;
}
if (item is RoleAttribute)
{
needauth = (item == this);
}
}
if (needauth)
{
//authorization
if (context.HttpContext.Request.Headers[PublicString.TokenHeadName].Count == 0)
{
throw new SmartToolException("当前未登录,请登录后重试", "401");
}
var token = context.HttpContext.Request.Headers[PublicString.TokenHeadName].ToString();
if (token.StartsWith("Bearer"))
{
token = token.Replace("Bearer ", "");
} //// 获得当前用户信息后 如果要使用base.CurrentUser.的属性,下面要按需注入
//var list = new System.Security.Claims.ClaimsIdentity();
//list.AddClaim(new System.Security.Claims.Claim("editionid", "张三"));//EditionId
//list.AddClaim(new System.Security.Claims.Claim("client_id", token)); //ClientId
//list.AddClaim(new System.Security.Claims.Claim("tenantid", token));//TenantId
//list.AddClaim(new System.Security.Claims.Claim(ClaimTypes.Name, token));//TenantId
//var _guid_userid = Guid.NewGuid().ToString();
//Console.WriteLine(_guid_userid);
//list.AddClaim(new System.Security.Claims.Claim(AbpClaimTypes.UserId, _guid_userid));
//context.HttpContext.User = new System.Security.Claims.ClaimsPrincipal(list); //这里可以做token的安全校验
if (!String.IsNullOrEmpty(token))
{
//if (token.CheckToken())
//{
var back = _appCache.HasRole(_model, _role, token);
if (!back.role)
{
throw new SmartToolException($"{(back.code == 401 ? "当前登录密钥失效,请重新登录" : "没有当前接口的操作权限,请确认")}", $"{back.code}");
}
//}
//else
//{
// throw new SmartToolException("当前密钥信息有误,请登录后重试", "401");
//}
}
else
{
throw new SmartToolException("当前密钥信息有误,请登录后重试", "401");
}
}
base.OnActionExecuting(context);
}
}

注入

在需要使用的地方使用如下方式注入

    [TypeFilter(typeof(RoleAttribute), Arguments = new object[] { "data", "add" })]

当然为了省事你也可以使用全局注入,比如

            //全局处理异常信息
context.Services.AddControllers(options =>
{
//访问限制
//options.Filters.Add(typeof(ReferrerAttribute));
//错误统一处理
//options.Filters.Add(typeof(PlanExceptionAttribute));
//统一授权
options.Filters.Add(typeof(RoleAttribute));
});

不过一般不建议全局注入,如果全局注入就变成权限的划分要按照Controller和Action两个部分了,如果使用*做识别,还是有搞头的,

不需要的再通过过滤器AllowAnonymousAttribute标记下,还是可以的!

在PasteTemplate项目中,使用的是按需注入,主要是接口权限的问题,看RoleAttribute可以了解到有2个参数Model和Role

可以这么理解一个是模块,一个是权限,比如会员模块的查看,会员模块的新增!

查看上面信息已经可以知道大概的授权流程了,就是用户访问接口的时候,带上自己的token,

接口处标注model和role,然后代码计算当前token所表示的信息是否包含对应的model和role的权限,有则通过,没有则报403错误!

那么问题就剩下token的生成规则和使用注意问题了!

借鉴jwt或者oauth2.0,个人感觉oauth2.0是更合理的,jwt就有点老赖的感觉,我授权出去了就和我没关系了,每次请求还得附带一大堆东西(权限列表加密后的内容等)

密钥生成

拿PasteSpider的token来说 token的格式大概为1760192342_11923_xoifsdkfwejrkwetjoweirwerwet

从_拆分打开分成三部分1.时间戳 2.当前会员id.3消息加密校验,也可以成为sign

用户登陆后,代码可以获取到当前登陆用户的userid,然后var temptoken=md5/sha/sha256...(timestamp_userid_appsecret);

var token =timestamp_userid_temptoken

这样生成的好处是,在不执行redis查询的时候就可以排除一些加的token的访问

如果对接口的权限授权有区分的,比如get的只做一层校验即可,参考jwt,授权一个密钥使用1个月,那么这个账号下一秒删除了,之前授权出去的还能继续使用直到到期!post等请求对数据有更改的再执行redis的二次确认!这样的做法可以极大的提交相应速度!

其实如果权限不是很多的,可以基于上面的方式参考jwt直接封装到token中也是可以的!消息长度绝对比jwt的短!

密钥作废

如果一个用户被禁用了,只要把它对应的token从redis中删除即可!超过时间戳的,密钥直接作废,其实就是下一次访问的时候服务端检查到密钥过期了,直接返回401

问题一

如何在使用自定义过滤器的同时,使用Abp的base.CurrentUser获取当前登陆用户的信息,这个可以去查看下源码,找到这个base.CurrentUser的具体是如何获取值的就行了,按照他们的关系,在过滤器的时候对对应的值赋值即可!

问题二

如何使用AuthorizeAttribute?有时候人的习惯就是那么奇怪,或者旧项目,只要不启用这个Authorize模块即可,然后随便全局注入一个自己的过滤器,在自己的过滤器里面去找当前是否有AuthorizeAttribute即可实现授权。

问题三

市面上一大堆介绍jwt等的授权,用这个自定义的会不会有并发不足等的问题,这个你得自己研究下代码,看看啥叫瓶颈!!!

PasteSpider之接口的授权实现为什么不采用JWT方式的更多相关文章

  1. 易盛信息9.0外盘期货行情数据API接口公共授权开发包例子代码

    易盛信息9.0外盘期货行情数据API接口公共授权开发包例子代码        怎么才能获取到外盘期货行情数据API接口呢?不少朋友就会考虑到易盛9.0行情API接口,本身易盛就是一个软件提供商,提供行 ...

  2. OAuth 第三方登录授权码(authorization code)方式的小例子

    假如上面的网站A,可以通过GitHub账号登录: 下面以OAuth其中一种方式,授权码(authorization code)方式为例. 一.第三方登录的原理 所谓第三方登录,实质就是 OAuth 授 ...

  3. 项目一:第十二天 1、常见权限控制方式 2、基于shiro提供url拦截方式验证权限 3、在realm中授权 5、总结验证权限方式(四种) 6、用户注销7、基于treegrid实现菜单展示

    1 课程计划 1. 常见权限控制方式 2. 基于shiro提供url拦截方式验证权限 3. 在realm中授权 4. 基于shiro提供注解方式验证权限 5. 总结验证权限方式(四种) 6. 用户注销 ...

  4. AspNetCore 成长杂记(一):JWT授权鉴权之生成JWT(其二)

    引子 前面说了用第三方类库生成JWT的故事,给我带来了很大的方便,并且我也承诺要写一篇用常规方法生成JWT的文章(一般都是用微软官方的类库),因此才有了这篇文章. 另外,在前面的文章中,我要纠正一下一 ...

  5. ZeroMQ接口函数之 :zmq_curve – 安全的认证方式和保密方式

    ZeroMQ 官方地址 :http://api.zeromq.org/4-0:zmq_curve zmq_curve(7) ØMQ Manual - ØMQ/4.1.0 Name zmq_curve  ...

  6. php用curl调用接口方法,get和post两种方式

    首先是客户端执行方法ApiModel.php: <?php /** * 模拟post进行url请求 * @param string $url * @param array $post_data ...

  7. 微信公众平台--网页授权获取用户基本信息(snsapi_base方式)

    关于snsapi_base网页授权的说明 以snsapi_base为scope发起的网页授权,是用来获取进入页面的用户的openid的,并且是静默授权并自动跳转到回调页的.用户感知的就是直接进入了回调 ...

  8. 微信公众平台--网页授权获取用户基本信息(snsapi_userinfo方式)

    关于snsapi_userinfo网页授权的说明 以snsapi_userinfo为scope发起的网页授权,是用来获取用户的基本信息的.但这种授权需要用户手动同意,并且由于用户同意过,所以无须关注, ...

  9. 使用Callable接口创建线程和使用线程池的方式创建线程

    1.使用Callable接口的方式实现多线程,这是JDK5.0新增的一种创建多线程的方法 package com.baozi.java2; import java.util.concurrent.Ca ...

  10. wp rest api 授权方法步骤(使用JWT Authentication插件)

    环境:wordpress 4.7 以上,WP自带的 rest api v2 目标:使用javascript与wp rest api交互,其中编辑.新增.删除等需要Oauth认证授权 方法: 步骤一:  ...

随机推荐

  1. 基于OT与CRDT协同算法的文档划词评论能力实现

    基于OT与CRDT协同算法的文档划词评论能力实现 当我们实现在线文档平台时,划词评论的功能是非常必要的,特别是在重文档管理流程的在线文档产品中,文档反馈是非常重要的一环,这样可以帮助文档维护者提高文档 ...

  2. VMware下CentOS7.6安装openGauss

    VMware 下 CentOS7.6(7.9)安装 openGauss centos 安装 这里我使用的是 vmware workstation Pro 15 虽然官网了解了一下 openGauss ...

  3. openGauss基于4路鲲鹏服务器的性能调优

    1.概述 本文主要描述了在4路鲲鹏服务器上,通过软硬件协同优化配置达到openGauss数据库的极致性能的方法. 主要包括软硬件要求.BIOS配置.网卡配置.磁盘配置.服务器参数设置.数据库参数配置. ...

  4. 插入排序的基本实现【数据结构与算法—TypeScript 实现】

    笔记整理自 coderwhy 『TypeScript 高阶数据结构与算法』课程 概念 本质:将数列分为已排序和未排序,将未排序中的元素插入到已排序中的合适位置 特性 复杂度分析 时间复杂度: 最好情况 ...

  5. webpack 配置热更新

    正文 代码 const path=require('path'); module.exports={ devtool:'', entry:{ entry:'./src/entry.js', entry ...

  6. 重新整理数据结构与算法(c#)—— 线索化二叉树[二十]

    前言 为什么会有线索化二叉树呢? 是这样子的,二叉树呢,比如有n个节点,那么就有n+1个空指针域. 这个是怎么来的呢?比如我们假如一个节点都有左子树和右子树,那么就有2n个节点. 但是我们发现连接我们 ...

  7. leetcode每日一题:836. 矩形重叠

    836. 矩形重叠 矩形以列表 [x1, y1, x2, y2] 的形式表示,其中 (x1, y1) 为左下角的坐标,(x2, y2) 是右上角的坐标. 如果相交的面积为正,则称两矩形重叠.需要明确的 ...

  8. easyx的使用 鼠标交互(3.1)

    本文学习于B站,进行借鉴学习记录: 视频链接:鼠标操作(新版)_哔哩哔哩_bilibili 初始化调用文件头不再使用#include<graphics.h>,选择调用#include< ...

  9. b站的视频进度条悬浮预览视频画面实现方式

    1.探究 在看b站视频,滑到进度条的时候突发奇想,想知道这个预览图是怎么做到的 打开控制台,发现每次移动鼠标悬浮位置的时候都会发出一条网络请求,并且该请求的size显示来源于内存,当时以为每次加载视频 ...

  10. Oracle ORA-12725 unmatched parentheses in regular expression

    Oracle ORA-12725 unmatched parentheses in regular expression 简单来说就是正则表达式中的括号问题 这种一般就可以锁定使用正则的函数,例如 r ...