7-Django项目--账号管理

目录

templates/admin_role/admin_list.html

​编辑

templates/admin_role/add_modify.html

views/admin_role.py

账号管理---->

账号添加

views.py

身份修改

views.py

重置密码

views.py


templates/admin_role/admin_list.html

{% extends "index/index.html" %}

{% block content %}
    <div class="container">
            <div style="margin-bottom: 10px">
                <a class="btn btn-success" href="/add/admin/"><span class="glyphicon glyphicon-plus" aria-hidden="true"></span>添加账号</a>
            </div>
            <div class="panel panel-warning">
                <div class="panel-heading">
                    <h3 class="panel-title">账号列表</h3>
                </div>
                <div class="panel-body">
                    <table class="table">
                        <thead>
                        <tr>
                            <th>id</th>
                            <th>用户名</th>
                            <th>密码</th>
                            <th>重置密码</th>
                            <th>身份</th>
                            <th>操作</th>
                        </tr>
                        </thead>
                        <tbody>
                        {% for data in data_list %}
                            <tr>
                            <th>{{ data.id }}</th>
                            <td>{{ data.username }}</td>
                            <td>******</td>
                            <td><a href="/reset/{{ data.id }}/admin/">重置密码</a></td>
                            <td>{{data.get_role_display}}</td>
                            <td>
                                <a href="/modify/{{ data.id}}/admin/"><span style="color: green" class="glyphicon glyphicon-pencil" aria-hidden="true"></span></a>
                                <a href="/del/{{ data.id}}/admin/"><span style="color: red" class="glyphicon glyphicon-trash" aria-hidden="true"></span></a>
                            </td>
                        </tr>
                        {% endfor %}
                        </tbody>
                    </table>
                </div>
            </div>
        </div>
{% endblock %}

templates/admin_role/add_modify.html

{% extends "index/index.html" %}
{% load static %}

{% block css %}
    <link rel="stylesheet" href="{% static 'css/layui.css' %}">
{% endblock %}

{% block content %}
    <div class="container">
        <div class="panel panel-success">
            <div class="panel-heading">
                <h3 class="panel-title">{{ title }}</h3>
            </div>
            <div class="panel-body">
                <div class="form-group">
                    <form method="post" novalidate>
                        {% csrf_token %}
                        {% for item in form %}
                            <label for="exampleInputEmail1" class="col-sm-2" >{{ item.label }}</label>
                            {{ item }}
                            <span style="color: red">{{ item.errors.0 }}</span>
                        {% endfor %}
                        <button type="submit" class="btn btn-success">提交</button>
                    </form>
                </div>
            </div>
        </div>
    </div>

{% endblock %}


views/admin_role.py

# -*- coding:utf-8 -*-
from django.shortcuts import render, redirect
from django.core.validators import ValidationError
from django import forms
from demo_one import models
from demo_one.utils import pwd_data

def admin_list(request):
    data_list = models.Adminrole.objects.all()
    content = {
        "data_list": data_list
    }
    return render(request, "admin_role/admin_list.html",content)


class AdminModelForm(forms.ModelForm):
    # 创建一个确认密码的输入框,然后将input类型修改为password
    confirm_password = forms.CharField(label="确认密码", widget=forms.PasswordInput)
    class Meta:
        model = models.Adminrole
        fields = ["username", "password", "confirm_password", "role"]
        widgets = {
            # render_value=True 保留这个字段的值
            "password": forms.PasswordInput(render_value=True)
        }

    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        for name, field in self.fields.items():
            field.widget.attrs = {"class": "form-control", "autocomplete": "off"}

    # 钩子方法,处理改字段
    # 将第一次输入的密码进行加密处理
    def clean_password(self):
        # 获取用户框输入的该字段
        pwd = self.cleaned_data.get("password")
        # print(f"第一次获取的password:{pwd}")
        # print("*-*"*30)
        return pwd_data.md5(pwd)

    # 将确认密码也进行同样的加密方式
    def clean_confirm_password(self):
        confirm = pwd_data.md5(self.cleaned_data.get("confirm_password"))
        # 获取到第一次数据的密码(加密后的)
        pwd = self.cleaned_data.get("password")
        # print(f"加密之后的确认密码:{confirm}")
        # print(f"第二次获取输入的密码:{pwd}")
        if confirm != pwd:
            raise ValidationError("两次密码不一致")
        # 将需要存储的字段返回
        return confirm


