我是Web开发和Python的新手,尝试使用python flask创建一个facebook应用程序。在本教程中找到了一些我用来开始使用的代码:http://ryaneshea.com/facebook-authentication-for-flask-apps
Facebook OAuth身份验证正常运行,用户首次使用应用时会要求他们向应用授予权限。之后,它们应该被重定向到应用程序索引站点。如果在Facebook中使用该应用程序,则会给出消息:“405方法不允许”。如果从Facebook外部(从我的apache web服务器)使用该应用程序,重定向将起作用。
当从Facebook外部使用应用程序时,只会发出GET请求,但是当从Facebook内部使用时,这是发出405错误的POST请求:
"POST /?fb_source=search&ref=br_tf HTTP/1.1""
有关如何接受来自Facebook的POST请求的任何建议,以便可以重定向用户吗?
以下是代码的相关部分:
from flask import render_template, url_for, request, session, redirect
from flask_oauth import OAuth
oauth = OAuth()
facebook = oauth.remote_app('facebook',
base_url='https://graph.facebook.com/',
request_token_url=None,
access_token_url='/oauth/access_token',
authorize_url='https://www.facebook.com/dialog/oauth',
consumer_key=FACEBOOK_APP_ID,
consumer_secret=FACEBOOK_APP_SECRET,
request_token_params={'scope': 'email, '}
)
app = Flask(__name__)
@facebook.tokengetter
def get_facebook_token():
return session.get('facebook_token')
def pop_login_session():
session.pop('logged_in', None)
session.pop('facebook_token', None)
@app.route("/")
def index():
return render_template('index.html')
@app.route("/facebook_login")
def facebook_login():
return facebook.authorize(callback=url_for('facebook_authorized',
next=request.args.get('next'), _external=True))
@app.route("/facebook_authorized")
@facebook.authorized_handler
def facebook_authorized(resp):
next_url = request.args.get('next') or url_for('index')
if resp is None or 'access_token' not in resp:
return redirect(next_url)
session['logged_in'] = True
session['facebook_token'] = (resp['access_token'], '')
return redirect(next_url)
答案 0 :(得分:3)
我通过为适当的路由指定GET和POST方法来修复它。不得不重新启动apache以使其正常工作。
这是语法:
@app.route("/facebook_authorized", methods=['GET', 'POST'])