首页
学习
活动
专区
圈层
工具
发布

5个REST API安全准则

必须确保传入的HTTP方法对于会话令牌/API密钥和相关资源集合,操作和记录都是有效的。 例如,如果您有一个RESTful API的库,不允许匿名用户删除书目录条目,但他们可以获得书目录条目。...当设计REST API时,不要只使用200成功或404错误。 以下是每个REST API状态返回代码要考虑的一些指南。 正确的错误处理可以帮助验证传入的请求,并更好地识别潜在的安全风险。...200 OK -回应一个成功的REST API的行动。HTTP方法可以是GET,POST,PUT,PATCH或DELETE。 400错误请求 -请求格式错误,如消息正文格式错误。...401未授权 -错误或没有提供任何authencation ID /密码。 403禁止 -当身份验证成功,但身份验证的用户没有权限使用请求的资源。 404未找到 -当请求一个不存在的资源。...405不允许的方法 -意外的HTTP方法的错误检查。 例如,RestAPI期待HTTP GET,但使用HTTP PUT。

5.1K10

从0开始构建一个Oauth2Server服务 资源服务器

另一种选择是使用Token Introspection规范来构建 API 来验证访问令牌。...过期令牌 如果您的服务使用短期访问令牌和长期刷新令牌,那么您需要确保在应用程序使用过期令牌发出请求时返回正确的错误响应。...返回带有标头的 HTTP 401 响应,WWW-Authenticate如下所述。如果您的 API 通常返回 JSON 响应,那么您也可以返回具有相同错误信息的 JSON 正文。...错误代码和未经授权的访问 如果访问令牌不允许访问所请求的资源,或者如果请求中没有访问令牌,则服务器必须使用 HTTP 401 响应进行回复,并在响应中包含一个标头WWW-Authenticate。...invalid_token(HTTP 401) – 访问令牌已过期、撤销、格式错误或由于其他原因无效。客户端可以获取新的访问令牌并重试。

