【测试人员兼职指南】利用专业技能:如何从测试转向开发赚钱

一、赚钱:无论何时何地,它从来都不寒碜

题主至今尝试性承接兼职以来,赚了也有小几千了,虽然这点钱,赚了花了也没啥感觉,收入支出并没有多大变化,但是这种助人为乐、好为人师的情绪却是饱满了不少,在跟雇主的沟通过程中发现,他们并不是很在行开发或者具有开发者思维,或许因为他们大多数是初学者或者是学生的身份,所以在收取酬劳的时候 ,多少有些恻隐之心,只想尽可能的帮助到他们,从1到500不等,至今最高才500/次;所以话不多说,先看雇主的诉求,题主又是如何入坑开发的!

tips:做兼职时千万要忘记自己原有的职业,否则兼职做事很受限制!
譬如题主本职是测试,但偶尔可以做一些开发、运维等岗位的工作(都是初阶的)!

在这里插入图片描述
在这里插入图片描述在这里插入图片描述

二、分析:永远不要相信解决一个问题就真的只是一个问题

作为一个测试,如果相信开发提测的代码没有质量问题,那么他的测试职业生涯也就该结束了,命运这东西还是掌握在自己手里会放心的多。并且作为一员10+年测试老兵,就算是做兼职,也不要盲目去相信别人提交的代码,他要是没问题也就不会来找你解决了,所以经过一番自测,得出结论如下:
1、登录问题,没有校验账号密码为空的情况,从源码来看,登录成功之后的页面跳转也有问题;
2、注册问题,正常一点的注册都需要做二次密码确认,再有注册时需要避免账号名重复
3、原本解读的需求是:用户登录成功之后,需要跳转到首页,(附加:在首页显示用户名)
4、再额外附加一个需求:用户在首页点击退出之后需要清除当前token缓存,恢复未登录状态

2.1、登录源码:页面跳转
  • 先解决登录跳转问题,从源码看就是页面重定向问题
def login(request):
    if request.method == 'GET':
        return render(request, 'userApp/login.html')

    if request.method == 'POST':
        # 如果登录成功,返回baidu界面
        name = request.POST.get('name')
        passwor = request.POST.get('passwor')
        # 查询用户是否在数据库中
        if Users.objects.filter(u_name=name).exists():
            user = Users.objects.get(u_name=name)
            if check_password(passwor, user.u_password):
                return HttpResponseRedirect('base.html')
            else:
                return render(request, 'userApp/login.html', {'passwor': '用户密码错误'})
        else:
            return render(request, 'userApp/login.html', {'name': '用户不存在'})

在这里插入图片描述

错在校验帐号密码正确了,却跳转到base.html,不应该是去/首页就行了吗?所以需要修改return HttpResponseRedirect(“/”)

# 查询用户是否在数据库中
if Users.objects.filter(u_name=name).exists():
    user = Users.objects.get(u_name=name)
    if check_password(passwor, user.u_password):
        return HttpResponseRedirect('/')

留下一个思考题:redirect和HttpResponseRedirect的区别,貌似使用哪个都能正确跳转

2.2、登录/注册:避免重复帐号注册
  • 因为是测试嘛,难免会注册多个一样的账号,所以造成登录时出现返回多用户
    在这里插入图片描述
    在这里插入图片描述

从错误截图不难看出,它return了两个帐号,在代码user = Users.objects.get(u_name=name)处就报错了;然后去数据库求证,使用navicat工具连接sqlite3数据库检查用户表,果然出现了大量的重复帐号数据;所以找到用户views.py模块修改注册函数;顺带加了二次确认密码的逻辑

