HTTP请求头中的Authorization

当使用HTTP请求中的Authorization头时,表示传入的是认证信息。具体的认证类型由凭证前缀指明。以下是Authorization头中常见的几种认证机制:

  1. 基本认证(Basic Authentication):

    bash 复制代码
    Authorization: Basic base64(用户名:密码)

    这是最常见的一种,涉及将用户名和密码以base64格式编码并与请求一起发送。需要注意,Basic 后面有空格, 未使用HTTPS时基本认证不够安全。 实际使用例子,比如:

    bash 复制代码
    curl -u "admin:P@88w0rd" -H "Accept: application/json" http://localhost:8090/api/v1alpha1/users

    curl -u "username:password" 就相当于在请求的请求头中添加keyAuthorizationvalueadmin:P@88w0rd,这是一种认证方式。 对账号密码进行base64编码之后

    bash 复制代码
    echo -n "admin:P@88w0rd" | base64

    得到:YWRtaW46UEA4OHcwcmQ= ,上方的curl也可以写成:

    bash 复制代码
    curl -H "Authorization: Basic YWRtaW46UEA4OHcwcmQ=" -H "Accept:  application/json" http://localhost:8090/api/v1alpha1/users
  2. Bearer令牌(Bearer Token):

    makefile 复制代码
    Authorization: Bearer <令牌>

    这通常与OAuth 2.0一起使用。<令牌>通常是通过单独的认证过程获取的长寿命访问令牌。

  3. 摘要认证(Digest Authentication):

    ini 复制代码
    Authorization: Digest username="用户名", realm="领域", nonce="随机数", uri="URI", response="响应", opaque="opaque", qop=auth, nc=00000001, cnonce="cnonce"

    摘要认证比基本认证更安全,涉及挑战-响应机制来验证客户端。挑战-响应机制(Challenge-Response Mechanism,在这种机制中,服务器通过向客户端发送一个随机的挑战(challenge),并期望客户端使用其凭据(通常是密码)生成一个对应的响应(response)来证明其身份,服务端收到响应后验证身份)

  4. API密钥(API Key):

    makefile 复制代码
    Authorization: ApiKey <API密钥>

    API密钥通常用于API请求中的身份验证。密钥包含在Authorization头中。

  5. Bearer令牌(JWT):

    makefile 复制代码
    Authorization: Bearer eyJhbGciOiJIUzI1NiIsIn...

    JSON Web Tokens(JWT)通常在现代身份验证系统中使用。令牌包含在Bearer方案中。

  6. 自定义方案(Custom Schemes): 一些应用程序或服务可能定义了自己的自定义认证方案。例如:

    makefile 复制代码
    Authorization: CustomScheme 自定义数据

以上的使用的scheme,如BasicBearer,Digest,ApiKey是约定俗成的,大家都这样使用,具体认证类型取决于服务器的要求和实现的协议,针对自己的业务也可以自定义scheme。也可以参考正在与之交互的服务或API的文档,以确定Authorization头的正确格式。

相关推荐
上进小菜猪23 分钟前
基于 Rokid CXR-S SDK 的智能提词器开发全解析——AI 应答辅助系统
后端
Rust语言中文社区33 分钟前
【Rust日报】 丰田“先锋”选择了 Rust
开发语言·后端·rust
椎49533 分钟前
苍穹外卖资源点整理+个人错误解析-Day10-订单状态定时处理(Spring Task)、来单提醒和客户催单
java·后端·spring
努力的小雨36 分钟前
从零跑起 RokidDemo:开发小白也能搞定的入门实践
后端
p***629942 分钟前
CVE-2024-38819:Spring 框架路径遍历 PoC 漏洞复现
java·后端·spring
Lisonseekpan42 分钟前
Java分词器深度评测与实战指南
java·开发语言·后端
c***87191 小时前
Flask:后端框架使用
后端·python·flask
aiopencode1 小时前
iOS 应用性能测试的系统化实践,构建从底层分析到真机回归的多工具协同体系
后端
举大栗子2 小时前
基于Java的Socket.IO服务端基础演示
后端
用户69371750013842 小时前
14.Kotlin 类:类的形态(一):抽象类 (Abstract Class)
android·后端·kotlin