我正在尝试使用FIWARE对用户进行身份验证。当我请求令牌时它返回404,但是我没有遇到访问代码请求的问题。 我的代码:
class OAuth2(object):
def __init__(self):
self.client_id = "<client_id>"
self.client_secret = "<client_secret>"
self.site = 'http://0.0.0.0:8000'
self.redirect_uri = "http://192.168.99.101:8000/auth"
self.authorization_url = '/oauth2/authorize'
self.token_url = '/oauth2/token'
def authorize_url(self, **kwargs):
oauth_params = {'response_type': 'code', 'redirect_uri': self.redirect_uri, 'client_id': self.client_id}
oauth_params.update(kwargs)
return "%s%s?%s" % (self.site, quote(self.authorization_url), urlencode(oauth_params))
def get_token(self, code, **kwargs):
url = "%s%s" % (self.site, quote(self.token_url))
data = {'grant_type': 'authorization_code', 'redirect_uri': self.redirect_uri, 'client_id': self.client_id, 'client_secret': self.client_secret, 'code': code}
data.update(kwargs)
response = requests.post(url, data=data)
content = response.content
if isinstance(response.content, str):
try:
content = json.loads(response.content)
except ValueError:
content = parse_qs(response.content)
else:
return content
在我的应用中,我调用authorize_url()来获取代码。
@app.route("/authenticate")
def authenticate():
auth_url = auth_app.authorize_url()
return redirect(auth_url)
之后,我通过回调网址获取代码,并调用get_token()方法:
@app.route('/auth', methods=['GET', 'POST'])
def auth():
error = request.args.get('error', '')
if error:
return "Error: " + error
code = request.args.get('code')
content = auth_app.get_token()
return render_template('index.html', content="content: " + content)
Github项目:https://github.com/I-am-Gabi/security-app/tree/master/2-BasicAuthentication/securityapp-ui/web
Fiware wiki:https://github.com/ging/fiware-idm/wiki/using-the-fiware-lab-instance
答案 0 :(得分:0)
尝试使用POST方法代替GET
答案 1 :(得分:0)
请检查您是否正确发送了授权标题