美文网首页
Django图书荐购云平台开发与实践 - 5图书馆模块

Django图书荐购云平台开发与实践 - 5图书馆模块

作者: libdream | 来源:发表于2022-04-12 13:34 被阅读0次

图书馆模块包括图书馆的资料信息、图书馆审核读者、图书馆对荐购图书的反馈以及图书馆对评论的回应。

  1. 图书馆的资料信息应包括图书馆的名称、地址、联系人和联系方式。
  2. 图书馆需要审核读者的身份信息,是否是该馆读者,审核通过的才能向该馆荐购图书。
  3. 图书馆可以对被荐购图书进行处理,包括已接受荐购、正在购买中、图书已到馆、图书已上架和未采纳荐购,并给出未采纳的理由。
  4. 图书馆管理员可以对评论进行回复,屏蔽或删除某条评论或者某个人的所有评论。

图书馆的资料信息在前面的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请求,则获取该馆所有荐购记录传给模板文件。这里涉及到一个三表联查,比较复杂,博主在这里卡了比较久,需要细细品味,如果不清楚,可以看博主前面的文章,模型和数据库

相关文章

网友评论

      本文标题:Django图书荐购云平台开发与实践 - 5图书馆模块

      本文链接:https://www.haomeiwen.com/subject/xzkjbqtx.html