def add_admin(request):
    title = "账号添加"
    if request.method == "GET":
        form = AdminModelForm()
        content = {
            "title": title,
            "form": form
        }
        return render(request, "admin_role/add_modify.html", content)
    form = AdminModelForm(data=request.POST)
    if form.is_valid():
        form.save()
        return redirect("/admin/list/")
    return render(request, "admin_role/add_modify.html", {"title": title, "form": form})


class AdminModifyModelForm(forms.ModelForm):
    class Meta:
        model = models.Adminrole
        fields = ["username", "role"]

    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        for name, field in self.fields.items():
            field.widget.attrs = {"class": "form-control", "autocomplete": "off"}

# 修改账户和权限
def modify_admin(request, nid):
    title = "编辑页面"
    title_obj = models.Adminrole.objects.filter(id=nid).first()
    if request.method == "GET":
        form = AdminModifyModelForm(instance=title_obj)
        return render(request, "admin_role/add_modify.html",{"form":form, "title":title})
    form = AdminModifyModelForm(instance=title_obj,data=request.POST)
    if form.is_valid():
        form.save()
        return redirect("/admin/list/")
    return render(request, "admin_role/add_modify.html", {"form": form, "title": title})


def del_admin(request, nid):
    models.Adminrole.objects.filter(id=nid).delete()
    return redirect("/admin/list/")


class AdminResetModelForm(forms.ModelForm):
    # 创建一个确认密码的输入框,然后将input类型修改为password
    confirm_password = forms.CharField(label="确认密码", widget=forms.PasswordInput)
    class Meta:
        model = models.Adminrole
        fields = ["password"]
        widgets = {
            # render_value=True 保留这个字段的值
            "password": forms.PasswordInput(render_value=True)
        }

    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        for name, field in self.fields.items():
            field.widget.attrs = {"class": "form-control", "autocomplete": "off"}

    # 钩子方法,处理改字段
    # 将第一次输入的密码进行加密处理
    def clean_password(self):
        # 获取用户框输入的该字段
        pwd = self.cleaned_data.get("password")
        # print(f"第一次获取的password:{pwd}")
        # print("*-*"*30)
        return pwd_data.md5(pwd)

    # 将确认密码也进行同样的加密方式
    def clean_confirm_password(self):
        confirm = pwd_data.md5(self.cleaned_data.get("confirm_password"))
        # 获取到第一次数据的密码(加密后的)
        pwd = self.cleaned_data.get("password")
        # print(f"加密之后的确认密码:{confirm}")
        # print(f"第二次获取输入的密码:{pwd}")
        if confirm != pwd:
            raise ValidationError("两次密码不一致")
        # 将需要存储的字段返回
        return confirm

# 重置密码
def reset_admin(request, nid):
    title_obj = models.Adminrole.objects.filter(id=nid).first()
    title = f"重置《{title_obj.username}》密码"
    if request.method == "GET":
        form = AdminResetModelForm()
        return render(request, "admin_role/add_modify.html",{"form":form, "title":title})
    form = AdminResetModelForm(data=request.POST,instance=title_obj)
    if form.is_valid():
        form.save()
        return redirect("/admin/list/")
    return render(request, "admin_role/add_modify.html", {"form": form, "title": title})

账号管理---->

