1

我已经创建了一个相当严格的 Flask/Python 应用程序示例,然后我决定将代码拆分为两个文件,因此我将身份验证的所有装饰器移动到单独的文件中,如下所示:

#### test.py
from flask import Flask, request, abort, request, make_response, url_for, jsonify
from flask.ext.httpauth import HTTPBasicAuth
import pypyodbc, json, collections, _db, _sc
from customauth import CustomHTTPBasicAuth

app = Flask(__name__)
app.debug = True

from werkzeug.debug import DebuggedApplication
application = DebuggedApplication(app, evalex=True)

@app.errorhandler(400)
def not_found(error): return make_response(jsonify( { 'error': 'Bad request' } ), 400)
@app.errorhandler(404)
def not_found(error): return make_response(jsonify( { 'error': 'Not found' } ), 404)

auth = CustomHTTPBasicAuth()

@app.route('/hello')
@auth.login_required
def hello_world():
    name = request.args.get('name','')
    return 'Hello ' + name + '!'

if __name__ == '__main__':
    app.run()



#### customauth.py
from flask import Flask, jsonify, make_response, request
from flask.ext.httpauth import HTTPBasicAuth
import md5, socket

class CustomHTTPBasicAuth(HTTPBasicAuth):
    def __init__(self):
    super(CustomHTTPBasicAuth, self).__init__()

        @self.get_password
        def get_password(username):
            if (md5.new(username).hexdigest() == '0cc175b9c0f1b6a831c399e269772661'): #'0cc175b9c0f1b6a831c399e269772661' is md5('a')
                return '0cc175b9c0f1b6a831c399e269772661'
            return None 

        @self.hash_password
        def custom_authenticate(password):
            return '0cc175b9c0f1b6a831c399e269772661'

        @self.error_handler
        def unauthorized():
            return make_response(jsonify( { 'error': 'Unauthorized access' } ), 401)

#### wsgi.py
import sys
sys.path.insert(0, "c:/testflask/test")

from flask1 import app
application = app
  1. 第一个问题是:此代码在使用python test.py执行时工作正常 验证表单将弹出询问用户名和密码,输入“a”后,“a”验证将通过并显示结果“Hello + 不管”。但是当通过 Apache mod_wsgi 执行时,它不会按预期运行身份验证表单将显示无限次。请有人可以解释在 python 下而不是在 mod_wsgi 下运行的这段代码,有没有办法解决这个问题?我在想我在装饰器上做错了,但我不确定是什么,它也没有回答为什么它是通过 python 而不是通过 mod_wsgi 运行的。

  2. 另一件事是如何通过 apache mod_wsgi 而不是“内部服务器错误”页面获取调试页面?我尝试过使用“werkzeug.debug”和互联网上的其他一些建议,但没有什么对我真正有用。

谢谢,

#

我找到了第一个项目符号的解决方案,它是 Apache 设置,唯一需要的是在配置文件中添加 WSGIPassAuthorization On。

仍在尝试找到调试解决方案...

4

1 回答 1

0

如果 Flask 调试器检测到它在多进程配置中运行,则它可能无法工作,如果您使用嵌入式模式,mod_wsgi 通常会出现这种情况。确保您使用的是 mod_wsgi 的守护进程模式:

WSGIDaemonProcess mysite
WSGIProcessGroup mysite

注意,不要将 'processes=1' 设置为 WSGIDaemonProcess。让它默认为 1。使用带有任何值的 'processes' 选项将导致 wsgi.multiprocess 为 True,这可能是导致 Flask 调试器被禁用的原因。

于 2013-09-17T12:45:29.683 回答