401 HTTP错误码详解

一、请求头与身份认证

在HTTP协议中,客户端向服务器发送请求时需要在请求头中附带一些信息,其中 Authorization 字段用于在请求中传递凭据信息。有些接口需要进行身份认证才能够访问,若用户凭据错误或无效,则服务器会返回401错误码。

例如,在以下代码示例中,当请求头中未附带有效的Bearer Token时,则会返回401错误码。

import requests

response = requests.get(url="http://example.com/api/v1/data", headers={"Authorization": "Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c"})

if response.status_code == 401:
  print("Invalid or missing auth token")

二、会话超时

当用户登录后长时间不操作,或者会话时间到期后再次访问页面时,服务器可能会返回401错误码。这是因为在过期时间内未进行身份认证的话,会话失效。

为了避免会话失效,可以在每次用户访问时通过发送请求来快速刷新会话。下面的代码示例中,发送POST请求充当“心跳”机制,使得会话时间得以存活。

import requests

session = requests.Session()
login_data = {"username": "my_username", "password": "my_password"}
session.post(url="http://example.com/login", data=login_data)

while True:
    response = session.post(url="http://example.com/keepalive")

    if response.status_code == 401:
        print("Session expired, logging in again...")
        session.post("http://example.com/login", data=login_data)

三、跨域访问

由于浏览器的同源策略限制,如果一个Web页面中的JavaScript代码试图访问不属于本域名下的资源时,则会返回401错误码。这通常是因为跨域访问没有经过允许而发生的,用户可能会因此遭受跨站点攻击。

为了解决跨域访问问题,可以在服务器上设置响应头,允许跨域的访问。以下代码示例展示如何在服务器端使用Flask框架来实现访问不同域的资源。

from flask import Flask, jsonify, request
from flask_cors import CORS, cross_origin

app = Flask(__name__)
CORS(app)

@app.route("/")
def index():
    return jsonify({"message": "Hello World!"})

if __name__ == "__main__":
    app.run()

四、访问授权

有些资源可能需要授予特定的用户或用户组才能够访问,而服务器会在请求中检查用户的访问权限。如果用户没有合适的权限,则会返回401错误码。

以下代码示例中,服务器使用Flask-JWT-Extended库来检查请求。只有当请求包含正确的Token且用户有访问此资源的权限时,才会返回请求数据。

from flask import Flask, jsonify
from flask_jwt_extended import get_jwt_identity, jwt_required, JWTManager

app = Flask(__name__)
app.config["JWT_SECRET_KEY"] = "super-secret-jwt-key"
jwt = JWTManager(app)

@app.route("/")
@jwt_required
def index():
    current_user = get_jwt_identity()
    if current_user and current_user["type"] == "admin":
        return jsonify({"message": "Welcome to the admin panel!"}), 200
    else:
        return jsonify({"message": "You are not authorized to access this resource."}), 401

if __name__ == "__main__":
    app.run()

原创文章,作者:YMTJA,如若转载,请注明出处:https://www.506064.com/n/331444.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
YMTJAYMTJA
上一篇 2025-01-16 15:47
下一篇 2025-01-16 15:47

相关推荐

  • 为什么要加请求头(HTTP Header)?

    在进行网页抓取(Web Scraping)时,请求头(HTTP Header)扮演着非常重要的角色。请求头中包含了用户代理(User Agent)、cookie、referer等信…

    编程 2025-04-27
  • HTTP请求方式的选择:POST还是GET?

    对于使用xxl-job进行任务调度的开发者,通常需要发送HTTP请求来执行一些任务。但是在发送请求时,我们总是会遇到一个问题:是使用POST还是GET?下面将从多个方面对这个问题进…

    编程 2025-04-27
  • 如何快速发布http接口

    想要快速发布http接口,可以从以下几个方面入手。 一、选择合适的框架 选择合适的框架对于快速发布http接口非常重要。目前比较受欢迎的框架有Flask、Django、Tornad…

    编程 2025-04-27
  • Linux sync详解

    一、sync概述 sync是Linux中一个非常重要的命令,它可以将文件系统缓存中的内容,强制写入磁盘中。在执行sync之前,所有的文件系统更新将不会立即写入磁盘,而是先缓存在内存…

    编程 2025-04-25
  • 神经网络代码详解

    神经网络作为一种人工智能技术,被广泛应用于语音识别、图像识别、自然语言处理等领域。而神经网络的模型编写,离不开代码。本文将从多个方面详细阐述神经网络模型编写的代码技术。 一、神经网…

    编程 2025-04-25
  • Linux修改文件名命令详解

    在Linux系统中,修改文件名是一个很常见的操作。Linux提供了多种方式来修改文件名,这篇文章将介绍Linux修改文件名的详细操作。 一、mv命令 mv命令是Linux下的常用命…

    编程 2025-04-25
  • Python输入输出详解

    一、文件读写 Python中文件的读写操作是必不可少的基本技能之一。读写文件分别使用open()函数中的’r’和’w’参数,读取文件…

    编程 2025-04-25
  • nginx与apache应用开发详解

    一、概述 nginx和apache都是常见的web服务器。nginx是一个高性能的反向代理web服务器,将负载均衡和缓存集成在了一起,可以动静分离。apache是一个可扩展的web…

    编程 2025-04-25
  • 详解eclipse设置

    一、安装与基础设置 1、下载eclipse并进行安装。 2、打开eclipse,选择对应的工作空间路径。 File -> Switch Workspace -> [选择…

    编程 2025-04-25
  • git config user.name的详解

    一、为什么要使用git config user.name? git是一个非常流行的分布式版本控制系统,很多程序员都会用到它。在使用git commit提交代码时,需要记录commi…

    编程 2025-04-25

发表回复

登录后才能评论