# Flask Cheatsheet ## Unique Features - Lightweight web framework - Jinja2 template engine - Werkzeug WSGI toolkit - URL routing - Flask extensions ## Routing ```python # Define a route @app.route('/url') def function_name(): # Route body return render_template('template.html') ``` ## Templates ```html {% for item in items %} {{ item.attribute }} {% endfor %} ``` ## Forms ```html
@app.route('/url', methods=['GET', 'POST']) def function_name(): if request.method == 'POST': field_name = request.form['field_name'] # Form handling code return redirect('/success') return render_template('template.html') ``` ## Database ```python # Connect to a database app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///database.db' db = SQLAlchemy(app) # Define a model class ModelName(db.Model): id = db.Column(db.Integer, primary_key=True) field_name = db.Column(db.String(255), nullable=False) # Create a migration flask db init flask db migrate flask db upgrade ``` ## Authentication ```python # User registration @app.route('/register', methods=['GET', 'POST']) def register(): form = RegistrationForm() if form.validate_on_submit(): user = User(username=form.username.data, email=form.email.data) user.set_password(form.password.data) db.session.add(user) db.session.commit() flash('Congratulations, you are now a registered user!') return redirect(url_for('login')) return render_template('register.html', title='Register', form=form) # User login @app.route('/login', methods=['GET', 'POST']) def login(): form = LoginForm() if form.validate_on_submit(): user = User.query.filter_by(username=form.username.data).first() if user is None or not user.check_password(form.password.data): flash('Invalid username or password') return redirect(url_for('login')) login_user(user, remember=form.remember_me.data) return redirect(url_for('index')) return render_template('login.html', title='Sign In', form=form) # User logout @app.route('/logout') def logout(): logout_user() return redirect(url_for('index')) ``` ## Resources - [Flask Documentation](https://flask.palletsprojects.com/) - [Flask Mega-Tutorial](https://blog.miguelgrinberg.com/post/the-flask-mega-tutorial-part-i-hello-world) - [Flask Extensions](https://flask.palletsprojects.com/en/2.0.x/extensions/)