基本配置

# 设置数据库为使用的mysql
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'library',
'USER': 'root',
'PASSWORD': 'password',
'HOST': '10.18.99.166',
'PORT': '3306',
}
} # 设置语言为 中文
LANGUAGE_CODE = 'zh-hans' # 设置时区为 中国
TIME_ZONE = 'Asia/Shanghai' # 自定义模块 与 静态文件 位置
TEMPLATES = [
{
...
'DIRS': [os.path.join(BASE_DIR, 'templates')],
...
},
] # 静态文件目录,为包含一个元素的元组; 此句放于 STATIC_URL='/static' 语句后
STATICFILES_DIRS = (os.path.join(BASE_DIR,'static'),)

一、 Form 表单

1、在获取信息较多时,使用Django自带的form类比较简单,其又分为以下两类

form 与 modelForm:

前者获取信息,不需要存入数据库;

后者获取信息,一般需要存入数据库;

from django import forms
class LoginForm(forms.Form):
username = forms.CharField()
password = forms.CharField(label="密码",widget=forms.PasswordInput)

在注册与更新时,CreateView更简单,直接使用即可,但是若是需要注册的信息需要各种校验还是自定义一个RegisterForm比较方便。

2、在select需要联动时,可以考虑自定义form

3、在数据量所需更少时,可以直接通过ajax传递数据

二、自带管理系统使用

创建管理员账号 Superuser

虚拟环境中输入 python manage.py createsuperuser

# 新建用户,在用户注册时常使用,此处的User可以为继承了AbstractUser的自定义User
u = User.objects.create_user(username=username, password=password, email=email)
# 获取登录后的用户信息,以用户名字为例
user_name = request.user.username

注册、登录、密码修改的实现方式

1、注册

在注册时,因为有特殊需要,所以手写了一个RegisterFrom(forms.Form),此处加入一些多选框。在获取到前端传过来的数据后,通过楼上的新建用户实现用户的注册。

2、登录

也是自定义一个简单Form(forms.Form),通过获取前端传过来的数据,使用 user = authenticate(username=cd['username'],password=cd['password']),验证用户输入是否正确实现登录。

3、密码修改

使用了自带的PasswordChangeView(),自定义了前端模板实现。

以上,都有使用django自带的功能实现需求。

权限管理

from django.contrib.auth.models import Permission

# 在Views.py中检查用户权限
myuser.hasperm('appname.haha') # 传递参数时要加入model所属app
# 或是在HTML模板里
{% if perms.appname%} #
<p>You have permission to do something in the appname.</p>
{% if perms.appname.can_vote %}
<p>You can vote!</p>
{% endif %}
{% else %}
<p>You dont have permission to do anything in the appname.</p>
{% endif %} # 增删权限
myuser.user_permissions.add(per1,per2)
myuser.user_permissions.remove(per1,per2)
myuser.user_permissions.clear() # 清空权限 user.get_all_permissions() # 列出用户所有权限,返回值为permission_name的list
user.get_group_permissions() # 列出用户 所属group的权限

三、界面信息展示

1、后端传回queryset,前端用 模板语言遍历到表格中。若是想用datatable处理之,则在datatable初始化时对各列重命名,例

<tbody>

{% for a in queryset %}
<tr>
<td hidden>{{a.id}}</td>
<td>{{ a.name }}</td>
</tr>
{% endfor %} </tbody> <script>
var table = $('#table_id').DataTable({
columns:[
{data:'id'},
{data:'name'},
]
})
table.select.style('os') # 想多选行时使用
</script>

2、前端在datatable中直接通过自带的ajax功能,获取数据。

1、登录认证 参考

https://www.cnblogs.com/lvye001/p/10141365.html

https://www.cnblogs.com/zhanghongfeng/p/8331493.html

Django开发汇总的相关教程结束。