>[success] # 用来处理用户信息
~~~
1.用来保存当前访问 用户的session = {}
2.random_str 生成随机的sessionid
3.template 读取html文件
4.current_user 判断用户是否登录
5.route_index 请求头+body + username判断+响应返回
6.response_with_headers 定制响应头
7.route_login 处理用户登录
8.route_register 用户注册
~~~
>[danger] ##### 代码
~~~
import random
from models import User
from utils import log
from utils import template
# 这个函数用来保存所有的 messages
message_list = []
# 用来保存当前访问 用户的session
session = {}
# 生成一个加密 session id
def random_str():
seed = 'abcdefjsad89234hdsfkljasdkjghigaksldf89weru'
s = ''
for i in range(16):
random_index = random.randint(0, len(seed) - 2)
s += seed[random_index]
return s
def current_user(request):
'''
获取cookies中保存的sessionid 然后从字典中匹配对应的信息
'''
session_id = request.cookies.get('user', '')
username = session.get(session_id, '游客')
if username is not "游客":
username = User.find(username).username
return username
def route_index(request):
"""
主页的处理函数, 返回主页的响应
请求头+body + username判断+响应返回
"""
header = 'HTTP/1.1 210 VERY OK\r\nContent-Type: text/html\r\n'
body = template('index.html')
username = current_user(request)
body = body.replace('{{username}}', username)
r = header + '\r\n' + body
return r.encode(encoding='utf-8')
# 定制响应头
def response_with_headers(headers, status_code=200):
"""
Content-Type: text/html
Set-Cookie: user=gua
"""
header = 'HTTP/1.1 {} VERY OK\r\n'.format(status_code)
header += ''.join(['{}: {}\r\n'.format(k, v)
for k, v in headers.items()])
return header
def redirect(location, headers=None):
if headers is None:
headers = {
'Content-Type': 'text/html',
}
headers['Location'] = location
# 302 状态码的含义, Location 的作用
header = response_with_headers(headers, 302)
r = header + '\r\n' + ''
return r.encode(encoding='utf-8')
def route_login(request):
headers = {
'Content-Type': 'text/html',
}
username = current_user(request)
if request.method == "POST":
# 获取所有post 请求的参数
form = request.form()
# 调用 User 函数
u = User(form)
if u.validate_login():
# 查询用户名密码是否存在
user = User.find_by(username=u.username)
session_id = random_str()
session[session_id] = user.id
log('userid',user.id)
headers['Set-Cookie'] = 'user={}'.format(session_id)
# headers['Set-Cookie'] = 'user_id={}'.format(user.id)
result = '登录成功'
log('headers response', headers)
return redirect('/', headers)
else:
result = '用户名或者密码错误'
else:
result = ''
body = template('login.html',username = username)
header = response_with_headers(headers)
r = header + '\r\n' + body
# log('login', r)
return r.encode(encoding='utf-8')
def route_register(request):
"""
注册页面的路由函数
"""
header = 'HTTP/1.1 210 VERY OK\r\nContent-Type: text/html\r\n'
if request.method == 'POST':
form = request.form()
u = User(form)
if u.validate_register():
u.save()
result = '注册成功<br> <pre>{}</pre>'.format(User.all())
else:
result = '用户名或者密码长度必须大于2'
else:
result = ''
body = template('register.html')
body = body.replace('{{result}}', result)
r = header + '\r\n' + body
return r.encode(encoding='utf-8')
def route_static(request):
"""
静态资源的处理函数, 读取图片并生成响应返回
"""
filename = request.query.get('file', 'doge.gif')
path = 'static/' + filename
with open(path, 'rb') as f:
header = b'HTTP/1.1 200 OK\r\nContent-Type: image/gif\r\n\r\n'
img = header + f.read()
return img
route_dict = {
'/': route_index,
'/login': route_login,
'/register': route_register,
}
~~~
- 网络原理
- 为搭建框架做准备
- 简单认识网路
- 自定义模拟网站案例
- 优化最终框架
- 数据存储 -- data
- 用户个人信息存储 -- User.txt
- 路由映射 -- routes
- 处理用户信息 -- routes_static.py
- 保存静态文件 -- static
- templates -- html 集中处理模块
- 首页 -- index.html
- 登陆 -- login.html
- 用户注册页面 -- register
- 日志模块 -- log.gua.txt
- 启动文件--server.py
- orm处理 -- model.py
- 日志模块 -- utils.py
- 两种数据库类型
- 传统数据库了解篇
- 前端快速入门
- JS简单使用入门
- css简单快速入门
- DJANGO
- virtualenv-创建虚拟环境
- 项目结构
- django-admin中文配置
- django-打印sql语句
- django-基础
- 认识MVC和MTV
- Django--初识
- Django--初识案例
- Django-FBV/CBV
- Django--常用input 交互
- Django-url
- Django-url.py 配置
- Django-include 使用
- Django-url name
- Django-ORM
- ORM-数据库配置
- ORM-model字段
- ORM-model字段解释
- ORM-字段选项
- ORM-查询
- ORM-四种常用查询方法
- ORM-三种获取数据
- ORM-其他查询方式
- ORM-条件查询双线
- ORM-Q和F条件使用
- ORM-三种数据库交互
- 案例 -- 一对多
- ORM-技巧/常见问题
- ORM-N+1 问题
- ORM-并发的处理
- ORM-数量查询、
- ORM-正向反向查询
- ORM-基础案例一
- ORM-基础一对多案例
- Django-templates
- Django-模板的继承
- Django-模板的过滤
- Django-自定义模板的过滤
- Django-cookie
- Django-cookies 装饰器
- Djang-session
- Django-CSRF
- Django-中间件 -- 后续了解
- Django- 缓存 -- 没有深入了解
- Django-form
- From-ajax
- form-内部验证处理
- form-属性
- form-常用的标签字段
- form-常用的下拉和选择
- form-widget速查
- Django-ajax序列化
- Django-多种ajax写法
- ajax-原生写法
- ajax-$写法
- ajax-ifram
- Django-ajax图片上传
- ajax-原始写法
- ajax-正常写法
- iframe+form
- 实战写法
- Django-常用自编写组件
- Django-双菜单组合搜索
- Django - 多菜单组合搜索
- Django-分页
- django-综合基础
- 综合基础-render
- django-admin
- admin-页面配置
- admin-字段配置
- admin-编辑页面
- admin-forms验证
- admin-创建抽象类
- django-验证码
- 验证码-第三方生成库
- 验证码-view.py使用
- 验证码-注意引入Monaco.ttf
- django-用户注册
- 注册-form 模块
- 注册-views 模块
- 注册-html模块
- 注册-model模块
- django-用户登录三种
- session登录
- form-session 写法
- view-写法
- Html-写法
- model-写法
- 继承类登录
- 外键关联登录
- django-简单的student 管理案例
- app-urls.py
- app-models.py配置
- admin-admin.py配置
- app-form.py 和数据库关联的写法
- app-FBV_views.py
- app-CBV_views.py
- templates-index.html
- django-博客系统
- APP目录-models.py 创建
- APP目录-基础展示数据分析
- APP目录-基础数据展示cls
- ListView
- DetailView
- FormView
- 额外功能拓建
- 添加文章搜索/用户文章查询功能
- 增加一个友情链接
- 增加一个评论模块
- App-利用Bootstrap4 搭建样式
- 项目crm
- 思维导图
- perfectCRM-项目名字
- settings.py-配置
- view.py-登陆/登出函数
- crm-app文件
- model.py-表的创建
- admin.py-注册后台
- view.py-视图层
- static-静态文件
- css
- bootstrap.min.css
- dashboard.css
- ie10-viewport-bug-workaround.css
- signin.css
- fonts
- imgs
- js
- jquery.js
- bootstrap.min.js
- holeder.js
- ie10-viewport-bug-workaround.js
- ie-emulation-modes-warning.js
- plugins
- html模板文件-templates
- crm
- index.html-首页模板