2

私はフラスコログインを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 リクエストを作成した後、メインの定義を取得しようとしたように見えますが、システムはログイン ページを許可せず、再度返します。

4

1 に答える 1