プログラミング学習

【Python】ログイン機能を作る「Flask-Login」⑦

投稿日:

「ログイン機能を作る」【Part7】。
前回は「データベース」の設定を追加しました。
今回は「ログイン処理」の部分を変更していこうと思います。

ログイン処理を変更しよう

「名前」に「ANDoblog」,「メールアドレス」に「test@mail」と入力しないとログインできない仕様となっていましたね。

今回は「データベース」に登録されている「アカウント」と「入力されたデータ」を照合しログインできるような処理を書いていきます。

データベースにアカウントを登録しよう

あらかじめ「データベース」に「アカウント」を登録し照合してみます。

アカウントの登録は「DB Browser for SQLite」を使用します。

「login.py」を実行して、データベースに「テーブル」を作成(db.create_all())しましょう。

「DB Browser for SQLite」についてはこちら。

これで「User」テーブルが作成されました。
では「アカウント」を追加してみましょう。

「新しいレコード」を挿入します。

この部分を変更していきましょう。

「name」に「testuser」,「mail」に「test@test」と入力しました。
最後に「変更を書き込み」を押して更新しましょう。

ログイン処理を書き込もう

あとは「ログイン処理」を書いていきます。

from flask import Flask, render_template, redirect
from flask_login import LoginManager, login_required, UserMixin, login_user, logout_user
from flask_wtf import FlaskForm
from wtforms import StringField, SubmitField
from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__)
login_manager = LoginManager()
login_manager.init_app(app)
app.config['SECRET_KEY'] = "secret"

db_uri = 'sqlite:///login.db'
app.config['SQLALCHEMY_DATABASE_URI'] = db_uri
db = SQLAlchemy(app)

class User(UserMixin, db.Model):
    __tablename__ = 'User'
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.Text())
    mail = db.Column(db.Text())
    def __init__(self, name, mail):
      self.name = name
      self.mail = mail

db.create_all()

class LoginForm(FlaskForm):
  name = StringField('名前')
  mail = StringField('メールアドレス')
  submit = SubmitField('ログイン')

@login_manager.user_loader
def load_user(user_id):
  return User.query.get(int(user_id))

@app.route('/')
def index():
  return render_template('top.html')

@app.route('/member')
@login_required
def member():
  return render_template('member.html')

--------------------------------------------------------------------------------------------

@app.route('/login', methods=['GET','POST'])
def login():
  form = LoginForm()
  if form.validate_on_submit():
    if User.query.filter_by(name=form.name.data, mail=form.mail.data).one_or_none():
      user = User.query.filter_by(name=form.name.data).one_or_none()
      login_user(user)
      return redirect('/member')
    else:
      return 'ログインに失敗しました'
  return render_template('login.html',form=form)

--------------------------------------------------------------------------------------------

@app.route('/logout')
def logout():
  logout_user()
  return render_template('logout.html')

if __name__ == "__main__":
    app.run(host="localhost", debug=True)

これで動いてくれるでしょう。

では試してみます。

ログインしてみよう

では動画でご覧ください。

以前のように「ANDoblog」,「test@mail」ではログインできませんね。

アカウントデータに基づいてログインできています。

まとめ

無事ログイン処理が実行されました。
次回は「新規アカウント作成」の機能を作っていきたいですね。
それではまた。

-プログラミング学習
-

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

関連記事

【Python】リサイズした画像をExcelに貼ってみよう

前回は、画像を「openpyxl」でExcelシートに貼り付けることができました。今回は「OpenCV」を使って、リサイズしてから画像を貼り付けてみたいと思います。 リサイズした画像を貼ってみよう O …

【SQLite】DBブラウザを使ってみよう

「SQLite」を「GUI」で管理できるものがあることを知りました。それが「DB Browser for SQLite」です。今回はこの「DBブラウザ」について紹介します。 DBブラウザを使ってみよう …

【Python】VBAをPythonで再現してみる①

以前に「エクセル」で出来るプログラミングとして「VBA」を紹介しましたが今回は「Python」でその中身を再現していきたいと思います。 VBAをPythonで再現してみよう 「VBA(Visual B …

VBAでお仕事効率化

みなさんはExcelを仕事で使用していますか?Excelの中には「VBA」というものが搭載されています。この「VBA」が使えればいつものルーティンワークも自動化することができます。今回は「VBA」の使 …

【Python】Flaskで掲示板を作ってみよう②

「Flaskで掲示板を作ってみよう①」から、間が空きましたが続きを書いていきたいと思います。今回は、実際に動作したコードを紹介します。 前回の記事はこちら 【Python】Flaskで掲示板を作ってみ …