admin后台

一、创建一个管理员用户

(1).设置时区、语言(可选步骤)

打开settings.py,改成下面那样

LANGUAGE_CODE = 'zh-Hans'
TIME_ZONE = 'Asia/Shanghai'

(2).执行命令python manage.py createsuperuser

(3).按提示输入用户名、邮箱、密码(密码至少需要8位)

(4).启动服务,访问 127.0.0.1:8000/admin 即可进入站点管理

二、向admin注册模型

#----------admin.py---------
from django.contrib import admin
# Register your models here.
from .models import Department,Student,Course admin.site.register(Department)
admin.site.register(Student)
admin.site.register(Course)

三、自定义管理页面

Django提供了admin.ModelAdmin类通过定义ModelAdmin的子类,来定义模型在Admin界面的显示方式

(一).列表页属性

(1).list_display:显示字段,可以点击列头进行排序

(2).list_filter:过滤字段,过滤框会出现在右侧

(3).search_fields:搜索字段,搜索框会出现在上侧

(4).list_per_page:分页,分页框会出现在下侧

(二).示例

(1).先写好模型

#-----models.py------
class Department(models.Model):
d_id = models.AutoField(primary_key=True)
d_name = models.CharField(max_length=30)
def __str__(self):
return 'Department<d_id=%s,d_name=%s>'%(
self.d_id,self.d_name
) class Student(models.Model):
s_id = models.AutoField(primary_key=True)
s_name = models.CharField(max_length=30)
department = models.ForeignKey('Department')
course = models.ManyToManyField('Course')
def __str__(self):
return 'Student<s_id=%s,s_name=%s>'%(
self.s_id,self.s_name
) class Course(models.Model):
c_id = models.AutoField(primary_key=True)
c_name = models.CharField(max_length=30)
def __str__(self):
return 'Course<c_id=%s,c_name=%s>'%(
self.c_id,self.c_name
)

(2).在该模型的app中的admin.py

# -----------admin.py--------
from django.contrib import admin
from .models import Department,Student,Course class DepartmentAdimin(admin.ModelAdmin):
list_display = ['d_id','d_name']
list_display_links = ['d_id','d_name']
list_filter = ['d_id']
search_fields = ['d_name'] class StudentAdimin(admin.ModelAdmin):
list_display = ['s_id','s_name']
list_display_links = ['s_id','s_name'] class CourseAdmin(admin.ModelAdmin):
list_display = ['c_id','c_name']
list_display_links = ['c_id','c_name']
list_per_page = 5 admin.site.register(Department,DepartmentAdimin)
admin.site.register(Student,StudentAdimin)
admin.site.register(Course,CourseAdmin)

auth权限

一、使用视图方式创建一个超级用户

from django.contrib.auth.models import User
User.objects.create_user(username="yyyyyy",password="yyyyyy",email="xxx@yyy.com")

二、用户User操作

(一).验证用户

不需要再用之前的filter().first()方式了,直接用django封装好的authenticate()

from django.contrib.auth import authenticate
user = authenticate(username=username,password=password)

authenticate这个单词的本意就是“证明…是真实的”

(二).保持登录状态

接上面(一)的验证代码,使用django的login(request,user)

if user is not None:
if user.is_active:
login(request, user)
# 登录成功
else:
# 用户没有被激活,不能登录
else:
# 用户名或者密码错误

Ps:request这个参数必须写上

(三).注销

直接logout(request)

from django.contrib.auth import logout

def logout_view(request):
logout(request)
# 注销这个用户。他的session信息将被清除掉。

(四).操作前的验证判断

比如说,购买之前必须要登录,没有登录就不能购买。那么就用django自带的装饰器,装饰一下。

在具体的某个视图函数上面加上装饰器,例:

from django.contrib.auth.decorators import login_required

@login_required  # 这是一个装饰器
def my_view(request):
...

这样之后,操作这个my_view()业务逻辑之前,都会判断下是否有登录,没有登录就执行其他操作。

(五).User模型常用属性和方法

- username:用户名。
- email:邮箱。
- groups:多对多的组。
- user_permissions:多对多的用户权限。
- is_staff: 是否是admin的管理员。
- is_active: 是否激活,判断该用户是否可用。
- is_superuser: 是否是超级用户。
- last_login: 上次登录时间。
- date_joined: 注册时间。
- is_authenticated: 是否验证通过了。
- is_anonymous:是否是匿名用户。
- set_password(raw_password): 设置密码,传原生密码进去。
- check_password(raw_password): 检查密码。
- has_perm(perm): 判断用户是否有某个权限。
- has_perms(perm_list): 判断用户是否有权限列表中的某个列表

三、Permission权限模型

(一).在模型中添加权限

from django.db import models

class BlogModel(models.Model):
id = models.AutoField(primary_key=True)
title = models.CharField(max_length=100,blank=True)
content = models.TextField() class Meta:
permissions = (
('watch_article', u'查看文章的权限'),
('update_article', u'修改文章的权限'),
('delete_article', u'删除文章的权限'),
('add_article', u'发布文章的权限'),
)

(二).在代码中添加权限

from django.contrib.auth.models import Permission
from django.contrib.contenttypes.models import ContentType def test(request):
content_type = ContentType.objects.get_for_model(BlogModel)
permission = Permission.objects.create(
codename='can_publish',
name='Can Publish BlogModel',
content_type=content_type,
)
permission.save()
return HttpResponse('success')

