分页器
- 优化加载
- Paginator
- 将数据源分割成一页一页的数据
- Page
- 具体的某一页数据
分页加载实现
- 从请求中接收page_number参数
- 查询显示
- 使用bootstrap
- 粘贴样式
- class
- 页码问题
- 迭代页面范围
- 上一页下一页
- 注意是否存在上一页,下一页
views.py:
def get_students(request):
students = S()
# 指定页数
page_num = in("page", 1))
# 将学生进行分页
paginator = Paginator(students, 10)
# 获取指定页面的学生
page = (page_num)
data = {
"students": ,
"page_object": page,
"page_range": _range,
}
return render(request, 'S;, context=data)
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
绘制验证码的步骤
- 绘制验证码
# 绘制验证码
def get_verify_code(request):
# 设置画布大小
image_size = (200, 100)
# 设置画布背景颜色
image_color = get_color()
# 生成画布
image = Image.new("RGB", image_size, image_color)
# 导入字体 设置字体大小
image_font = Image('/home/intro/django/day07/DjangoAdvanced/static/fon;,
size=60)
# 生成画笔
image_draw = ImageDraw.Draw(image, "RGB")
# 字符串库
source_str = "1234567890qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM"
dest_str = ""
# 取四次字符
for i in range(4):
r = random.randrange(len(source_str))
dest_str += source_str[r]
# 将dest_str存到session中
reque['verifycode'] = dest_str
# 起点,需要画的内容,实例化字体
# image_draw.text((20, 30), "q", font=image_font)
# image_draw.text((65, 30), "W", font=image_font)
# image_draw.text((110, 30), "e", font=image_font)
# image_draw.text((155, 30), "R", font=image_font)
for i in range(4):
image_draw.text((20 + 45 * i, 20), dest_str[i], fill=get_color(), font=image_font)
# 干扰点
for i in range(1000):
image_draw.poin(200), random.randrange(100)), fill=get_color())
# 实例化一个IO流
buffer = BytesIO()
# 将图片存储到流中 格式是png
image.save(buffer, "png")
return HttpResponse(), content_type="image/png")
# 生成随机颜色
def get_color():
r = random.randrange(256)
g = random.randrange(256)
b = random.randrange(256)
return (r, g, b)
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 登录时 验证验证码
# 返回登录界面
def user_login(request):
return render(request, 'U;)
# 执行登录
def do_user_login(request):
#获取用户输入的验证码
verify_code = reque("verifycode")
#系统生成的验证码
dest_code = reque.get('verifycode')
#判断输入的验证码是否正确,并且忽略大小写
if veri() == de():
return HttpResponse('验证成功')
return HttpResponse("验证失败")
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
富文本(略)
缓存机制
- 浏览器有这样一个缓存机制
- 当页面发生差量更新的时候,局部更新的时候,是根据url判定是够发生了更新的
创建本地缓存的表
python manage.py createcachetable cachetable
- 1
# 使用装饰器 缓存时间为20s
@cache_page(20)
def get_sleeping(request):
sleep(5)
print("学习,断片了")
return HttpResponse("我不是故意的")
# 不使用装饰器 自己写缓存
def get_last(request):
# 从缓存中获取缓存
result = cac("get_last")
# 如果存在直接返回
if result:
return HttpResponse(result)
# 睡6s
sleep(6)
print("你完了")
students = S()
data = {
"students": students,
}
#渲染模板 返回数据
result = loader.get_template('S;).render(context=data)
#保存缓存 cac(缓存名, 缓存数据, 缓存时长)
cac("REMOTE_ADDR") + 'get_last', result, timeout=20)
return HttpResponse(result)
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
homework
- 使用markdown插件