16,2024年Python大厂面试分享

6.3. 路由


6.3.1. 配置分布式路由

tedu_note/urls.py中,将所有user/***相关路由转交给user处理

from django.contrib import admin

from django.urls import path, include

urlpatterns = [

path(‘admin/’, admin.site.urls),

path(‘user/’, include(‘user.urls’))

]

在这里插入图片描述

6.3.2. 配置子路由

from django.urls import path

from . import views

urlpatterns = [

path(‘reg’, views.reg_view)

]

在这里插入图片描述

6.4. 视图函数


def reg_view(request):

注册

if request.method == ‘GET’:

GET 返回界面

return render(request, ‘user/register.html’)

elif request.method == ‘POST’:

POST 处理提交数据

username = request.POST[‘username’]

password_1 = request.POST[‘password_1’]

password_2 = request.POST[‘password_2’]

1. 两个密码要保持一致

if password_1 != password_2:

return HttpResponse(‘两次密码输入不一致’)

2. 用户名是否可用

old_users = User.objects.filter(username=username)

if old_users:

return HttpResponse(‘用户名已注册’)

3. 插入数据【明文密码处理】

User.objects.create(username=username, password=password_1)

return HttpResponse(‘注册成功’)

在这里插入图片描述

6.5. 测试


基础代码编写完成后,进行测试成功

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

七、注册问题 — 优化

======================================================================

  • 密码如何处理

  • 插入问题

  • 产品经理要求注册则免登录一天,如何实现

7.1. 哈希算法


哈希算法 —— 给定明文,计算出一段定长的,不可逆的值

7.1.1. 特点

  • 定长输出:不管明文输入长度为多少,哈希值都是定长的。md5 - 32位16进制

  • 不可逆:无法反向计算出对应的明文

  • 雪崩效应:输入改变,输出必然变

7.1.2. 使用场景

  1. 密码加密

  2. 文件完整性校验

7.1.3. 如何使用

python3内置hashlib哈希算法包

import hashlib

m = hashlib.md5()

m.update(b’123456’)

m.hexdigest()

如果想要生成别的哈希值,需要重新生成hashlib…。不然就是字符串拼接

在这里插入图片描述

7.1.4. 密码加密

在这里插入图片描述

7.1.5. 测试

重新注册查看数据库,存储加密后的密码

在这里插入图片描述

7.2. 并发写入


在数据进行插入执行create操作的时候,如果并发量高了,多用户同时注册,可能会出现同时执行create的情况,如果申请用户名一致,则会报错。

解决方案:

在插入的时候,try…catch…一下

try:

User.objects.create(username=username, password=password)

except Exception as e:

有可能报错 重复插入【唯一索引注意并发写入问题】

print(‘–create user error %s’ % e)

return HttpResponse(‘用户名已注册’)

return HttpResponse(‘注册成功’)

在这里插入图片描述

7.3. 免登录


在session中存储用户信息

免登录一天

request.session[‘username’] = username

request.session[‘uid’] = user.id

八、用户登录

=================================================================

  • url:/user/login

  • 视图函数:login_view

  • 模板位置:templates/user/login.html

  • 页面样式:

  • 流程:

  • 发送GET请求的话,返回界面

  • 点击登录发送POST请求,进行登录

8.1. 模板界面


登录

用户名:

密码:

记住用户名

在这里插入图片描述

8.2. 路由


from django.urls import path

from . import views

urlpatterns = [

path(‘reg’, views.reg_view),

path(‘login’, views.login_view)

]

在这里插入图片描述

8.3. 访问逻辑


在这里插入图片描述

8.4. 视图函数


如果点击记住用户名,则在浏览器端存储cookies

def login_view(request):

登录

if request.method == ‘GET’:

return render(request, ‘user/login.html’)

elif request.method == ‘POST’:

username = request.POST[‘username’]

password = request.POST[‘password’]

try:

user = User.objects.get(username=username)

except Exception as e:

print(‘–login user error %s’ % e)

return HttpResponse(‘用户名或密码错误’)

比对密码

m = hashlib.md5()

m.update(password.encode())

if m.hexdigest() != user.password:

return HttpResponse(‘用户名或密码错误’)

记录会话状态

request.session[‘username’] = username

request.session[‘uid’] = user.id

resp = HttpResponse(‘登录成功’)

判断用户是否点选了’记录用户名’

if ‘remember’ in request.POST:

点选了 → Cookies 存储 username,uid 时间 3

resp.set_cookie(‘username’, username, 3600243)

resp.set_cookie(‘uid’, user.id, 3600243)

return resp

8.5. 测试


在这里插入图片描述

九、用户登录 — 优化

======================================================================

用户登录流程

获取界面后

  1. 请求登录界面

  2. 服务器端检查session

  3. session有数据的话,直接跳转主界面

  4. session没有数据的话,检查浏览器端cookie,如果cookie有数据,跳转主界面

  5. session没有数据、cookie没有数据的话,跳转登陆界面

def login_view(request):

登录

if request.method == ‘GET’:

检查登录状态,如果登陆了,显示’已登录’

if request.session.get(‘username’) and request.session.get(‘uid’):

return HttpResponse(‘已登录’)

检查Cookies

c_username = request.COOKIES.get(‘username’)

c_uid = request.COOKIES.get(‘uid’)

if c_username and c_uid:

回写session

request.session[‘username’] = c_username

request.session[‘uid’] = c_uid

return HttpResponse(‘已登录’)

return render(request, ‘user/login.html’)

elif request.method == ‘POST’:

···

在这里插入图片描述

十、网站首页

=================================================================

  • url:/index

  • 视图函数:index_view

  • 模板位置:templates/index/index.html

  • 界面样式

在这里插入图片描述

10.1. 创建新项目


10.1.1. 生成项目

$ python3 manage.py startapp index

在这里插入图片描述

10.1.2. 注册

在这里插入图片描述

10.2. 模板界面


首页

{% if request.session.username %}

欢迎{{ request.session.username }}

退出登录

进入我的笔记

{% else %}

{% if request.COOKIES.username %}

欢迎{{ request.COOKIES.username }}

退出登录

进入我的笔记

{% else %}

登录

注册

{% endif %}

{% endif %}

在这里插入图片描述

10.3. 路由


在这里插入图片描述

10.4. 视图函数


def index_view(request):

return render(request, ‘index/index.html’)

在这里插入图片描述

10.5. 测试


在这里插入图片描述

10.6. 修改登录注册视图函数


改为跳转到首页

from django.http import HttpResponse, HttpResponseRedirect

from django.shortcuts import render

from .models import User

import hashlib

Create your views here.

def reg_view(request):

注册

if request.method == ‘GET’:

GET 返回界面

return render(request, ‘user/register.html’)

elif request.method == ‘POST’:

POST 处理提交数据

username = request.POST[‘username’]

password_1 = request.POST[‘password_1’]

password_2 = request.POST[‘password_2’]

1. 两个密码要保持一致

if password_1 != password_2:

return HttpResponse(‘两次密码输入不一致’)

哈希算法 —— 给定明文,计算出一段定长的,不可逆的值 md5 sha256

m = hashlib.md5()

m.update(password_1.encode())

password = m.hexdigest()

2. 用户名是否可用

old_users = User.objects.filter(username=username)

if old_users:

return HttpResponse(‘用户名已注册’)

3. 插入数据【明文密码处理】

try:

user = User.objects.create(username=username, password=password)

except Exception as e:

有可能报错 重复插入【唯一索引注意并发写入问题】

print(‘–create user error %s’ % e)

return HttpResponse(‘用户名已注册’)

免登录一天

request.session[‘username’] = username

request.session[‘uid’] = user.id

TODO:修改session存储时间为1天

return HttpResponse(‘注册成功’)

return HttpResponseRedirect(‘/index’)

def login_view(request):

登录

if request.method == ‘GET’:

检查登录状态,如果登陆了,显示’已登录’

if request.session.get(‘username’) and request.session.get(‘uid’):

return HttpResponse(‘已登录’)

return HttpResponseRedirect(‘/index’)

检查Cookies

c_username = request.COOKIES.get(‘username’)

c_uid = request.COOKIE.get(‘uid’)

if c_username and c_uid:

回写session

request.session[‘username’] = c_username

request.session[‘uid’] = c_uid

return HttpResponse(‘已登录’)

return HttpResponseRedirect(‘/index’)

return render(request, ‘user/login.html’)

elif request.method == ‘POST’:

username = request.POST[‘username’]

password = request.POST[‘password’]

try:

user = User.objects.get(username=username)

except Exception as e:

print(‘–login user error %s’ % e)

return HttpResponse(‘用户名或密码错误’)

比对密码

m = hashlib.md5()

m.update(password.encode())

if m.hexdigest() != user.password:

return HttpResponse(‘用户名或密码错误’)

记录会话状态

request.session[‘username’] = username

request.session[‘uid’] = user.id

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img



既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Python开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注Python)
img

最后

🍅 硬核资料:关注即可领取PPT模板、简历模板、行业经典书籍PDF。
🍅 技术互助:技术群大佬指点迷津,你的问题可能不是问题,求资源在群里喊一声。
🍅 面试题库:由技术群里的小伙伴们共同投稿,热乎的大厂面试真题,持续更新中。
🍅 知识体系:含编程语言、算法、大数据生态圈组件(Mysql、Hive、Spark、Flink)、数据仓库、Python、前端等等。

简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。**
[外链图片转存中…(img-g0gWPsvN-1711607276796)]
[外链图片转存中…(img-XelHOejv-1711607276797)]



既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Python开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注Python)
[外链图片转存中…(img-Z15QCUzT-1711607276797)]

最后

🍅 硬核资料:关注即可领取PPT模板、简历模板、行业经典书籍PDF。
🍅 技术互助:技术群大佬指点迷津,你的问题可能不是问题,求资源在群里喊一声。
🍅 面试题库:由技术群里的小伙伴们共同投稿,热乎的大厂面试真题,持续更新中。
🍅 知识体系:含编程语言、算法、大数据生态圈组件(Mysql、Hive、Spark、Flink)、数据仓库、Python、前端等等。

  • 18
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值