账号添加

  • views.py

    class AdminModelForm(forms.ModelForm):
        # 创建一个确认密码的输入框,然后将input类型修改为password
        confirm_password = forms.CharField(label="确认密码", widget=forms.PasswordInput)
        class Meta:
            model = models.Adminrole
            fields = ["username", "password", "confirm_password", "role"]
    ​
        def __init__(self, *args, **kwargs):
            super().__init__(*args, **kwargs)
            for name, field in self.fields.items():
                field.widget.attrs = {"class": "form-control", "autocomplete": "off"}
    ​
        # 钩子方法,处理改字段
        # 将第一次输入的密码进行加密处理
        def clean_password(self):
            # 获取用户框输入的该字段
            pwd = self.cleaned_data.get("password")
            # print(f"第一次获取的password:{pwd}")
            # print("*-*"*30)
            return pwd_data.md5(pwd)
    ​
        # 将确认密码也进行同样的加密方式
        def clean_confirm_password(self):
            confirm = pwd_data.md5(self.cleaned_data.get("confirm_password"))
            # 获取到第一次数据的密码(加密后的)
            pwd = self.cleaned_data.get("password")
            # print(f"加密之后的确认密码:{confirm}")
            # print(f"第二次获取输入的密码:{pwd}")
            if confirm != pwd:
                raise ValidationError("两次密码不一致")
            # 将需要存储的字段返回
            return confirm
    ​
    ​
    def add_admin(request):
        title = "账号添加"
        if request.method == "GET":
            form = AdminModelForm()
            content = {
                "title": title,
                "form": form
            }
            return render(request, "admin_role/add_admin.html", content)
        form = AdminModelForm(data=request.POST)
        if form.is_valid():
            form.save()
            return redirect("/admin/list/")
        return render(request, "admin_role/add_admin.html", {"title": title, "form": form})

身份修改

  • views.py

    class AdminModifyModelForm(forms.ModelForm):
        class Meta:
            model = models.Adminrole
            fields = ["username", "role"]
    ​
        def __init__(self, *args, **kwargs):
            super().__init__(*args, **kwargs)
            for name, field in self.fields.items():
                field.widget.attrs = {"class": "form-control", "autocomplete": "off"}
    ​
    # 修改账户和权限
    def modify_admin(request, nid):
        title = "编辑页面"
        title_obj = models.Adminrole.objects.filter(id=nid).first()
        if request.method == "GET":
            form = AdminModifyModelForm(instance=title_obj)
            return render(request, "admin_role/add_modify.html",{"form":form, "title":title})
        form = AdminModifyModelForm(instance=title_obj,data=request.POST)
        if form.is_valid():
            form.save()
            return redirect("/admin/list/")
        return render(request, "admin_role/add_modify.html", {"form": form, "title": title})

重置密码

  • views.py

    class AdminResetModelForm(forms.ModelForm):
        # 创建一个确认密码的输入框,然后将input类型修改为password
        confirm_password = forms.CharField(label="确认密码", widget=forms.PasswordInput)
        class Meta:
            model = models.Adminrole
            fields = ["password"]
            widgets = {
                # render_value=True 保留这个字段的值
                "password": forms.PasswordInput(render_value=True)
            }
    ​
        def __init__(self, *args, **kwargs):
            super().__init__(*args, **kwargs)
            for name, field in self.fields.items():
                field.widget.attrs = {"class": "form-control", "autocomplete": "off"}
    ​
        # 钩子方法,处理改字段
        # 将第一次输入的密码进行加密处理
        def clean_password(self):
            # 获取用户框输入的该字段
            pwd = self.cleaned_data.get("password")
            # print(f"第一次获取的password:{pwd}")
            # print("*-*"*30)
            return pwd_data.md5(pwd)
    ​
        # 将确认密码也进行同样的加密方式
        def clean_confirm_password(self):
            confirm = pwd_data.md5(self.cleaned_data.get("confirm_password"))
            # 获取到第一次数据的密码(加密后的)
            pwd = self.cleaned_data.get("password")
            # print(f"加密之后的确认密码:{confirm}")
            # print(f"第二次获取输入的密码:{pwd}")
            if confirm != pwd:
                raise ValidationError("两次密码不一致")
            # 将需要存储的字段返回
            return confirm
    ​
    # 重置密码
    def reset_admin(request, nid):
        title_obj = models.Adminrole.objects.filter(id=nid).first()
        title = f"重置《{title_obj.username}》密码"
        if request.method == "GET":
            form = AdminResetModelForm()
            return render(request, "admin_role/add_modify.html",{"form":form, "title":title})
        form = AdminResetModelForm(data=request.POST,instance=title_obj)
        if form.is_valid():
            form.save()
            return redirect("/admin/list/")
        return render(request, "admin_role/add_modify.html", {"form": form, "title": title})

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/668172.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

