MySQL 8.0.23 数据库用户管理、权限分配和远程连接

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL 8.0.23 数据库用户管理、权限分配和远程连接相关的知识,希望对你有一定的参考价值。

参考技术A 这个目前应该是mysql比较新的版本了,教程仅在Linux平台上验证通过,其他平台请自证。提供步骤和思路方便快速分析和定位问题。

根据需求在完成理解前面步骤后,接下来需要配置允许远程连接(生产环境请通过ssh隧道方式,且mysql配置文件bind-address为特定ip或本机)

最后,感谢您的阅读,由于时间仓促,文章内容难免有不妥之处,欢迎交流和指正~~
Mark一下 惟月慎行 再也不会迷路了^_^!

权限分配之用户管理

用户管理示例图:

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 第一步:路由的创建

rbac/urls.py

from django.urls import re_path
from rbac.views import role
from rbac.views import user

urlpatterns = [
    # 角色管理
    re_path(r\'^role/list/$\', role.role_list, name="role_list"),
    re_path(r\'^role/add/$\', role.role_add, name="role_add"),
    re_path(r\'^role/edit/(?P<pk>\\d+)/$\', role.role_edit, name="role_edit"),
    re_path(r\'^role/del/(?P<pk>\\d+)/$\', role.role_del, name="role_del"),
    # 用户管理
    re_path(r\'^user/list/$\', user.user_list, name="user_list"),
    re_path(r\'^user/add/$\', user.user_add, name="user_add"),
    re_path(r\'^user/edit/(?P<pk>\\d+)/$\', user.user_edit, name="user_edit"),
    re_path(r\'^user/del/(?P<pk>\\d+)/$\', user.user_del, name="user_del"),
    re_path(r\'^user/reset/password/(?P<pk>\\d+)/$\', user.user_reset_pwd, name="user_reset_pwd"),
]

第二步:ModelForm的书写

rbac/forms/user.py

from django import forms
from rbac import models
from django.core.exceptions import ValidationError


class UserModelForm(forms.ModelForm):
    """添加用户"""
    confirm_password = forms.CharField(
        label="确认密码",
    )  # model中没有的字段,可自行添加一个该字段
    class Meta:
        model = models.Userinfo  # 关联的表
        fields = ["name", "email", "password", "confirm_password"]  # 字段
        # 错误提示改为中文的第一种方法
        # error_messages = 
        #     "name": "required": "用户名不能为空",
        #     "email": "required": "邮箱不能为空",
        #     "password": "required": "密码不能为空",
        #     "confirm_password": "required": "确认密码不能为空",  # 无效
        # 
        # 错误提示改为中文的第二种方法(在settings.py中把LANGUAGE_CODE进行修改)
        # LANGUAGE_CODE = \'zh-hans\'

    def __init__(self, *args, **kwargs):
        """为所有字段添加样式"""
        super(UserModelForm, self).__init__(*args, **kwargs)
        for name, field in self.fields.items():
            # name就是上面fields中的字段
            field.widget.attrs["class"] = "form-control"

    def clean_confirm_password(self):
        """局部钩子函数,校验两次密码是否一致"""
        password = self.cleaned_data.get("password")
        confirm_password = self.cleaned_data.get("confirm_password")
        if password != confirm_password:
            raise ValidationError("两次密码输入不一致...")
        return confirm_password


class UpdateUserModelForm(forms.ModelForm):
    """编辑用户"""
    class Meta:
        model = models.Userinfo
        fields = ["name", "email"]

    def __init__(self, *args, **kwargs):
        super(UpdateUserModelForm, self).__init__(*args, **kwargs)
        for name, field in self.fields.items():
            field.widget.attrs["class"] = "form-control"


class ResetPasswordUserModelForm(forms.ModelForm):
    """重置密码"""
    confirm_password = forms.CharField(
        label="确认密码",
    )
    class Meta:
        model = models.Userinfo
        fields = ["password", "confirm_password"]

    def __init__(self, *args, **kwargs):
        super(ResetPasswordUserModelForm, self).__init__(*args, **kwargs)
        for name, field in self.fields.items():
            field.widget.attrs["class"] = "form-control"

    def clean_confirm_password(self):
        password = self.cleaned_data.get("password")
        confirm_password = self.cleaned_data.get("confirm_password")
        if password != confirm_password:
            raise ValidationError("两次密码输入不一致...")
        return confirm_password

第三步:视图函数的书写

rbac/views/user.py

"""角色管理"""
from rbac import models
from django.shortcuts import render, redirect, HttpResponse
from django.urls import reverse
from rbac.forms.user import UserModelForm, UpdateUserModelForm, ResetPasswordUserModelForm


def user_list(request):
    """
    用户列表
    :param request:
    :return:
    """
    user_queryset = models.Userinfo.objects.all().order_by("pk")
    return render(request, "rbac/user_list.html", "users": user_queryset)


def user_add(request):
    """
    添加用户
    :param request:
    :return:
    """
    if request.method == "GET":
        form = UserModelForm()
        return render(request, "rbac/change.html", "form": form)
    form = UserModelForm(data=request.POST)  # 保存
    if form.is_valid():
        form.save()
        return redirect(reverse("rbac:user_list"))
    return render(request, "rbac/change.html", "form": form)


def user_edit(request, pk):
    """
    用户编辑
    :param request:
    :param pk: 要修改的用户ID
    :return:
    """
    obj = models.Userinfo.objects.filter(id=pk).first()
    if not obj:
        return HttpResponse("用户不存在...")
    if request.method == "GET":
        form = UpdateUserModelForm(instance=obj)  # 将原有的数据展示
        return render(request, "rbac/change.html", "form": form)
    form = UpdateUserModelForm(instance=obj, data=request.POST)  # 保存编辑后的数据
    if form.is_valid():
        form.save()
        return redirect(reverse("rbac:user_list"))
    return render(request, "rbac/change.html", "form": form)


def user_del(request, pk):
    """
    删除用户
    :param request:
    :param pk:
    :return:
    """
    origin_url = reverse("rbac:user_list")
    if request.method == "GET":
        return render(request, "rbac/delete.html", "cancel_url": origin_url)
    models.Userinfo.objects.filter(id=pk).delete()
    return redirect(origin_url)


def user_reset_pwd(request, pk):
    """
    重置密码
    :param request:
    :param pk:
    :return:
    """
    obj = models.Userinfo.objects.filter(id=pk).first()
    if not obj:
        return HttpResponse("用户不存在...")
    if request.method == "GET":
        form = ResetPasswordUserModelForm()  # 重置密码,不需要把之前的密码进行展示
        return render(request, "rbac/change.html", "form": form)
    form = ResetPasswordUserModelForm(instance=obj, data=request.POST)  # 保存编辑后的数据
    if form.is_valid():
        form.save()
        return redirect(reverse("rbac:user_list"))
    return render(request, "rbac/change.html", "form": form)

第四步:模板的创建(change.html和delete.html都是共用的,所以只需要创建一个展示用户的html即可)

rbac/templates/rbac/user_list.html

% extends \'layout.html\' %

% block content %
    <div class="luffy-container">
        <div class="btn-group" style="margin: 5px 0">
            <a class="btn btn-default" href="% url \'rbac:user_add\' %">
                <i class="fa fa-plus-square" aria-hidden="true"></i> 添加用户
            </a>
        </div>
        <table class="table table-bordered table-hover">
            <thead>
            <tr>
                <th>序号</th>
                <th>用户名</th>
                <th>邮箱</th>
                <th>重置密码</th>
                <th>操作</th>
            </tr>
            </thead>
            <tbody>
            % for row in users %
                <tr>
                    <td> forloop.counter </td>
                    <td> row.name </td>
                    <td> row.email </td>
                    <td>
                        <a href="% url \'rbac:user_reset_pwd\' pk=row.id %">重置密码</a>
                    </td>
                    <td>
                        <a style="color: #333333;" href="% url \'rbac:user_edit\' pk=row.id %">
                            <i class="fa fa-edit" aria-hidden="true"></i></a>
                        <a style="color: #d9534f;" href="% url \'rbac:user_del\' pk=row.id %">
                            <i class="fa fa-trash-o"></i>
                        </a>
                    </td>
                </tr>
            % endfor %
            </tbody>
        </table>
    </div>
% endblock %

 

 

 

知识点:
  - ModelForm
    - 字段的自定制
    - 钩子函数
    - 错误提示变成中文的两种方法
    - 重写__init__方法,统一给所有字段添加属性("form-control")
  - 根据namespace和name反向生成URL
  - 模板的查找顺序

while True: print(\'studying...\')

以上是关于MySQL 8.0.23 数据库用户管理、权限分配和远程连接的主要内容,如果未能解决你的问题,请参考以下文章

MySQL 用户管理及权限管理

MySQL用户及权限管理

mysql用户和权限管理

MySQL 数据库用户和权限管理

Mysql用户权限管理

MySQL(十六)之MySQL用户管理