Loading

Quipoin Menu

Learn • Practice • Grow

flask / User Authentication
tutorial

User Authentication

User authentication allows users to register, log in, and log out. Flask‑Login manages sessions and protects routes.

Installing Flask‑Login

pip install flask-login

Setting Up Flask‑Login

from flask_login import LoginManager, UserMixin, login_user, current_user, logout_user, login_required

login_manager = LoginManager(app)
login_manager.login_view = 'login'

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

Update User Model (Inherit UserMixin)

class User(db.Model, UserMixin):
# existing columns...

Registration Route

Hash the password using `werkzeug.security` before storing.
from werkzeug.security import generate_password_hash

hashed_pw = generate_password_hash(password, method='sha256')
new_user = User(username=username, email=email, password=hashed_pw)
db.session.add(new_user)
db.session.commit()

Login Route

from werkzeug.security import check_password_hash

@app.route('/login', methods=['GET', 'POST'])
def login():
# ...
user = User.query.filter_by(email=email).first()
if user and check_password_hash(user.password, password):
login_user(user)
return redirect(url_for('home'))
# ...

Logout and Protected Routes

@app.route('/logout')
@login_required
def logout():
logout_user()
return redirect(url_for('home'))


Two Minute Drill
  • Flask‑Login manages user sessions.
  • User model must inherit `UserMixin`.
  • Hash passwords with `generate_password_hash`.
  • Use `login_user()` and `logout_user()` for session control.
  • Protect routes with `@login_required`.

Need more clarification?

Drop us an email at career@quipoinfotech.com