[有监督学习] 7.详细图解随机森林

随机森林 随机森林&#xff08;random forest&#xff09;是将多个模型综合起来创建更高性能模型的方法&#xff0c;既可用于回归&#xff0c;也可用于分类。同样的算法有梯度提升&#xff08;gradient boosting&#xff09;等在机器学习竞赛中很受欢迎的算法。 通过学习随机森…

SpringBoot整合jasypt加密配置文件敏感信息

SpringBoot整合jasypt加密配置文件敏感信息 在项目中我们需要对配置文件的一些敏感信息进行加密处理&#xff0c;比如数据库账户密码&#xff0c;避免直接暴露出来&#xff0c;这种场景常常用于生产环境&#xff0c;我们不想让开发人员知道生产库的密码&#xff0c;有运维人员…

Ubuntu 安装好虚拟环境后,找不到workon 命令

1、安装虚拟环境 pip3 install virtualenv pip3 install virtualenvwrapper 2、安装完成后 workon 命令。 找不到workon 命令 执行&#xff0c;source virtualenvwrapper.sh 执行后&#xff0c;在使用workon命令&#xff0c;即可完成。

1.1 Mediapipe随手简记(一)

为了后续项目展开&#xff0c;需要Python、C、Linux、OpenCV、Mediapipe、ROS知识。 最后面有手势识别&#xff08;数字&#xff09;精准案例&#xff0c;项目会用到。 Mediapipe学习篇1 Mediapipe 是一个开源的跨平台框架&#xff0c;它提供了大量的解决方案&#xff0c;用…

MySQL十部曲之九:MySQL优化理论

文章目录 前言概述查询优化查询执行计划EXPLAIN获取表结构信息获取执行计划信息 EXPLAIN 输出格式如何使用EXPLAIN进行优化 范围访问优化单列索引的范围访问多列索引的范围访问 索引合并优化索引合并交叉访问算法索引合并联合访问算法索引合并排序联合访问算法 索引下推优化连接…

随身wifi网络卡顿怎么解决?随身WiFi哪个牌子的最好用?排名第一名的随身WiFi!

对于随身wifi靠不靠谱这个问题&#xff0c;网上一直存在争议。很多人的随身wifi网速不稳定&#xff0c;信号看着满格就是上不了网。关于随身wifi卡顿到底该怎么解决呢&#xff1f; 1.如果是设备网络在一个地方上网速度很快&#xff0c;换一个地方网络就不行了&#xff0c;很可能…

爬虫学习2

中国国家地理网 单张图片爬取 import requests url http://img0.dili360.com/ga/M00/02/AB/wKgBzFQ26i2AWujSAA_-xvEYLbU441.jpg!rw9 headers {"User-Agent": Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0…

CC工具箱使用指南:【山西省村规结构调整表(亦求长生亦求你)】

一、简介 群友定制工具。 工具根据输入的用地图层&#xff0c;生成山西村规的结构调整表。 和一般的用地表有些不一样的地方是&#xff0c;现状和规划字段都在同一个图层里。 并且还有一个【村庄名称】的字段&#xff0c;可以将多个村庄放在一个图层中&#xff0c;一次性生…

简介项目管理七步训练与站上山顶

前言 麦肯锡七步成诗法,实际上并非用于创作诗歌,而是一种解决问题的方法,它源自于全球知名的管理咨询公司麦肯锡(McKinsey & Company)。 这种方法强调逻辑清晰、结构化思维,用于解决商业问题非常有效。这种创意思维方法被广泛应用于问题解决和创新过程中。以下是“麦…

【设计模式深度剖析】【7】【结构型】【享元模式】| 以高脚杯重复使用、GUI中的按钮为例说明,并对比Java类库设计加深理解

&#x1f448;️上一篇:外观模式 | 下一篇:结构型设计模式对比&#x1f449;️ 设计模式-专栏&#x1f448;️ 目录 享元模式定义英文原话直译如何理解&#xff1f;字面理解例子&#xff1a;高脚杯的重复使用例子&#xff1a;GUI中的按钮传统方式使用享元模式 4个角色1. …

