我有一个简单的Flask应用程序,用于熟悉flask_httpauth
库。我可以通过浏览器登录,发出GET
请求,然后输入用户名和密码。我试图使用request
对http2lib进行相同操作,但它始终返回401未经授权访问。下面是我的Flask服务器代码:
from flask import Flask, jsonify, request
from flask_httpauth import HTTPDigestAuth
app = Flask(__name__)
app.config['SECRET_KEY'] = "asasdasd"
auth = HTTPDigestAuth()
users = {
"Tim":"1234",
"Susan": "bye"
}
@app.route('/greeting')
def greeting():
return "<h1>Welcome to Flask-HTTPAuth’s</h1>"
@app.route('/')
@auth.login_required
def index():
return "Hello"
@auth.get_password
def get_pw(username):
if username in users:
return users.get(username)
else:
return None
if __name__ == '__main__':
app.debug = True
app.run(host='0.0.0.0', port=5000)
对于请求,它也返回401:
import httplib2
if __name__ == '__main__':
h = httplib2.Http()
h.add_credentials('Tim','1234')
resp = h.request('http://localhost:5000/','GET')
print(resp)
谢谢您的帮助!
答案 0 :(得分:0)
那是因为在您的服务器上使用的是Digest auth和客户端Basic。
尝试将其更改为:
from flask_httpauth import HTTPDigestAuth
url = 'http://localhost:5000/'
requests.get(url, auth=HTTPDigestAuth('Time', '1234'))