zoukankan      html  css  js  c++  java
  • Flask项目实战:创建电影网站(2)

    flask网站制作后台时候常见流程总结

    安利一个神神器:

    百度脑图PC版

    创建数据库

    下面是创建User数据库,需要导入db

    #coding:utf8
    from flask import Flask
    from datetime import datetime
    from app import db
    
    
    #会员数据模型
    class User(db.Model):
        __tablename__ = "user"
        __table_args__ = {"useexisting": True}
        id = db.Column(db.Integer,primary_key=True)#编号
        name = db.Column(db.String(100),unique=True)#昵称
        pwd = db.Column(db.String(100))#密码
        email = db.Column(db.String(100),unique=True)#邮箱
        phone = db.Column(db.String(11),unique=True)#手机号
        info = db.Column(db.Text)#个性简介
        face = db.Column(db.String(255),unique=True)#头像
        addtime = db.Column(db.DateTime,index=True,default=datetime.utcnow)#注册时间
        uuid = db.Column(db.String(255),unique=True)#唯一标识符
        #(设置外键的第二步)
        userlogs = db.relationship('Userlog',backref = 'user')#会员日志外键关系关联
        comments = db.relationship('Comment', backref='user')  # 评论外键关系关联
        moviecols = db.relationship('Moviecol', backref='user')  # 收藏外键关系关联
        def __repr__(self):
            return '<User %r>' % self.name
    

    然后在入口里面写入

    创建表:

    if __name__ == "__main__":
         db.create_all()
    

    创建数据库完成

    添加数据示例:

    if __name__ == "__main__":
        role = Role(
            name="超级管理员",
            auths="2323"
        )
        db.session.add(role)
        db.session.commit()
    

    在代码中删除数据示例:

    @admin.route('/tag/del/<int:id>',methods=["GET"])
    @admin_login_req
    def tag_del(id=None):
        tag = Tag.query.filter_by(id=id).first_or_404()
        db.session.delete(tag);
        db.session.commit()
        flash("删除标签成功!","ok")
        return redirect(url_for('admin.tag_list',page=1))
    

    有时候会出现创建不成功,或者已经创建成功还是报错,查看User结构里面的语句,或者百度直接搜索关键字。

         __table_args__ = {"useexisting": True}
    

    操作验证

    装饰器验证

    在代码里面需要各种操作。比如每次操作都要判断admin是否已经登录,每个函数前面要添加装饰器。

    装饰器写法:

    def admin_login_req(f):
        @wraps(f)
        def decorated_function(*args,**kwargs):
            if "admin" not in session :
                return redirect(url_for("admin.login",next=request.url))
            return f(*args,**kwargs)
        return decorated_function
    

    代码示例:

    @admin.route("/")
    @admin_login_req
    def index():
        return render_template('admin/index.html')
    

    表格验证

    html模板里面的每一个form创建一个对应的验证类.如添加标签:

    class TagForm(FlaskForm):
        tagname = StringField(
            label='名称',
            validators=[  # 验证器
                DataRequired("请输入标签")
            ],
            description="标签",
            render_kw={
                "class ": "form-control",
                "placeholder": "请输入标签名称!",
                "id":"input_name",
                # "required": "required"
            }
        )
        submit = SubmitField(
            "编辑",
            render_kw={
                "class ": "btn btn-primary"
            }
        )
    

    读取数据操作数据

    此时在视图views.py中进行判断:

    @admin.route('/tag/edit/<int:id>/',methods=["POST","GET"])
    @admin_login_req
    def tag_edit(id=None):
        form = TagForm()
        #从数据库中查询标签id,返回标签数据
        tag = Tag.query.get_or_404(id)
        #表单提交的话,执行
        if form.validate_on_submit():
            data = form.data #读取表单数据
            tag_count = Tag.query.filter_by(name=data['tagname']).count()#查看标签数量
            if tag.name == data["tagname"] and tag_count == 1:
                flash("名称已经存在!",'err')
                return redirect(url_for('admin.tag_edit',id=id))
            tag.name = data['tagname']
            db.session.add(tag)#添加表单数据
            db.session.commit()
            flash("添加标签成功!",'ok')
            redirect(url_for('admin.tag_edit',id=id))
        return render_template('admin/tag_edit.html',form=form,tag=tag)
    

    html中的模板

    {% extends 'admin/admin.html' %}
    {% block content %}
    <!--内容-->
    <section class="content-header">
        <h1>微电影管理系统</h1>
        <ol class="breadcrumb">
            <li><a href="#"><i class="fa fa-dashboard"></i> 标签管理</a></li>
            <li class="active">修改标签</li>
        </ol>
    </section>
    <section class="content" id="showcontent">
        <div class="row">
            <div class="col-md-12">
                <div class="box box-primary">
                    <div class="box-header with-border">
                        <h3 class="box-title">修改标签</h3>
                    </div>
                    <form role="form" METHOD="POST" action="{{url_for('admin.tag_edit',id=tag.id)}}">
                        <div class="box-body">
                            {% for msg in get_flashed_messages(category_filter=['err'])%}
                            <div class="alert alert-danger alert-dismissible">
                                <button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button>
                                <h4><i class="icon fa fa-ban"></i> 操作失败</h4>
                                {{msg}}
                            </div>
                            {% endfor %}
                            {% for msg in get_flashed_messages(category_filter=['ok'])%}
                            <div class="alert alert-success alert-dismissible">
                                <button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button>
                                <h4><i class="icon fa fa-check"></i> 操作成功</h4>
                                 {{msg}}
                            </div>
                            {% endfor %}
                            <div class="form-group">
                                {{form.tagname(value=tag.name)}}
                                <span class="glyphicon glyphicon-envelope form-control-feedback"></span>
                                <input name="id" value="{{tag.id}}" type="hidden">
                                {% for err in form.tagname.errors%}
                                <div class="col-md-12" style="color:#ff0000">{{err}}</div>
                                {%endfor%}
                            </div>
                        </div>
                        <div class="box-footer">
                            {{form.submit}}
                            {{form.csrf_token}}
                        </div>
                    </form>
                </div>
            </div>
        </div>
    </section>
    <!--内容-->
    {% endblock %}
    {% block js %}
    <script>
        $(document).ready(function () {
            $('#id-2-1').addClass('active');
            $('#id-2-2').addClass('active');
        })
    </script>
    {% endblock %}
    

    简化一下就是:

    {% extends 'admin/admin.html' %}
    {% block content %}
    <form role="form" METHOD="POST" action="{{url_for('admin.tag_edit',id=tag.id)}}">
                        <div class="box-body">
                            {% for msg in get_flashed_messages(category_filter=['err'])%}
                                <h4><i class="icon fa fa-ban"></i> 操作失败</h4>
                                {{msg}}
                            </div>
                            {% endfor %}
                            {% for msg in get_flashed_messages(category_filter=['ok'])%}
                                <h4><i class="icon fa fa-check"></i> 操作成功</h4>
                                 {{msg}}
                            </div>
                            {% endfor %}
                            <div class="form-group">
                                {{form.tagname(value=tag.name)}}
                                <span class="glyphicon glyphicon-envelope form-control-feedback"></span>
                                <input name="id" value="{{tag.id}}" type="hidden">
                                {% for err in form.tagname.errors%}
                                <div class="col-md-12" style="color:#ff0000">{{err}}</div>
                                {%endfor%}
                            </div>
                        </div>
                        <div class="box-footer">
                            {{form.submit}}
                            {{form.csrf_token}}
                        </div>
                    </form>
    {% endblock %}
    {% block js %}
    <script>
    
    </script>
    {% endblock %}
    

    其中form对应TagForm里面的内容

  • 相关阅读:
    多线程
    Flume和 Sqoop
    Struts2部分
    hibernate学习笔记(一)
    idea创建普通的java小项目教程
    IntelliJ Idea 常用快捷键列表
    idea创建springMVC框架和配置小文件
    对于Git的总结
    关于jvm运行时时区的总结
    事务的总结笔记(详解很仔细),mysql事务隔离级别演示,,,
  • 原文地址:https://www.cnblogs.com/wyy5552/p/8570797.html
Copyright © 2011-2022 走看看