html期末复习速览

一.基础标签 1.段落标签<p></p> 特点&#xff1a;分段分割 2.标题标签<h1></h1>……<h6></h6> 特点&#xff1a;文字加粗&#xff0c;单独占一行 3.换行标签<br /> 特点&#xff1a;单标签&#xff0c;强制换行 二.文本格式化…

流媒体内网穿透/组网/视频协议转换EasyNTS上云网关如何更改密码?

EasyNTS上云网关的主要作用是解决异地视频共享/组网/上云的需求&#xff0c;网页对域名进行添加映射时&#xff0c;添加成功后会生成一个外网访问地址&#xff0c;在浏览器中输入外网访问地址&#xff0c;即可查看内网应用。无需开放端口&#xff0c;EasyNTS上云网关平台会向Ea…

备忘录--

备忘录 vue新建项目&#xff0c;body 大小占不了全屏 // 解决问题 // public/index.html 更改基础样式 html,body{height: 100%width: 100%&#xff1b;margin: 0;border: 0;padding: 0; }Element Plus 经典布局 参考 Element Plus 官网 <template><div class"…

jmeter性能测试用例提取

性能测试用例提取参考(根据单、混合场景、模块、运行时间、优先级)去考虑 Tips&#xff1a;用例提取和用例设计不一样 后期可以结合性能测试用例设计(设置线程数、时间、循环、同步定时器等等&#xff09;来做性能测试

从零到一建设数据中台 - 关键技术汇总

一、数据中台关键技术汇总 语言框架&#xff1a;Java、Maven、Spring Boot 数据分布式采集&#xff1a;Flume、Sqoop、kettle 数据分布式存储&#xff1a;Hadoop HDFS 离线批处理计算&#xff1a;MapReduce、Spark、Flink 实时流式计算&#xff1a;Storm/Spark Streaming、…

VB.net进行CAD二次开发(四)

netload不能弹出对话框&#xff0c;参考文献2 参考文献1说明了自定义菜单的问题&#xff0c;用的是cad的系统命令 只要加载了dll&#xff0c;自定义的命令与cad的命令同等地位。 这时&#xff0c;可以将自定义菜单的系统命令替换为自定义命令。 <CommandMethod("Add…

开源代码分享(32)-基于改进多目标灰狼算法的冷热电联供型微电网运行优化

参考文献&#xff1a; [1]戚艳,尚学军,聂靖宇,等.基于改进多目标灰狼算法的冷热电联供型微电网运行优化[J].电测与仪表,2022,59(06):12-1952.DOI:10.19753/j.issn1001-1390.2022.06.002. 1.问题背景 针对冷热电联供型微电网运行调度的优化问题&#xff0c;为实现节能减排的目…

换电脑怎么软件搬家?最好的8个电脑迁移软件

您知道何时需要数据迁移吗&#xff1f;比方说。您可能需要数据迁移以确保安全、备份或将操作系统升级到最新版本。您对迁移软件有任何了解吗&#xff1f;如您所想&#xff0c;我们将在本文中提供有关数据迁移软件的信息。让我们继续阅读。 最佳数据迁移软件列表 数据的完整性在…

深入探讨npm、Yarn、pnpm和npx之间的区别

前端生态系统是一个快速发展的领域&#xff0c;充满了各种工具和技术。对于开发人员来说&#xff0c;跟上这些创新可能是一项艰巨的挑战。 在本文中&#xff0c;我们将深入探讨npm、Yarn、pnpm和npx之间的区别&#xff0c;帮助你理解每个工具的不同之处。 包管理器比较 npm …

视频监控汇聚EasyCVR助力山体滑坡/自然灾害可视化监测与应急救援

近日&#xff0c;巴布亚新几内亚恩加省遭遇山体滑坡&#xff0c;持续引发关注。截至5月29日&#xff0c;恩加省山体滑坡导致的遇难人数可能超过2000人。据悉&#xff0c;巴布亚新几内亚恩加省位于巴布亚新几内亚中部高原的西部&#xff0c;地形多山。由于事发地区相对偏远&…