21、Flask構(gòu)建彈幕微電影網(wǎng)站-基于角色訪問控制-權(quán)限管理:增刪查改

百度云搜索,搜各種資料:http://www.81ad.cn

Flask 構(gòu)建微電影視頻網(wǎng)站

已上線演示地址: http://movie.tbquan.cn

權(quán)限管理

權(quán)限增加

創(chuàng)建權(quán)限表單

class AuthForm(FlaskForm):
    name = StringField(
        label='權(quán)限名稱',
        validators=[
            DataRequired('請輸入權(quán)限名稱!')
        ],
        description='請輸入權(quán)限名稱!',
        render_kw={
            'class': "form-control"
        }
    )
    url = StringField(
        label='訪問鏈接',
        validators=[
            DataRequired('請輸入訪問鏈接!')
        ],
        description='請輸入訪問鏈接!',
        render_kw={
            'class': "form-control",
            'placeholder': '鏈接地址'
        }
    )
    submit = SubmitField(
        label='提交',
        render_kw={
            'class': "btn btn-primary"
        }
    )

修改auth_add增加權(quán)限視圖

@admin.route("/auth/add/", methods=['GET', 'POST'])
@admin_login_require
def auth_add():
    form = AuthForm()
    if form.validate_on_submit():
        data = form.data
        if Auth.query.filter_by(url=data['url']).count() == 1:
            flash('權(quán)限鏈接地址已存在!',category='err')
            return redirect(url_for('admin.auth_add'))
        auth = Auth(
            name=data['name'],
            url=data['url']
        )
        db.session.add(auth)
        db.session.commit()
        flash('權(quán)限地址添加成功!', category='ok')
    return render_template('admin/auth_add.html', form=form)

修改auth_edit.html增加權(quán)限模板

<form role="form" method="post">
    <div class="box-body">
        {% include 'admin/alert_info.html' %}
        <div class="form-group">
            <label for="input_name">{{ form.name.label }}</label>
            {{ form.name }}
            {% for err in form.name.errors %}
                <div class="col-md-12" style="color: red">{{ err }}</div>
            {% endfor %}
        </div>
        <div class="form-group">
            <label for="input_url">{{ form.url.label }}</label>
            {{ form.url }}
            {% for err in form.url.errors %}
                <div class="col-md-12" style="color: red">{{ err }}</div>
            {% endfor %}
        </div>
    </div>
    {{ form.csrf_token }}
    <div class="box-footer">
        {{ form.submit }}
    </div>
</form>

BLOG_20181111_202846_24

權(quán)限列表

修改auth_list權(quán)限顯示視圖

@admin.route("/auth/list/<int:page>/")
@admin_login_require
def auth_list(page=None):
    if not page:
        page = 1
    page_auths = Auth.query.order_by(Auth.add_time.desc()).paginate(page=page, per_page=10)
    return render_template('admin/auth_list.html', page_auths=page_auths)

修改auth_list.html權(quán)限顯示模板

{% include 'admin/alert_info.html' %}
<table class="table table-hover">
    <tbody>
    <tr>
        <th>編號</th>
        <th>名稱</th>
        <th>地址</th>
        <th>添加時(shí)間</th>
        <th>操作事項(xiàng)</th>
    </tr>
    {% for auth in page_auths.items %}
        <tr>
            <td>{{ auth.id }}</td>
            <td>{{ auth.name }}</td>
            <td>{{ auth.url }}</td>
            <td>{{ auth.add_time }}</td>
            <td>
                <a class="label label-success">編輯</a>
                &nbsp;
                <a class="label label-danger">刪除</a>
            </td>
        </tr>
    {% endfor %}
    </tbody>
</table>

{% import 'admin/pagination.html' as pg %}
{{ pg.render_pagination(page_auths, 'admin.auth_list') }}

修改base.html增加

<a href="{{ url_for('admin.auth_list', page=1) }}">
    <i class="fa fa-circle-o"></i> 權(quán)限列表
</a>

權(quán)限刪除

修改auth_delete權(quán)限刪除視圖

@admin.route("/auth/delete/<int:delete_id>/")
@admin_login_require
def auth_delete(delete_id=None):
    auth = Auth.query.get_or_404(delete_id)
    db.session.delete(auth)
    db.session.commit()
    flash('刪除權(quán)限地址成功', category='ok')
    return redirect(url_for('admin.auth_list', page=1))

修改auth_list.html權(quán)限刪除鏈接

<a class="label label-danger" href="{{ url_for('admin.auth_delete', delete_id=auth.id) }}">刪除</a>

BLOG_20181111_202856_94

權(quán)限編輯

增加auth_update權(quán)限更新視圖

@admin.route("/auth/update/<int:update_id>/", methods=['GET', 'POST'])
@admin_login_require
def auth_update(update_id=None):
    auth = Auth.query.get_or_404(update_id)
    form = AuthForm(
        name=auth.name,
        url=auth.url
    )
    if form.validate_on_submit():
        data = form.data
        if Auth.query.filter_by(url=data['url']).count() == 1 and auth.url != data['url']:
            flash('權(quán)限鏈接地址已存在!', category='err')
            return redirect(url_for('admin.auth_update', update_id=update_id))
        auth.name = data['name']
        auth.url = data['url']
        db.session.commit()
        flash('權(quán)限地址修改成功!', category='ok')
    return render_template('admin/auth_edit.html', form=form)

修改auth_edit.html權(quán)限編輯模板

增加訪問鏈接判斷

修改auth_list.html增加編輯鏈接

<a class="label label-success" href="{{ url_for('admin.auth_update', update_id=auth.id) }}">編輯</a>

修改auth_edit.html的添加和更新判斷

<li class="active">
    {% if request.path == url_for('admin.auth_add') %}
        添加權(quán)限
    {% else %}
        更新權(quán)限
    {% endif %}
</li>

<h3 class="box-title">
    {% if request.path == url_for('admin.auth_add') %}
        添加權(quán)限
    {% else %}
        更新權(quán)限
    {% endif %}
</h3>

BLOG_20181111_202922_94
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容