Django图书荐购云平台开发与实践 - 5图书馆模块
图书馆模块包括图书馆的资料信息、图书馆审核读者、图书馆对荐购图书的反馈以及图书馆对评论的回应。
- 图书馆的资料信息应包括图书馆的名称、地址、联系人和联系方式。
- 图书馆需要审核读者的身份信息,是否是该馆读者,审核通过的才能向该馆荐购图书。
- 图书馆可以对被荐购图书进行处理,包括已接受荐购、正在购买中、图书已到馆、图书已上架和未采纳荐购,并给出未采纳的理由。
- 图书馆管理员可以对评论进行回复,屏蔽或删除某条评论或者某个人的所有评论。
图书馆的资料信息在前面的user模块已经实现,只需要在admin后台添加图书馆的资料即可。
这部分我们将要实现图书馆审核读者身份、对荐购图书处理的功能,评论部分我们留到下个模块再实现。
首先实现读者的身份审核,思路是新注册的读者需要提交个人的实名信息,包括姓名、学号/工号、Email等必填信息,以及部分其他选填信息。新注册的读者属于普通读者用户组,没有荐购权限,在图书馆对读者的身份进行核实后,图书馆管理员可以将用户放入认证读者组,获得荐购权限。
具体实现路径是:首先判断用户是否图书馆管理员身份,如果是则可以进入图书馆后台管理,如果不是提示用户无权限进入。图书馆后台管理的首页分两部分,一是展示所属馆的读者及读者身份,可以按读者注册时间排序或读者身份排序;另一部分是对读者的荐购进行处理,并将荐购的具体处理进程更新在荐购反馈中。
首先在网站的导航部分增加荐购管理的入口,做一个权限判断,如果有荐购管理的权限则显示。
{% if perms.recommend.change_recommend %}
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" data-toggle="dropdown" href="#">荐购管理</a>
<div class="dropdown-menu">
<a class="dropdown-item" href="{% url 'lib_useradmin' %}">用户管理</a>
<a class="dropdown-item" href="{% url 'lib_recadmin' %}">荐购管理</a>
</div>
</li>
{% endif %}
上面的代码中对用户做了是否有change_recommend的权限,如果有则显示该入口。导航做成下拉列表式。包含两个链接地址分别为 'lib_useradmin' 和'lib_recadmin'的URL,表示读者用户管理和荐购管理。下面到urls.py中定义该URL地址信息。
#library 的 urls.py
from django.urls import path
from . import views
#设置URL的地址信息
urlpatterns = [
path('lib_useradmin/', views.LibUserAdminView, name='lib_useradmin'),
path('lib_recadmin/', views.LibRecAdminView, name='lib_recadmin'),
]
在此之前不要忘记到项目根目录的urls.py中将library包含进来。
#项目根目录urls.py
path('library/', include('library.urls')),
定义好URL后就是编写对应的视图函数了。
读者用户管理
读者用户管理主要是对读者的权限做一个审核,所以需要展示所属馆的读者资料,以及为管理员添加一个验证按钮。如下图所示。
image.png
在做这项工作之前,需要到user模块下为MyUser模型增加一个is_verify的字段,这个字段我们用来判断用户有没有通过身份验证,通过验证的按钮用绿色表示,未通过的按钮为黄色。
用户管理的视图函数如下:
from django.shortcuts import render
from user.models import Library, MyUser
from django.contrib.auth.decorators import login_required,permission_required
from django.contrib.auth.models import Group
#登陆验证和身份验证
@login_required(login_url='/user/login.html')
@permission_required(perm='recommend.change_recommend')
def LibUserAdminView(request):
#如果通过GET方法获取到用户的id,则说明管理员在确认读者身份
if request.GET.get('uid'):
#如果获取到参数verify则说明管理员是在通过验证读者身份,否则是在取消读者的身份验证
if request.GET.get('verify'):
#获取该读者的用户模型对象
user = MyUser.objects.get(id=request.GET.get('uid'))
#将该读者添加到认证读者组
user.groups.add(Group.objects.get(id=2))
#将用户认证状态设为True
user.is_verify = 1
user.save()
else:
#获取该读者的用户模型对象
user = MyUser.objects.get(id=request.GET.get('uid'))
#将该读者添加到认证读者组
user.groups.remove(Group.objects.get(id=2))
#将用户认证状态设为True
user.is_verify = 0
user.save()
#获取该用户所属馆的馆名
lib_name = request.user.lib_id
#获取该馆下所有用户
lib_users = MyUser.objects.select_related('lib_id').filter(lib_id__lib_name=lib_name)
return render(request, 'lib_useradmin.html', locals())
大概解释下流程,具体代码中已经注释的很明确。首先对用户做登陆验证和权限认证,然后根据管理员是要验证读者还是取消验证,做不同的选择,最后获取该用户的馆名以及该馆下的所有读者,返回给模板lib_useradmin.html。
图书荐购管理
图书荐购管理主要是为了实现图书馆处理读者的荐购,对荐购及时给出反馈。因此,需要展示该馆下所有荐购的图书,并可以对荐购图书的处理流程进行操作。
image.png
模板文件和用户管理的差不多,下面主要介绍视图处理函数。
@login_required(login_url='/user/login.html')
@permission_required(perm='recommend.change_recommend')
def LibRecAdminView(request, page):
#获取该用户所属馆的馆名
lib_name = request.user.lib_id
#获取所有荐购反馈的状态
processrecommend = Feedback.objects.all()
#如果是POST请求,则说明是管理员在处理荐购反馈,select是接收的反馈状态的值,rec_id是荐购表recommend的id
if request.method == 'POST':
select = request.POST.get('sel')
rec_id = request.POST.get('rec_id')
Recommend.objects.filter(rec_id=rec_id).update(feed_id=select)
#获取该馆下所有荐购记录,这里的查询是三表联查,意思是查询Recommend的外键user_id关联表MyUse的外键lib_id关联表的lib_name字段值为lib_name的所有数据。注意外键之间的连接是双下划线'__'
recommends = Recommend.objects.select_related('user_id__lib_id').order_by('-rec_id').filter(user_id__lib_id__lib_name=lib_name)
#分页
paginator = Paginator(recommends, 10)
try:
pageInfo = paginator.page(page)
except PageNotAnInteger:
pageInfo = paginator.page(1)
except EmptyPage:
pageInfo = paginator.page(paginator.num_pages)
return render(request, 'lib_recadmin.html',locals())
图书荐购的管理的逻辑是这样的,首先验证用户的登录和权限,然后判断用户的请求方式,如果是POST请求,则说明用户是在更改荐购反馈,将新的反馈id更新到该条荐购记录中。如果是GET请求,则获取该馆所有荐购记录传给模板文件。这里涉及到一个三表联查,比较复杂,博主在这里卡了比较久,需要细细品味,如果不清楚,可以看博主前面的文章,模型和数据库。