首页  > 精英论坛 > 【测试人员兼职指南】利用专业技能:如何从测试转向开发赚钱

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

精英论坛 2025-11-16 19:00:20 6121

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

题主至今尝试性承接兼职以来,赚了也有小几千了,虽然这点钱,赚了花了也没啥感觉,收入支出并没有多大变化,但是这种助人为乐、好为人师的情绪却是饱满了不少,在跟雇主的沟通过程中发现,他们并不是很在行开发或者具有开发者思维,或许因为他们大多数是初学者或者是学生的身份,所以在收取酬劳的时候 ,多少有些恻隐之心,只想尽可能的帮助到他们,从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页面:

{% csrf_token %}

注册学号:

注册密码:

确认密码:

{

{ messagesbox }}

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

先修改base.html页面:找到登录按钮那部分

{# 判断是否已经登录;这里可以保持登录态 #}

{% if request.session.user_name|default:'' != '' %}

{# default过滤器进行判断如果request.session.user_name不等于空字符串则用户登陆状态为true #}

{# 也就是说当用户为已登陆状态时则显示用户名 #}

{% else %}

{# 由if判断是否登录来显示按钮功能 #}

{% 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登录成功的页面


友情链接:
Copyright © 2015 BOSS网游 - 高价值游戏活动发现中心 All Rights Reserved.