密码管理和身份验证
访问认证:为 Web 页面接入身份验证
只需简单配置且无需改造任何既有代码,xpw-locker
可快速为任何 Web 页面启用身份验证。
xpw-locker
是一个轻量级的 Web 代理服务,它在用户通过身份验证后,将用户请求转发到目标服务器并返回响应。
xpw-locker
的工作流程如下:
- 首先检查用户的 session_id 是否在 cookies 中。
- 如果 session_id 不在 cookies 中,
xpw-locker
会分配一个新的 session_id,并将其增加至用户的 cookies 中,然后xpw-locker
向用户返回重定向请求以刷新页面。 - 如果 session_id 已在 cookies 中,
xpw-locker
会检查 session_id 是否需要进行验证。 - 如果 session_id 无需登录,
xpw-locker
会将用户用户请求转发到目标服务器并返回响应。 - 如果 session_id 需要登录,
xpw-locker
会渲染登录页面并响应,用户输入用户名和密码后提交登录请求。 - 如果用户名和密码验证成功,
xpw-locker
会将登记 session_id 信息,然后xpw-locker
向用户返回重定向请求以刷新页面。 - 如果用户名和密码验证成功,
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
pip install --upgrade xpw
创建配置文件 xpwauth
并增加用户和密码:
[users]
demo = "demo"
xpw-locker --stdout --debug --target https://example.com/