首页
学习
活动
专区
圈层
工具
发布
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    浅谈 REST API 身份验证的四种方法

    3、API密钥认证api密钥认证使用率非常高,而且也非常灵活,我们先来看一下API密钥认证是如何工作的:图片如图:客户端先去向授权服务器请求到API KEY生成后的KEY可以入库记录客户端访问API服务的带上...API KEY缺点API KEY实际意义上并不是授权,有人还是可以获取 API 密钥并获得对他们可用的所有信息的访问权限,就像使用 HTTP 基本身份验证一样,API 密钥只是消除了攻击者猜测进入系统的方式的能力...我们先来看一下OAuth的工作原理:图片如图:客户端向资源服务器请求授权,这个时候通常就是以用户名和密码进行登录授权通过后,资源服务器同意客户端授权许可客户端拿着资源服务器授权许可去认证服务器申请令牌认证服务器验证授权通过后给客户端生成令牌客户端拿着令牌请求资源服务器资源服务器验证令牌的有效时间验证令牌无误且有效后...举个最简单的生活例子,比如有个军事重地,需要刷卡才能进,那么想要进去,肯定想到先去办张有进入权限的卡,这个卡是跟某某将军的身份证绑定,你通过某种手段拿到了将军的身份证,办理人员只认身份证,身份证无误,给你办了这张卡...总结本文介绍了四种rest api身份验证方法:HTTP认证令牌认证OAuth 2.0认证OpenID Connect认证最不安全的就是HTTP认证中的基本认证,常用一般是令牌认证、OAuth 2.0认证

    3.4K31

    通过询问-响应身份认证提高桌面登录安全

    当然,它有我们熟悉的用户名密码登录方式,它也同样提供了其他的身份认证选项,比如生物识别、指纹、智能卡、一次性密码,甚至是 询问-响应(challenge-response)身份认证。...令牌会把另一个其存储的加密密钥通过 可插入式身份认证(Pluggable Authentication Module)模块(PAM)框架来响应询问。最后,Fedora 才会提示你输入密码。...一些询问-响应的方法,比如一次性密码(OTP),在硬件令牌上获取加密的代码密钥,然后将这个密钥通过网络传输到远程身份认证服务器。...如果身份认证服务器在本地网络上,这个方法非常好。但它的缺点是如果网络连接断开或是你在没有网的远程端工作。你会被锁在系统之外,直到你能通过网络连接到身份认证服务器。...如果有其他人获得了你的密码,他们在没有你的物理硬件 Yubikey 的情况下,仍然不能登录。恭喜!你已经显著提高了你的工作环境登录的安全性了。

    1K20

    在 ASP.NET Core 中实现幂等 REST API

    幂等性是 REST API 的一个关键概念,可确保系统的可靠性和一致性。幂等操作可以重复多次,而不会更改初始 API 请求之外的结果。...在 API 中实现幂等性有几个好处: 它可以防止意外的重复操作 它提高了分布式系统的可靠性 它有助于处理网络问题并正常重试 在本周的期刊中,我们将探讨如何在 ASP.NET Core API 中实现幂等性...它显著提高了 API 的可靠性,尤其是在网络问题可能导致重试请求的分布式系统中。通过实施幂等性,可以防止由于客户端重试而发生的重复操作。 哪些 HTTP 方法是幂等的?...这可以防止滥用幂等密钥并保持 API 的完整性。 在 REST API 中实现幂等性可以提高服务的可靠性和一致性。它确保相同的请求产生相同的结果,防止意外的重复并妥善处理网络问题。...专注于 API 中的关键操作,尤其是那些修改系统状态或触发重要业务流程的操作。 通过采用幂等性,您可以构建更强大且用户友好的 API。

    63610

    Spring Cloud Task 任务执行-通过调用 REST API 启动任务

    Spring Cloud Task提供了REST API来启动任务。通过REST API启动任务使我们能够从其他应用程序或脚本中启动任务,从而进一步提高了任务的可用性和灵活性。...创建任务在使用REST API启动任务之前,我们需要先定义一个任务。...以下是使用REST API启动任务的示例:POST /tasks/execute?...我们还可以通过在请求正文中添加任务参数来传递任务参数。例如,以下是使用REST API传递任务参数的示例:POST /tasks/execute?...任务执行逻辑可以通过使用@Value注释将这些参数注入到任务中来使用这些参数。监控和管理任务一旦启动了任务,我们可以使用Spring Cloud Task提供的API和UI来监控和管理任务。

    1.7K20

    用ASP.NET Core 2.0 建立规范的 REST API -- 预备知识

    REST的原则/约束 REST有6大原则/约束, 每一个原则都是对API有正面或负面影响的设计决定....RESTful API 最关心的有这几方面: 性能, 可扩展性, 简洁性, 互操作性, 通讯可见性, 组件便携性和可靠性. 这些方面被封装在REST的6个原则里, 它们是:  1....在ASP.NET Core项目里可以通过多种方式来创建Controller,当然最建议的方式还是通过继承AspNetCore.Mvc.Controller这个抽象类来建立Controller。...实体验证 ASP.NET Core内置的实体验证是通过验证属性标签来实现的,大多数情况下这样会很方便。 例如: ?...在REST服务里,有个词叫内容协商,它表示客户端通过Accept Header里的media-type来指定所需的结果格式。

    2.2K00

    用ASP.NET Core 2.0 建立规范的 REST API -- GET 和 POST

    本文所需的一些预备知识可以看这里: http://www.cnblogs.com/cgzl/p/9010978.html 和 http://www.cnblogs.com/cgzl/p/9019314.html 本文介绍的是使用ASP.NET...使用GUID作为主键的好处就是: 可以切换数据库 一定层度上隐藏了内部实现细节 通过HTTP方法与资源交互 针对项目里的Country这个资源, 请参考下面这个列表: ?...处理异常 当Action发生异常的时候,默认情况下ASP.NET Core会返回500: ? ? 但还是自己处理一下比较好,可以在Action里面使用try catch: ?...的情况下,就该返回一个默认的格式,在ASP.NET Core 2.0里面就是application/json。...ASP.NET Core 支持输出和输入两种格式化器。 输出的media type在accept header里面,而输入的media type在content-type header里面。

    2.1K10

    通过 SCF Component 轻松构建 REST API,再也不用熬夜加班了

    当一个应用需要对第三方提供服务接口时,REST API 无疑是目前最主流的选择。不过,如果自建 REST API,开发者需要购买虚拟机、配置环境等等,等一切都搞定,可能已经又是一个深夜。...本教程将分享如何通过 Serverless SCF Component 、云函数 SCF 及 API 网关组件,快速构建一个 REST API ,并实现 GET/PUT 操作。 ?...测试 通过如下命令测试 REST API 的返回情况: 注:如 Windows 系统中未安装 curl,也可以直接通过浏览器打开对应链接查看返回情况 curl -XGET http://service-...移除 可以通过以下命令移除 REST API 应用 sls remove --debug DEBUG ─ Flushing template state and removing all components...您可以通过该模板快速开发业务 REST API、扩展代码,探索更丰富的场景。

    1K32

    用ASP.NET Core 2.0 建立规范的 REST API -- 预备知识 + 项目准备

    REST的原则/约束 REST有6大原则/约束, 每一个原则都是对API有正面或负面影响的设计决定....RESTful API 最关心的有这几方面: 性能, 可扩展性, 简洁性, 互操作性, 通讯可见性, 组件便携性和可靠性. 这些方面被封装在REST的6个原则里, 它们是:  1....在ASP.NET Core项目里可以通过多种方式来创建Controller,当然最建议的方式还是通过继承AspNetCore.Mvc.Controller这个抽象类来建立Controller。...实体验证 ASP.NET Core内置的实体验证是通过验证属性标签来实现的,大多数情况下这样会很方便。...在REST服务里,有个词叫内容协商,它表示客户端通过Accept Header里的media-type来指定所需的结果格式。

    3K72

    用ASP.NET Core 2.1 建立规范的 REST API -- 翻页排序过滤等

    (从ASP.NET Core 2.0 迁移至 ASP.NET Core 2.1: https://docs.microsoft.com/en-us/aspnet/core/migration/20_21...所以如果返回这样的数据就违反了REST的规则了(尽管本文代码的Richardson成熟度最多也就是2级),它违反了自我描述的约束(请参考本系列的预备知识文章),API消费者不知道如何通过application...通过之前的方法分别创建出两个链接,然后把翻页相关的数据组成一个匿名类,使用JSON.NET将其串行化,并放到响应的自定义Header:“X-Pagination”里面。...而搜索呢,是通过一个搜索关键字来模糊的筛选集合资源,可能会有多个属性针对这个关键字进行模糊筛选。 搜索的URI大致是下面的形式: http://localhost/api/countries?...该方法可以在Startup里面调用,从而注册到ASP.NET Core的服务容器里: ? 然后再次修改CountryRepository: ?

    1.6K10

    通过saml统一身份认证登录腾讯云控制台实战

    首先,它是一种XML格式的语言;然后,它是用来安全地验证身份的。目前SAML有两标准:Saml 1.1和Saml 2.0。 二:常用场景 saml常用场景是用来作为单点登录的。...三:目标效果 用户在网站https://authing.cn(或者其它提供idp身份认证的网站)登录后,访问设置好的登录链接 https://cloud.tencent.com/login/forwardIdp...五:SAML相关角色和登录流程 IDP(Identify Provider):身份提供商,上例中指的是Authing SP(Service Provider):服务提供商,这里指腾讯云 UA(User...Agent):用户   一句话解释流程:用户登录本地账号后,访问腾讯云资源,重定向到身份提供商处验证身份,验证成功后登录腾讯云。...image.png 上传上一步中生成的xml文档,身份提供商名字和代码处配置一致,审阅并完成配置 image.png 创建登录角色,最终用来映射成该角色登录 image.png 选择刚创建的身份提供商

    8.9K101

    用ASP.NET Core 2.0 建立规范的 REST API -- DELETE, UPDATE, PATCH 和 Log

    在REST API里,我们有时也会遇到这样的需求。我们暂时把这个方法叫做Upsert (Update + Insert) 。那么问题来了应该使用POST还是PUT呢?...然后通过patchDoc.ApplyTo()这个方法把patchDoc的操作依次附加给这个CityUpdateResource,这时候所有需要更新的值都体现在CityUpdateResource里了,而该对象其它的属性值则是数据库里的最新值...验证 为了进行输入验证(不验证输出),我们需要做以下三方面工作: 定义验证规则 检查验证规则 把验证错误信息发送给API的消费者 之前的文章也提到的ASP.NET Core里面定义验证规则的方式: Data...使用FluentValidation 安装FluentValidation,可以通过Nuget,Package Manager Console 或者 .net cli: 直接安装这个就可以: ?...最后还要为ASP.NET Core配置FluentValidation,在Startup的ConfigureServices方法里: ?

    2.4K20
    领券