def regist(request):
    # 一开始不要判断GET,直接return一个html模版即可
    if request.method == 'POST':
        # 注册
        name = request.POST.get('name')
        passwor = request.POST.get('passwor')
        passwor2 = request.POST.get('passwor2')

        # 注册加了些逻辑,帐号不存在、是否输入密码
        if not all([name, passwor, passwor2]):
            return render(request, './regist.html', {"messagesbox": "×帐号或密码不能为空,请重新输入!"})

        if Users.objects.filter(u_name=name).exists():
            # messages.success(request, "用户已存在,请重新注册!")
            return render(request, './regist.html', {"messagesbox": "×用户已存在,请重新注册!"})

        if passwor != passwor2:
            # messages.success(request,"两次密码输入不正确,请重新确认密码!")
            return render(request, './regist.html', {"messagesbox": "×两次密码不正确,请重新输入!"})

        # 以上不为空、不重复帐号、两次密码正确,才对密码进行加密,然后再创建用户
        passwor = make_password(passwor)
        Users.objects.create(u_name=name, u_password=passwor)
        return HttpResponseRedirect(reverse('userApp:login'))
    return render(request, './regist.html')
  • 修改regist.html页面:
<form action="" method="POST">
    {% csrf_token %}
    注册学号:<input type="text" name="name" value=""><br>
    注册密码:<input type="passwor" name="passwor"><br>
    确认密码:<input type="passwor" name="passwor2"><br> <!-- 二次确认密码 -->
    <div id="mydiv">
        <span class="mystyle"> {{ messagesbox }} </span> <!--变量要与函数返回的名字保持一致-->
    </div>
    <input type="submit" value="提交">
</form>

在这里插入图片描述

2.3、用户登录之后,需要在首页显示用户名

在这里插入图片描述

  • 先修改base.html页面:找到登录按钮那部分
{# 判断是否已经登录;这里可以保持登录态 #}
            {% if request.session.user_name|default:'' != '' %}
			{# default过滤器进行判断如果request.session.user_name不等于空字符串则用户登陆状态为true #}
			{# 也就是说当用户为已登陆状态时则显示用户名 #}
			
			<div class="col-md-3 hidden-xs">
				欢迎您:<span>{{ request.session.user_name }} | </span>
				<a href="{% url 'userApp:loginOut' %}">退出</a></em>
			</div>
			{% else %}
			{# 由if判断是否登录来显示按钮功能 #}
			<div class="col-md-3 hidden-xs">
				<div class="caption">
					<a href="{% url 'userApp:login' %}" role="button">登录</a>
				</div>
			</div>
			{% endif %}
  • 再修改登录函数,密码校验无误之后,将用户昵称放在session里给页面使用
# 查询用户是否在数据库中
if len(Users.objects.filter(u_name=name)) == 1:  # 源码Users.objects.filter(u_name=name).exists()
    user = Users.objects.get(u_name=name)
    if check_password(passwor, user.u_password):
        request.session['user_name'] = name  # 这行代码就是给base用的,需要将登录成功的用户名放在session里
        # 这个是路径问题,你的base模版需要到哪里去,
        return redirect('/')
2.4、附加一个功能,就是退出

退出很简单,题主的理解就是刷新session让它消失;html页面已经在base中写好了:退出

def loginOut(request):
    auth.logout(request)
    return redirect('/')

三、结尾:不管是开发还是测试,只要能赚钱,在IT岗都要能吃得下

题主结果的项目已经算是形形色色了,从python到java环境部署、从自动化测试到Python开发,兼职都快要把题主给榨干了,你想啊,除了测试/运维意外,开发的活儿,题主真的是绞尽脑汁才能做得出来,当然也确实有做不出来的,主要是时间成本/学习成本过大,不划算;没错,就是学习成本,你可能不知道,有些需求都是题主临阵磨枪找资料摸索解决的,虽然报酬一般,但是技能也算得上初窥门径了,再有同样的活儿也能单手接下了。
So,不管怎样,人总是需要有进步,还要想办法多赚钱,这样或许人生有点意思的事情,共勉吧,少年!
日拱一卒无有尽,功不唐捐终入海。

扩展1:Django可以使用sqlite3轻量级数据库
  • 这样着实方便,省去了自己搭建或去找远程数据库服务器的时间
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), # 指定本地数据库文件路径
    }
}
扩展2:需求方没有提及的后台管理

python manage.py createsuperuser

在这里插入图片描述
访问:http://127.0.0.1:8000/admin
在这里插入图片描述
登录成功的页面
在这里插入图片描述

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

职说测试

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值