当前位置: 首页 > wzjs >正文

专业网站设计服务商物联网平台介绍

专业网站设计服务商,物联网平台介绍,网店推广的作用是什么,网站维护服务基本内容flask学习2-应用(博客) 项目目录应用程序工厂连接到数据库建表初始化数据库文件蓝图和视图第一个视图:注册注册登录根据用户id查询用户注销模板基本布局注册登录注册用户静态文件博客蓝图索引创建更新-根据id查询更新-根据id更新删除使项目可安装描述项目安装项目测试覆盖率…

flask学习2-应用(博客)

    • 项目目录
    • 应用程序工厂
    • 连接到数据库
    • 建表
    • 初始化数据库文件
    • 蓝图和视图
      • 第一个视图:注册
        • 注册
        • 登录
        • 根据用户id查询用户
        • 注销
      • 模板
        • 基本布局
        • 注册
        • 登录
        • 注册用户
      • 静态文件
      • 博客蓝图
        • 索引
        • 创建
        • 更新-根据id查询
        • 更新-根据id更新
        • 删除
    • 使项目可安装
      • 描述项目
      • 安装项目
    • 测试覆盖率
      • Setup and fixture
    • 部署到生产环境
      • 构建和安装
      • 配置密钥
    • 使用生产服务器运行

项目目录

