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.5.tar.gz (17.5 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.5-py2.py3-none-any.whl (18.5 kB view details)

Uploaded Python 2Python 3

File details

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

File metadata

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

File hashes

Hashes for xpw-0.5.tar.gz
Algorithm Hash digest
SHA256 e413db119dbce179f5bde212e0e80970ea14000e8ec74c63702cc0fff6caf20a
MD5 eeb440f6f3c6c4f28269a851422d1f6a
BLAKE2b-256 088fee7fc96089201507f00f733c7dc07eb5e56aef9e59b141c87e2e6987ede5

See more details on using hashes here.

File details

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

File metadata

  • Download URL: xpw-0.5-py2.py3-none-any.whl
  • Upload date:
  • Size: 18.5 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.5-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 9754d357fef9d2b7e325a1279e47d7a2923eb2727e48841d3198b1d84c09d072
MD5 bc598574d0a4099fd7b90828ce38cd32
BLAKE2b-256 9d3d7aa384eb7fb8e983902172e9238062403d7501f3e8f8c9220b86fa1bac10

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