私はフラスコログインをpostgreSQLと組み合わせて作業しています。いつでも、特定の定義にリダイレクトしない定義の前に @login_required デコレータを持っています。ここに私のコード:
初期化.py
app = Flask(__name__)
app.config.from_object('config')
db = SQLAlchemy(app)
lm = LoginManager()
lm.init_app(app)
lm.login_message = "Login please"
lm.login_view = "signin"
from app import views
私のモデル:
class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(150))
user_name = db.Column(db.String(80), unique=True)
password = db.Column(db.String(64))
role = db.Column(db.Integer)
activate = db.Column(db.Boolean)
def is_authenticated(self):
return True
def is_active(self):
return self.activate
def is_anonymous(self):
return False
def get_id(self):
try:
return unicode(self.id) # python 2
except NameError:
return str(self.id) # python 3
そしてここに私の見解:
@lm.user_loader
def load_user(id):
return User.query.get(int(id))
@app.route('/signin', methods=['GET', 'POST'])
def signin():
form = LoginForm()
if request.method == "POST":
if current_user is not None and current_user.is_authenticated():
return redirect(url_for('first'))
user = User.query.filter(User.user_name == form.user_name.data, User.password == form.password.data).first()
login_user(user, remember=True)
session['signed'] = True
session['username'] = user.user_name
if session.get('next'):
next_page = session.get('next')
session.pop('next')
return redirect(next_page)
else:
return redirect(url_for('first'))
else:
session['next'] = request.args.get('next')
return render_template('log_in.html', form=form)
@app.route('/')
def first():
return render_template("layout.html")
@app.route('/main')
@login_required
def main():
return render_template("main.html")
したがって、ここから、url: localhost:5000/main にアクセスするたびに、ログイン ページが表示されます (まだログインしていない場合)。その後、入力を入力して、コマンド ラインにあるものを作成します。
127.0.0.1 - - [09/Mar/2015 00:37:39] "GET /signin?next=%2Fmain HTTP/1.1" 200 -
127.0.0.1 - - [09/Mar/2015 00:37:47] "POST /signin HTTP/1.1" 302 -
127.0.0.1 - - [09/Mar/2015 00:37:47] "GET /main HTTP/1.1" 302 -
127.0.0.1 - - [09/Mar/2015 00:37:47] "GET /signin?next=%2Fmain HTTP/1.1" 200 -
POST リクエストを作成した後、メインの定義を取得しようとしたように見えますが、システムはログイン ページを許可せず、再度返します。