Skip to main content

Password management and authentication

Project description

xpw

密码管理和身份验证

xpw-locker

访问认证:为 Web 页面接入身份验证

只需简单配置且无需改造任何既有代码,xpw-locker 可快速为任何 Web 页面启用身份验证。

xpw-locker 技术原理

xpw-locker 是一个轻量级的 Web 代理服务,它在用户通过身份验证后,将用户请求转发到目标服务器并返回响应。

xpw-locker demo

xpw-locker 的工作流程如下:

  1. 首先检查用户的 session_id 是否在 cookies 中。
  2. 如果 session_id 不在 cookies 中,xpw-locker 会分配一个新的 session_id,并将其增加至用户的 cookies 中,然后 xpw-locker 向用户返回重定向请求以刷新页面。
  3. 如果 session_id 已在 cookies 中,xpw-locker 会检查 session_id 是否需要进行验证。
  4. 如果 session_id 无需登录,xpw-locker 会将用户用户请求转发到目标服务器并返回响应。
  5. 如果 session_id 需要登录,xpw-locker 会渲染登录页面并响应,用户输入用户名和密码后提交登录请求。
  6. 如果用户名和密码验证成功,xpw-locker 会将登记 session_id 信息,然后 xpw-locker 向用户返回重定向请求以刷新页面。
  7. 如果用户名和密码验证成功,xpw-locker 会再次渲染登录页面并响应。
sequenceDiagram
    participant user as User
    participant locker as xpw-locker
    participant server as Web Server
    autonumber

    user->>+locker: GET
    critical login_required
    option session_id not in cookies
        note right of locker: allocate session_id and set_cookie
        note right of locker: redirect
    option SESSIONS.verify(session_id)
        critical proxy
            locker->>+server: PROXY.request(request)
            rect rgb(255, 0, 0)
                break requests.ConnectionErroruser
                note over locker,server: Response("Bad Gateway", status=502)
                end
            end
            server->>-locker: Response
        end
    option session_id need login
        note right of locker: render login.html
    end
    locker->>-user: Response

    opt login
        note right of user: input username and password
        critical submit
            user->>+locker: POST
            critical login_required
            option verify success
                note right of locker: SESSIONS.sign_in(session_id)
                note right of locker: redirect
            option verify failure
                note right of locker: render login.html
            end
            locker->>-user: Response
        end
    end

    opt redirect
        user->>+locker: GET
        critical login_required
            note right of locker: SESSIONS.verify(session_id)
            critical proxy
                locker->>+server: PROXY.request(request)
                rect rgb(255, 0, 0)
                    break requests.ConnectionErroruser
                    note over locker,server: Response("Bad Gateway", status=502)
                    end
                end
                server->>-locker: Response
            end
        end
        locker->>-user: Response
    end

安装 xpw-locker

pip install --upgrade xpw

使用 xpw-locker

创建配置文件 xpwauth 并增加用户和密码:

[users]
    demo = "demo"
xpw-locker --stdout --debug --target https://example.com/

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

xpw-0.14.1.tar.gz (22.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

xpw-0.14.1-py2.py3-none-any.whl (24.9 kB view details)

Uploaded Python 2Python 3

File details

Details for the file xpw-0.14.1.tar.gz.

File metadata

  • Download URL: xpw-0.14.1.tar.gz
  • Upload date:
  • Size: 22.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for xpw-0.14.1.tar.gz
Algorithm Hash digest
SHA256 082f40baf198106810a26cfec4dfdeca958cf5f4f29b684a0ab7298fb6982f70
MD5 6654954eb32a4940404b24c158f99b8b
BLAKE2b-256 f2fecb9f0227911a0f286024c63e75ac5ed9d19939c8e325b159fd5bc5ec8b38

See more details on using hashes here.

File details

Details for the file xpw-0.14.1-py2.py3-none-any.whl.

File metadata

  • Download URL: xpw-0.14.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 24.9 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for xpw-0.14.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 4706f4ae77f255439d1e3e8617606676eca8d31f6b70355a2062974cb4535092
MD5 67b70df26e8d4d6bdf62c986b9bc46fa
BLAKE2b-256 5efd48ea3bc644e284b22752476afd2cdcc18d5fe662aa6f176129bd7a4025bf

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page