1.4K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Java 新手如何使用Spring MVC RestAPI的加密

    使用Spring Boot创建RestAPI 使用HTTPS加密RestAPI 使用Spring Security增加安全性 使用JWT实现令牌身份验证 使用Postman测试加密的RestAPI 结论...以下是一个简单的RestAPI示例,它返回一条简单的问候消息: @RestController public class GreetingController { @GetMapping("/greet...使用JWT实现令牌身份验证 为了更进一步提高安全性,我们可以使用JWT(JSON Web Token)来实现令牌身份验证。JWT是一种轻量级的令牌,通常用于在客户端和服务器之间传递身份验证信息。...我们可以使用createToken方法为已验证的用户创建令牌,然后在请求头中包含这个令牌以进行访问。 接下来,我们需要配置Spring Security,以使用JWT令牌进行身份验证。...如果JWT令牌有效,您将能够成功访问RestAPI并获得响应。 结论 在本文中,我们讨论了如何使用Spring MVC和一些加密技术来保护您的RestAPI。

    79410

    构建Vue项目-身份验证

    请求 关于API交互,我们可以使用与TokenService中相同的逻辑。...这样,如果您需要在其他组件中显示或操作相同的数据,将来便可以重用逻辑。 补充:如何刷新过期的访问令牌? 关于身份验证,要处理令牌刷新或401错误(token失效)比较困难,因此被许多教程所忽略。...在某些情况下,最好是在发生401错误时简单地注销用户,但是让我们看看如何在不中断用户体验的情况下刷新访问令牌。这是上面提到的代码示例中的401拦截器。...如果是,则我们正在检查401是否在令牌刷新调用本身上发生(我们不想陷入循环中) 永久刷新令牌!)。然后,代码将刷新令牌并重试失败的请求,并将响应返回给调用方。...通过保存刷新令牌promise,并向每个刷新令牌请求返回相同的promise,我们可以确保令牌仅刷新一次。 您还需要在设置请求header之后立即在main.js中安装401拦截器。

    8.6K20

    Salesforce Integration 概览(五) Remote Call-In(远程操作 外部->salesforce)

    使用restapi复合资源在一个API调用中进行一系列更新。 •REST复合资源使用这些REST API资源在单个API调用中执行多个操作。也可以使用一个调用的输出作为下一个调用的输入。...流程草图 下图说明了在使用RESTAPI(用于外部事件的通知)或SOAP API(用于查询Salesforce对象)实现此模式时的事件序列。使用restapi时,事件的顺序是相同的。...在任何一种情况下,客户机都必须使用适当的值设置授权HTTP头(OAuth访问令牌或会话ID可以通过对soapapi的登录调用获得)。...然后,远程系统使用适当的动词生成REST调用(HTTP请求),并处理返回的结果(支持JSON和XML数据格式)。...Bulk API 2.0 bulkapi2.0是一个基于REST的API,因此应用了与restapi相同的调用机制。

    3.9K20

    flask 应用程序编程接口(API)最后一节

    当API客户端收到401状态码时,它知道它需要向用户询问凭证,但是它是如何实现的,服务器不需要关心。 用户模型中实现令牌 对于API身份验证需求,我将使用令牌身份验证方案。...保存在g.current_user中,盔甲我可以从API视图函数中访问它。 错误处理函数只返回由app / api / errors.py模块中的error_response()函数生成的401错误。...) 使用令牌认证时,Flask-HTTPAuth使用的是verify_token装饰器注册验证函数,另外,令牌认证的工作方式与基本认证相同。...请注意,装饰器被添加到除create_user()之外的所有API视图函数中,例如,此函数不能使用令牌认证,因为用户都不存在时,更不会有令牌了。...如果您直接对上面列出的受令牌保护的端点发起请求,导致得到一个401错误。为了成功访问,您需要添加Authorization标题,其值是请求/ api / tokens获得的令牌的值。

    6.2K10

    什么是REST API

    其中包括: 「客户服务器分离模式」(Client-Server):系统A向系统B托管的URL发出HTTP请求,并返回一个响应。这与浏览器的工作方式相同。...换句话说,应该可以按照任何顺序发出两个或更多的HTTP请求,并且会收到相同的响应(除非API被设计为返回随机响应)。 「可缓存」(Cacheable):响应应该被定义为可缓存或不可缓存。...当发生错误时应该返回适当的状态码,比如说400 Bad Request,404 Not Found,401 Unauthorized等等。...使用CORS来限制客户端对特定域的调用。 提供最少的功能,也就是不要创建不需要的DELETE选项。 验证所有端点URL和body对象。 避免在客户端JavaScript中暴露API令牌。...阻止来自未知域名或IP地址的访问。 阻止意外的大型有效负载。 考虑速率限制,也就是使用同一API令牌或IP地址的请求被限制在每分钟N个以内。 以适当的HTTP状态代码和缓存头进行响应。

    6K20

    Django进阶篇 Rest framework (四)

    zoo_id=ID 的含义是相同的。 ⑦ 状态码 服务器向用户返回的状态码和提示信息,常见的有以下一些(方括号中是该状态码对应的 HTTP 动词)。 服务器成功返回用户请求的数据,该操作是幂等的。...400 INVALID REQUEST - [ POST/PUT/PATCH ] 表示用户没有权限(令牌、用户名、密码错误)。...401 Unauthorized - [*] 表示用户得到权限(与401错误相对),但是访问是被禁止的。...406 Not Acceptable - [GET] 用户请求的资源被永久删除,且不会再得到。 410 Gone - [GET] 当创建一个对象时,发生一个验证错误。...DELETE /collection/resource ⑩ Hypermedia API RESTful API 最好做到 Hypermedia,即返回结果中提供链接,连向其它 API 方法,使用户不查文档

    83030

    从0开始构建一个Oauth2Server服务 发起认证请求

    事实上,尝试解码访问令牌是危险的,因为服务器不保证访问令牌将始终保持相同的格式。下次您从该服务获取访问令牌时,完全有可能采用不同的格式。...例如,Google 的 API 使用 OpenID Connect 提供一个 userinfo 端点,该端点可以返回有关给定访问令牌的用户的信息,或者您可以改为从 ID 令牌获取用户信息。...虽然这是一个非常好的优化,但它不会阻止您仍然需要处理如果访问令牌在预期时间之前过期时 API 调用失败的情况。...您可以检查此特定错误消息,然后刷新令牌并再次尝试请求。 如果您使用的是基于 JSON 的 API,那么它可能会返回带有错误的 JSON 错误响应invalid_token。...这就是应用程序是否知道刷新令牌的预期寿命无关紧要的原因,因为无论它过期的原因如何,结果总是相同的。

    1.4K30

    从0到1开发测试平台(五)RESTful API接口设计标准及规范

    limit=10:指定返回记录的数量 https://api.example.com/v1/zoos?...offset=10:指定返回记录的开始位置 https://api.example.com/v1/zoos?...animal_type_id=1:指定筛选条件 四.安全性和幂等性 安全性:不会改变资源状态,可以理解为只读的; 幂等性:执行1次和执行N次,对资源状态改变的效果是等价的 安全性和幂等性均不保证反复请求能拿到相同的...401 Unauthorized - [*]:表示用户没有权限(令牌、用户名、密码错误)。 403 Forbidden - [*] 表示用户得到授权(与401错误相对),但是访问是被禁止的。...410 Gone -[GET]:用户请求的资源被永久删除,且不会再得到的。 422 Unprocesable entity - [POST/PUT/PATCH] 当创建一个对象时,发生一个验证错误。

    1.4K60

    mapbox没有tokentoken失效,地图闪烁后变空白,报错Error: A valid Mapbox access token is required to use Mapbox GL JS.

    To create an account or a new access token, visit https://account.mapbox.com/ 错误:使用Mapbox GL JS需要有效的...要创建帐户或新的访问令牌,请访问https://account.mapbox.com/ 这个错误是说你的mapbox验证令牌(token)失效了,需要到官网(https://account.mapbox.com...它的作用就是对你的token请求进行判断:如果含token的请求在mapbox服务器对应接口上没有拿到数据,返回状态码是401(即token无效),那么就报错:"A valid Mapbox access...修改完并保存 4、清除缓存 最后还有一步,我们要知道,项目一旦启动过,就会生成依赖缓存文件,后续启动只会更新代码更新的部分,不会检查依赖库的代码是否变化,所以需要清除依赖缓存文件,这里用...同时由于错误信息中提到了“the server responded with a status of 401 ()”,代表服务器返回了一个状态码为401的响应(正确的状态码应该是200)。

    1.3K00

    如何使用SpringMvc处理Rest异常

    你的restAPI越容易使用,他们就越可能用你的服务(译注:这年头,连要服务别人都竞争激烈) 。...状态/status “状态”属性是整型的,而且跟http状态码值相同。...对于那些有可能是中间结点返回的错误响应(常见的包括401、403、404、405、406、408、409、429、500、502、503、504)要特别注意,它们的响应体未必符合http接口文档里声明的格式...这里“上传文件”的例子看起来有点太刻意了,但这里关键是说你的API使用自定义的错误码,可以表达更丰富的错误信息。 提示:若你对某一特殊错误没有自定义错误码,那么可以让错误码属性的值=状态码的值。...让API使用者在使用时节省更多时间的事情,做得越多越好。  调试信息/developerMessage “调试信息”属性可以用来放与技术有关的信息,对调用你restAPI的开发者很有用。

    1.7K00

    RESTful接口入门 转

    一般来说,数据库中的表都是同种记录的”集合”(collection),所以API中的名词也应该使用复数。...zoo_id=ID 的含义是相同的。 状态码(Status Codes) 服务器向用户返回的状态码和提示信息,常见的有以下一些(方括号中是该状态码对应的HTTP动词)。...401 Unauthorized - [*]:表示用户没有权限(令牌、用户名、密码错误)。 403 Forbidden - [*] 表示用户得到授权(与401错误相对),但是访问是被禁止的。...410 Gone -[GET]:用户请求的资源被永久删除,且不会再得到的。 422 Unprocesable entity - [POST/PUT/PATCH] 当创建一个对象时,发生一个验证错误。...使用方法 由于RESTful接口返回的都是json格式的数据,做好对这些json处理即可。

    1K30

    Firefox 如何对发送的参数进行调试

    在网页或者 API 进行调试的时候,尤其是在 OAuth 调试的时候,我们希望能够调试发送到 API 的数据,这个时候如何进行调试呢?...假设我们要访问一个 API 的网址: http://localhost:8080/search/user 正常访问的时候,我们获得是 401 的错误,这是因为这个网址需要授权。...选择你已经访问过的网址列表,在上图中,返回的结果是 401。 单击 Resend 按钮,在弹出的对话框中选择 Edit and Resend。...在下一个界面中,你可以对你需要添加的参数进行编辑,你可以在这里添加你需要的 token 参数。 将上面的参数设置好以后,可以单击选择重新发送。...虽然你还会得到 401 的错误,这是因为你的 token 的错误情况,这个错误的情况是你的 API 提供的,与第一次完全不提供得到的 401 错误信息是不一样的。

    1.9K00

    以太坊区块链 Asp.Net Core的安全API设计 (下)

    3.require函数只是hxr对象的封装,可以轻松地向API层调用ajax。 4.load_data_btn单击处理程序对API层安全端点进行ajax调用。...这需要有效的accessToken才能工作,否则,API层将响应401 HTTP响应。 5.login_btn单击是一个两步功能。首先,它要求用户签署任意消息。...如果一切正常,客户端将检索coinbase,你将在页面上看到你的帐户: 如果你现在单击“请求数据”按钮,将获得HTTP响应401。...如果单击“登录”按钮,Metamask将提示你签名: 签名后,处理程序将对令牌端点进行ajax调用。在此阶段,身份验证方法不会检查任何签名,因此端点将始终发出JWT令牌。...结论 现在你拥有基本的知识和一个项目的骨架,可以使用以太坊保护你的Asp.Net Core 2 API。

    1.4K30

    微服务 day17:基于Zuul网关实现路由转发、过滤器

    还是认证服务返回明文数据 4**、前端携带cookie中的token身份令牌及jwt令牌访问资源服务** 前端请求资源服务需要携带两个token,一个是cookie中的身份令牌,一个是http header...4、解析申请令牌错误信息 当账号输入错误应该返回用户不存在的信息,当密码错误要返回用户名或密码错误信息,业务流程图如下: ?...修改申请令牌的程序解析返回的错误: 由于 restTemplate 收到400或401的错误会抛出异常,而 spring security 针对账号不存在及密码错误会返回 400 及 401,所以在代码中控制针对...,这里设置为空则取消默认的黑名单,如果设置了具体的头信息则不会传到下游服务 # ignoredHeaders: Authorization serviceId:推荐使用 serviceId,zuul...error:处理请求时发生错误调用 filterOrder:此方法返回整型数值,通过此数值来定义过滤器的执行顺序,数字越小优先级越高。

    4.4K20

    实现“永久登录”:针对蜻蜓Q系统的用户体验优化方案(前端uni-app+后端Laravel详解)-优雅草卓伊凡

    三、后端开发(PHP + Laravel)要做的内容我们假设使用 Laravel Sanctum(API 令牌认证)或 Laravel Passport(OAuth2 服务器)来实现。...请求拦截器(自动携带 Token 和 处理 401)这是实现自动刷新的核心。使用 uni.addInterceptor 拦截所有请求。...> { const { statusCode, data } = response; if (statusCode === 401) { // 遇到 401 未授权错误 if (!...登录页面在登录页面,当用户成功登录并选择“记住我”后,保存返回的所有令牌。...前端:负责安全地存储令牌,在每次请求时自动携带,并在收到 401 错误时自动尝试刷新令牌,实现无感登录。同时,在 App 启动时自动恢复登录状态。

    40810
    领券