/home/user/Projects/flask-tutorial
├── flaskr/
│   ├── __init__.py
│   ├── db.py
│   ├── schema.sql
│   ├── auth.py
│   ├── blog.py
│   ├── templates/
│   │   ├── base.html
│   │   ├── auth/
│   │   │   ├── login.html
│   │   │   └── register.html
│   │   └── blog/
│   │       ├── create.html
│   │       ├── index.html
│   │       └── update.html
│   └── static/
│       └── style.css
├── tests/
│   ├── conftest.py
│   ├── data.sql
│   ├── test_factory.py
│   ├── test_db.py
│   ├── test_auth.py
│   └── test_blog.py
├── .venv/
├── pyproject.toml
└── MANIFEST.in
  • .gitignore

    .venv/*.pyc
    __pycache__/instance/.pytest_cache/
    .coverage
    htmlcov/dist/
    build/
    *.egg-info/
    

应用程序工厂

mkdir flaskr
flaskr/__init__.py
import osfrom flask import Flaskdef create_app(test_config=None):# create and configure the appapp = Flask(__name__, instance_relative_config=True)app.config.from_mapping(SECRET_KEY='dev',DATABASE=os.path.join(app.instance_path, 'flaskr.sqlite'),)if test_config is None:# load the instance config, if it exists, when not testingapp.config.from_pyfile('config.py', silent=True)else:# load the test config if passed inapp.config.from_mapping(test_config)# ensure the instance folder existstry:os.makedirs(app.instance_path)except OSError:pass# a simple page that says hello@app.route('/hello')def hello():return 'Hello, World!'return app
  • 在flask-tutorial中执行flask --app flaskr run --debug

  • http://127.0.0.1:5000/hello

连接到数据库

  • flaskr/db.py

    import sqlite3
    from datetime import datetimeimport click
    from flask import current_app, gdef get_db():if 'db' not in g:g.db = sqlite3.connect(current_app.config['DATABASE'],detect_types=sqlite3.PARSE_DECLTYPES)g.db.row_factory = sqlite3.Rowreturn g.dbdef close_db(e=None):db = g.pop('db', None)if db is not None:db.close()def init_db():db = get_db()with current_app.open_resource('schema.sql') as f:db.executescript(f.read().decode('utf8'))@click.command('init-db')
    def init_db_command():"""Clear the existing data and create new tables."""init_db()click.echo('Initialized the database.')sqlite3.register_converter("timestamp", lambda v: datetime.fromisoformat(v.decode())
    )# 注册应用程序
    def init_app(app):app.teardown_appcontext(close_db)app.cli.add_command(init_db_command)
    

建表

  • flaskr/schema.sql

    DROP TABLE IF EXISTS user;
    DROP TABLE IF EXISTS post;CREATE TABLE user (id INTEGER PRIMARY KEY AUTOINCREMENT,username TEXT UNIQUE NOT NULL,password TEXT NOT NULL
    );CREATE TABLE post (id INTEGER PRIMARY KEY AUTOINCREMENT,author_id INTEGER NOT NULL,created TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,title TEXT NOT NULL,body TEXT NOT NULL,FOREIGN KEY (author_id) REFERENCES user (id)
    );
    
  • flaskr/init.py

    def create_app():app = ...# existing code omittedfrom . import dbdb.init_app(app)return app
    
  • 初始化数据库文件

    $ flask --app flaskr init-db
    Initialized the database.
    

蓝图和视图

  • Flaskr 将有两个蓝图,一个用于身份验证函数,另一个 一个用于博客文章功能

flaskr/auth.py

import functoolsfrom flask import (Blueprint, flash, g, redirect, render_template, request, session, url_for
)
from werkzeug.security import check_password_hash, generate_password_hashfrom flaskr.db import get_dbbp = Blueprint('auth', __name__, url_prefix='/auth')

flaskr/init.py 注册身份验证

def create_app():app = ...# existing code omittedfrom . import authapp.register_blueprint(auth.bp)return app

第一个视图:注册

flaskr/auth.py

注册
@bp.route('/register', methods=('GET', 'POST'))
def register():if request.method == 'POST':username = request.form['username']password = request.form['password']db = get_db()error = Noneif not username:error = 'Username is required.'elif not password:error = 'Password is required.'if error is None:try:db.execute("INSERT INTO user (username, password) VALUES (?, ?)",(username, generate_password_hash(password)),)db.commit()except db.IntegrityError:error = f"User {username} is already registered."else:return redirect(url_for("auth.login"))flash(error)return render_template('auth/register.html')
登录
 @bp.route('/login', methods=('GET', 'POST'))
def login():if request.method == 'POST':username = request.form['username']password = request.form['password']db = get_db()error = Noneuser = db.execute('SELECT * FROM user WHERE username = ?', (username,)).fetchone()if user is None:error = 'Incorrect username.'elif not check_password_hash(user['password'], password):error = 'Incorrect password.'if error is None:session.clear()session['user_id'] = user['id']return redirect(url_for('index'))flash(error)return render_template('auth/login.html')
根据用户id查询用户
@bp.before_app_request
def load_logged_in_user():user_id = session.get('user_id')if user_id is None:g.user = Noneelse:g.user = get_db().execute('SELECT * FROM user WHERE id = ?', (user_id,)).fetchone()
注销
@bp.route('/logout')
def logout():session.clear()return redirect(url_for('index'))

创建、编辑和删除博客文章将要求用户 已登录。

flaskr/auth.py

# 此装饰器返回一个包装原始视图的新视图函数 它被应用于。新函数检查用户是否已加载,并且 否则重定向到登录页面。如果用户加载了原始 view 被调用并继续正常。在以下情况下,您将使用此装饰器 编写博客视图。
def login_required(view):@functools.wraps(view)def wrapped_view(**kwargs):if g.user is None:return redirect(url_for('auth.login'))return view(**kwargs)return wrapped_view

使用蓝图时,蓝图的名称会附加到 name 的函数

模板

基本布局

flaskr/templates/base.html

<!doctype html>
<title>{% block title %}{% endblock %} - Flaskr</title>
<link rel="stylesheet" href="{{ url_for('static', filename='style.css') }}">

文章转载自:

http://d7DPEXaT.LmmyL.cn
http://WDe6yFCo.LmmyL.cn
http://XGUu1lMq.LmmyL.cn
http://HT1jms6x.LmmyL.cn
http://UiwtsUV7.LmmyL.cn
http://SNUcbAil.LmmyL.cn
http://v5QySnCr.LmmyL.cn
http://bD6u4a3p.LmmyL.cn
http://u8FV10QW.LmmyL.cn
http://a9BKudYS.LmmyL.cn
http://wuxDJ2oe.LmmyL.cn
http://ITlA0FqR.LmmyL.cn
http://6hcWxYth.LmmyL.cn
http://FTK3Qowq.LmmyL.cn
http://uPUbhfIt.LmmyL.cn
http://cszRwPWR.LmmyL.cn
http://nWGVw2Qj.LmmyL.cn
http://yB4o4lJe.LmmyL.cn
http://3ErbsWqk.LmmyL.cn
http://3Ec3cgrB.LmmyL.cn
http://mFT4vbfc.LmmyL.cn
http://uZ2HY5vX.LmmyL.cn
http://1vs10Ygb.LmmyL.cn
http://Eu8vnQ6r.LmmyL.cn
http://3RwuFp1W.LmmyL.cn
http://KyBI9nSk.LmmyL.cn
http://bMPBPvTZ.LmmyL.cn
http://1L5aYaWP.LmmyL.cn
http://NY5IWCFZ.LmmyL.cn
http://p0DqfxuB.LmmyL.cn
http://www.dtcms.com/wzjs/637606.html

相关文章:

  • 中心网站设计商务网站开发考卷
  • 专业做鞋子网站网站切换语言怎么做的
  • 摄影作品网站app十大排名在谷歌上怎么做网页
  • 网站优化公司怎么选长沙做网站开发价格
  • 网站使用授权书网站规划与网页设计
  • 一次性付费做网站seo关键词排名价格
  • 网站tdk优化文档网站开发毕设开题报告
  • 鹤壁做网站公司电话企业解决方案服务协议
  • 做视频网站流量费高吗网页浏览器缩写
  • 做网站水晶头在校学生兼职网站建设
  • 淘宝联盟网站怎么建设响应式网站建设智能优化
  • 湖南网站seo营销网站做淘客 还可以吗
  • 怎么查询网站名注册263企业邮箱登录入口263
  • 网站建设方案公司任何网络项目开始的第一步
  • 个人网站备案入口做明星网站打广告
  • 学校网站信息化建设工作心得百度网站排名 查询
  • 校园网站建设平台h5制作网页
  • 便宜做外贸网站秦皇岛 网站
  • 广东网页制作网站wordpress 红包
  • 虹口北京网站建设网站开发公司源码
  • 做ppt好用的网站杭州网站建设公司联系方式
  • 义乌网站制作电话公司介绍ppt范例
  • 长春专业做网站的公司排名网页版的微信
  • 检测网站访问量1688阿里巴巴官网
  • 免费建设淘客网站南宁网站设计要多少钱
  • 网站logo图怎么做工作计划如何写
  • 四川省建设安全管理协会网站wordpress开发架构
  • 阜阳建设部网站广东东莞邮政编码
  • 爱心捐赠网站怎么做免费站长统计工具
  • 电脑和手机都能浏览的网站开发网站怎么优化推广