(三).用户权限操作

myuser.user_permissions.set([permission_list])
myuser.user_permissions.add(permission, permission, ...)
myuser.user_permissions.remove(permission, permission, ...)
myuser.user_permissions.clear()
myuser.has_perm('foo.add_bar')

四、Group模型

(一).导包

django.contrib.auth.models.Group

(二).创建Group

b1 = Group.objects.create(name="user_can_write_blog")
b1.save()

注意:必须传一个name参数进去

(三).示例

group.permissions.set([permission_list])
group.permissions.add(permission, permission, ...)
group.permissions.remove(permission, permission, ...)
group.permissions.clear()

Django - admin后台、auth权限的更多相关文章

  1. django博客项目6:Django Admin 后台发布文章

    在此之前我们完成了 Django 博客首页视图的编写,我们希望首页展示发布的博客文章列表,但是它却抱怨:暂时还没有发布的文章!如它所言,我们确实还没有发布任何文章,本节我们将使用 Django 自带的 ...

  2. Django Admin后台添加用户时出现报错:1452

    如果在使用Django Admin后台添加用户时出现报错: (1452, 'Cannot add or update a child row: a foreign key constraint fai ...

  3. Django Admin后台管理模块的使用

    Admin后台管理模块的使用 Django的管理员模块是Django的标准库django.contrib的一部分.这个包还包括其它一些实用的模块: django.contrib.auth django ...

  4. django admin后台插件:django-suit入门

    去年9月底开始用django来做公司内部项目,开始对django有了一些了解,感觉django真的蛮强大的(也有很多人推荐flask,将来有空的话我会试试).今天的话只是介绍一个小东西,django管 ...

  5. django admin后台的简单使用

    创建自己的model.py文件 from django.db import models from django.contrib.auth.models import ( BaseUserManage ...

  6. Django admin 后台管理

    在App 文件夹下的 admin.py 文件中写入 from django.contrib import admin from app名 import models admin.site.site_h ...

  7. Django Admin后台管理功能使用+二次开发

    一  使用环境 开发系统: windows IDE: pycharm 数据库: msyql,navicat 编程语言: python3.7  (Windows x86-64 executable in ...

  8. Django admin后台操作

    Django提供自动后台管理应用,简称admin. admin是一个应用,每个Web站点都需要它.admin通过让开发者可以在完成完整的UI之前验证处理数据的代码. 设置admin 打开setting ...

  9. Django Admin 后台Admin继承UserAdmin增加用户密码不显示明文和用户登录不了的解决方法

    Django后台Admin继承UserAdmin增加用户不显示明文方法 1.在 models.py 中用户表 # 导包规范-1.Python标准模块 from django.db import mod ...

随机推荐

  1. form表单中的id 与name的区别

    以前经常写form表单时,不写id和name,总觉得没有什么用.后来一看后台套完的页面发现,他们都补上name,不知道所以然,就查了一下资料,吓我一跳,要是照我那样写根本不会有数据传到服务器.原来表单 ...

  2. ADB 高级应用

    一.利用无线来查看adb shell > adb tcpip 5555   连接: > adb connect IP:5555   见后文<调试注意事项>   二.模拟按键   ...

  3. C#调用Windows CMD命令并,返回输出结果或错误信息

    public static string InvokeExcute(string Command) { Command = Command.Trim().TrimEnd('&') + &quo ...

  4. python相关性分析与p值检验

    ## 最近两天的成果 ''' ########################################## # # # 不忘初心 砥砺前行. # # 418__yj # ########### ...

  5. Oauth2.0协议曝漏洞 大量社交网站隐私或遭泄露

    2014年是IT业界不平常的一年,XP停服.IE长老漏洞(秘狐)等等层出不穷,现在,社交网络也爆出惊天漏洞:Oauth2.0协议漏洞 继OpenSSL漏洞后,开源安全软件再曝安全漏洞.新加坡南洋理工大 ...

  6. Codeforces 455C Civilization(并查集+dfs)

    题目链接:Codeforces 455C Civilization 题目大意:给定N.M和Q,N表示有N个城市,M条已经修好的路,修好的路是不能改变的.然后是Q次操作.操作分为两种.一种是查询城市x所 ...

  7. bashrc,bash_profile和/etc/profile

    bashrc,bash_profile和/etc/profile 最近老出现在shell里面能跑的程序用鼠标双击app去不能跑.究其原因是因为环境变量的问题. 在类unix系统中一般有三个bash配置 ...

  8. 简述 Python 类中的 __init__、__new__、__call__ 方法

    任何事物都有一个从创建,被使用,再到消亡的过程,在程序语言面向对象编程模型中,对象也有相似的命运:创建.初始化.使用.垃圾回收,不同的阶段由不同的方法(角色)负责执行. 定义一个类时,大家用得最多的就 ...

  9. Python 集合常用方法总结

    数据类型:int/str/bool/list/dict/tuple/float/set   (set类型天生去重) 一.集合的定义 s = set()  #定义空集合 s = {'a','b','c' ...

  10. .net , java webSocket 连接 Socket.io (1.4.4版本) 问题

    .net版Socketio4net类库和java版socket.io-java-client类库 连接socket.io 1.4版本都不行,网上大多是socket.io 0.9版本的,socket.i ...