Flask实战第51天:cms添加轮播图后端代码逻辑完成

首先,咱们须要给轮播图设计一张表,由于轮播图前端要展现,CMS要管理,因此咱们在apps下新建个models.py前端

编辑apps.models.pypython

from exts import db
from datetime import datetime


class BannerModel(db.Model):
    __tablename__ = 'banner'
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    name = db.Column(db.String(255), nullable=False)
    image_url = db.Column(db.String(255), nullable=False)
    link_url = db.Column(db.String(255), nullable=False)
    priority = db.Column(db.Integer, default=0)
    create_time = db.Column(db.DateTime, default=datetime.now)

同步表到数据库数据库

同步表前须要在manage.py中导入BannerModel,不然不会进行同步json

python manage.py db migrate
python manage.py db upgrade

表单认证,编辑cms.forms.pysession

class AddBannerForm(BaseForm):
    name = StringField(validators=[InputRequired(message='请输入轮播图名称!')])
    image_url = StringField(validators=[InputRequired(message='请输入轮播图图片连接!')])
    link_url = StringField(validators=[InputRequired(message='请输入轮播图跳转连接!')])
    priority = IntegerField(validators=[InputRequired(message='请输入轮播图优先级!')])

视图,编辑cms.views.pyapp

...
from .forms import AddBannerForm
from apps.models import BannerModel

@bp.route('/abanner/',methods=['POST'])
@login_required
def abanner():
    form = AddBannerForm(request.form)
    if form.validate():
        name = form.name.data
        image_url = form.image_url.data
        link_url = form.link_url.data
        priority = form.priority.data
        banner = BannerModel(name=name,image_url=image_url,link_url=link_url,priority=priority)
        db.session.add(banner)
        db.session.commit()
        return xjson.json_success()
    else:
        return xjson.json_param_error(message=form.get_error())
相关文章
相关标签/搜索