测试开发实践:Web平台之用户信息

上一篇 / 下一篇  2022-08-29 17:11:46 / 个人分类:软件测试

一. 回顾

在第一篇文章《手把手教你做测开:开发Web平台之环境准备》中,我们做了以下几件事情:加我VX:atstudy-js 回复“测试”,进入 自动化测试学习交流群~~

  1. 搭建了前后端项目工程

  2. 安装了前后端的依赖

  3. 配置并启动了前后端服务

  4. 创建了后端子应用

  5. 将Rest Framework和数据库连接信息配置进后端的配置文件中

在上篇文章中,我们做了以下几件事情:

  1. 后端登录认证的实现

  2. 前后端服务关联配置

  3. 前端登录逻辑的梳理

  4. 前端登录逻辑的修改

  5. 跨域问题的解决

接下来我们完成以下功能的实现:

  1. 前端用户信息逻辑的梳理

  2. 后端开发获取用户信息接口

  3. 后端自定义ModelViewSet

  4. 前端用户信息逻辑的修改

  5. vuex状态管理

二. 前端用户信息逻辑的梳理

(一). permission.js

回到permission.js文件,可以看到这里的逻辑是,如果在有token的情况下,如果访问的页面非登录页,这时候会从vuex中获取用户名,如果用户名存在,就跳转到该页,如果用户名不存在,表示是第一次登录,需要通过store目录下的user.js文件中的getInfo方法设置用户信息。

(二). store

继续切换到store/modules/user.js文件中,我们通过后端定义获取用户信息接口,因为已经在headers中带入了token,所以不需要将state.token作为参数传给getInfo方法,这里的state.token将来一定要修改。

另外,可以看到const { name, avatar } = data就是从响应结果里获取name、avatar(用户头像),commit是分别设置name、avatar到vuex中。响应结果里一定要有name和avatar字段,那有可能这两个字段并不一定在data对象中,因此这块可能要做修改。这是优化点一。

(三). api

在上述方法中点击下面那个getInfo,可以跳转到api目录下的user.js文件中,这个getInfo方法的url是前端自己定义的,到时候需要改成后端接口的路径,另外还要将url路径中的token去掉,这是优化点二。

(四).总结

综上所述,我们前端需要修改的地方有:

  1. 将modules目录下的users.js文件中的getInfo方法传入state.token参数取消掉,将commit时候的传参可能要修改下

  2. ​将api目录下的user.js文件中的getInfo方法,其url替换为后端接口路径,其token传参取消掉

三. 后端开发获取用户信息接口

(一). 用户信息模型类

在 userauth 子应用下的 models.py 文件中定义 UserProfile 模型类。这里需要将UserProfile 和 User 类一对一关联起来,一个用户对应一条个人信息,一条个人信息对应着一个用户。这里定义的 user 字段将来生成的表中展示为 user_id,对应的是 user 表中的id。

from django.db import models

from django.contrib.auth.models import User

class UserProfile(models.Model):

#UserProfile 类和 User 类是一对一关系,即一个 User 对应着一个人信息,一个人信息对应着一个 User

user = models.OneToOneField(User, on_delete=models.CASCADE, related_name='profile')

avatar = models.CharField(max_length=100, null=True, blank=True, verbose_name="avatar")

role = models.CharField(max_length=10, default="editor", verbose_name="role")

introduction = models.TextField(max_length=500, null=True, blank=True, verbose_name="introduction")

class Meta.:

verbose_name = "user_profile" verbose_name_plural = verbose_name

def __str__(self):

return "{}".format(self.user.__str__())

(二). 自定义 ModelViewSet

为什么要自定义 ModelViewSet 而不直接继承 ModelViewSet,因为 ModelViewSet 返回的响应结果没有 code(CURD 中有部分没有),没有 message,只有 data。因此需要将其改造成我们想要的形式。

在后端项目工程 backend 目录下创建一个 utils 目录,在 utils 目录下创建一个customized_drf.py 文件,这里设置了权限,定义了响应数据的格式和分页。

from collections import OrderedDict

import six

from django.db.models import Count, Sum

from rest_framework.response import Response

from rest_framework.serializers import Serializer

from rest_framework.pagination import PageNumberPagination

from rest_framework.viewsets import ModelViewSet, GenericViewSet

from rest_framework import filters

from django_filters.rest_framework import DjangoFilterBackend

from rest_framework.permissions import IsAuthenticated, AllowAny

# 定制化响应数据格式

class JsonResponse(Response): """An HttpResponse that allows its data to be rendered into arbitrary media types.""" def __init__(self, data=None, code=200, message='ok', success='true', status=None, template_name=None, headers=None, exception=False, content_type=None): """ Alters the init arguments slightly. For example, drop 'template_name', and instead use 'data'. Setting 'renderer' and 'media_type' will typically be deferred, For example being set automatically by the `APIView`. """

super(Response, self).__init__(None, status=status)

if isinstance(data, Serializer):

message = (

'You passed a Serializer instance as data, but '

'probably meant to pass serialized `.data` or '

'`.error`. representation.' )

raise AssertionError(message)

self.data = {"code": code, "message": message, "success": success, "data": data}

self.template_name = template_name

self.exception = exception

self.content_type = content_type

if headers:

for name, value in six.iteritems(headers):

self[name] = value

添加微信:atstudy-js  或者扫描下方二维码,备注“博客”邀请你进入Python自动化测试学习交流群~


TAG:

 

评分:0

我来说两句

Open Toolbar