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.12.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.12-py2.py3-none-any.whl (24.7 kB view details)

Uploaded Python 2Python 3

File details

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

File metadata

  • Download URL: xpw-0.12.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.12.tar.gz
Algorithm Hash digest
SHA256 25ad97c7cca4e47d2aaedf3bc5b60772c7c8756348fd1113dd112d2bde415475
MD5 410139e24b3d1e52844f745eac6c4f22
BLAKE2b-256 35e500372d2fc45cee4464f693c584d8eb40df57b4a94cd4b09bf02b9333b431

See more details on using hashes here.

File details

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

File metadata

  • Download URL: xpw-0.12-py2.py3-none-any.whl
  • Upload date:
  • Size: 24.7 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.12-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 b2fed2bd9df6083c3d7581450cd8e418aa825710d63f4e1d94e0cc1a42863b59
MD5 084a009195240f6fc06b383402c93138
BLAKE2b-256 27ae353d48573c16938b2d1f08c50194509c509936ffec74b0539b57d9c7351e

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