tornado 相关说明

在 users 表中创建记录,做测试

在项目根目录下创建 test.py

# -*- coding: utf-8 -*-
# 斌彬电脑
# @Time : 2019/2/27 0027 下午 12:20 from models.db import DBSession
from models.account import User # 实例工厂类
session = DBSession()
# 实例数据库的类
u = User(name='abc', password='123')
# 把数据库的类加到工厂中
session.add(u)
session.commit()

运行这个文件,就可以在数据库中保存记录

知道怎么向数据库添加数据后,就可以完成用户注册的功能:

在 handlers 的 auth.py 中写个用户注册类,

在 app.py 中设置路由

在 templates 模板文件中 添加 register.html

把测试成功的代码添加到 models 的 account.py 文件中

# -*- coding: utf-8 -*-
# 斌彬电脑
# @Time : 2019/2/27 0027 上午 4:57 from datetime import datetime
from sqlalchemy import (Column,Integer, String, DateTime) from .db import Base,DBSession
session = DBSession() class User(Base):
__tablename__ = 'users'
# 主键,自增长,
id = Column(Integer, primary_key=True, autoincrement=True)
# 唯一的,不可以为空
name = Column(String(100), unique=True, nullable=False)
# 密码 不是空的
password = Column(String(500), nullable=False)
# 创建时间
creatd = Column(DateTime, default=datetime.now) def __repr__(self):
return '<User(#{}: {})'.format(self.id, self.name) @classmethod
def add_user(cls,name, password):
user = User(name=name, password=password)
session.add(user)
session.commit()

  

在 utlis的 auth.py 中引入 models 的 account

# -*- coding: utf-8 -*-
# 斌彬电脑
# @Time : 2019/2/26 0026 上午 9:26 import hashlib # 对密码进行 md5 处理
from models.account import User def hashed(text):
"""哈西处理"""
return hashlib.md5(text.encode('utf8')).hexdigest() USER_DATA = {
'username':'abc',
'password':hashed('123')
} def authenticate(username, password):
"""
校验用户名,密码
:return True or False
"""
if username and password:
is_match = (username==USER_DATA['username'])and (hashed(password)==USER_DATA['password'])
return is_match
else:return False def register(name, password):
"""
用户注册,对密码进行哈西处理
:param name:
:param password:
:return:
"""
# 把密码哈西后存入数据库
User.add_user(name=name, password=hashed(password))

 在 handlers 的 auth.py 中 调用  register 的方法

# -*- coding: utf-8 -*-
# 斌彬电脑
# @Time : 2019/2/26 0026 上午 8:28 import tornado.web
from utlis import auth
from .main import AuthBaseHandler
# from models.account import User class LoginHandler(AuthBaseHandler):
"""登录"""
def get(self, *args, **kwargs):
self.render('login.html') def post(self, *args, **kwargs):
# 从 login.html 的 form 表单中拿到用户名,密码, None 为异常处理,(如果拿不到,传蛇夫座值)
name = self.get_argument('username', None)
password = self.get_argument('password', None)
next = self.get_argument('next', '/') # 返回原始页面
if auth.authenticate(name, password):
self.session.set('login_user', name)
# 重定向到首页
self.redirect(next)
else: self.write('用户名或密码不正确') class LogoutHandler(AuthBaseHandler):
"""用户退出登录"""
def get(self, *args, **kwargs):
self.session.set('login_user','')
self.write('您已成功退出登录') class RegisterHandler(AuthBaseHandler):
"""用户注册,信息写入数据库"""
def get(self, *args, **kwargs):
self.render('register.html') def post(self, *args, **kwargs):
name = self.get_argument('name', '')
password_1 = self.get_argument('password1', '')
password_2 = self.get_argument('password2', '') if password_1 == password_2:
# 所信息添加到数据库中
auth.register(name,password_1)
# 注册成功后跳转到首页面
self.redirect('/')
else:
self.write('两次输入的密码不一致')

  

如果这些可以跑通,就可以把 utlis 下 auth.py 中的USER_DATA删除,调用数据库的信息,

因为数据库中的 name 是唯一的,如果有同名的用户名进行注册,传到数据库中,就会报错,

所以,在注册是,把 name 值先在数据库中查询,看看是否存在,

创建图片信息数据库的表,

在 models 的 account.py 中写个创建图片信息存放的表

执行更新数据库的操作

alembic revision --autogenerate -m "create img_post table"

alembic upgrade head

在 utlis 中的 photo.py 中写个保存用户上传图片的信息,

在 main.py 处理图片上传中将图片信息存到数据库

把三个基本页面改成从数据库中获取数据,之后渲染

查询图片信息

把这个方法引入到 man.py 在  PostHandler 中调用

在 html 文件中渲染

index页面

潭州课堂25班:Ph201805201 tornado 项目 第五课 增加用户系统-用户中心(课堂笔记)的更多相关文章

  1. 潭州课堂25班:Ph201805201 tornado 项目 第八课 增加喜欢功能(课堂笔记)

    tornado 相关说明 新增一个页面,用来做图片收藏, 还要在 account.py 创建一个数据库表,记录用户喜欢的图片,哪些图片用户疯狂传奇 cd 到 项目目录下,执行数据库更新 alembic ...

  2. 潭州课堂25班:Ph201805201 tornado 项目 第四课 增加用户注册登录(课堂笔记)

    tornado 相关说明 在 handlers 中创建个 auth.py 用来做用户登录,在这文件中创建个类,并逐步完善 在 tornado 中创建 login.html 文件,是个登录页面 {% e ...

  3. 潭州课堂25班:Ph201805201 tornado 项目 第十课 深入应用异步和协程(课堂笔记)

    tornado 相关说明 需求: 增加 /save 的 handler,实现异步保存指定 URL 图片的功能 从网页上得到一张图片地址,由这个地址将图片保存到服务器,并将相关数据保存到数据库 impo ...

  4. 潭州课堂25班:Ph201805201 tornado 项目 第七课 界面美化和静态文件处理(课堂笔记)

    tornado 相关说明 使用  Bootstrap 前端框架 可以在 bootCDN 这里找 jquery ,poppe.js 文件 美化项目 twittel 的开源项目, 在 static 目录下 ...

  5. 潭州课堂25班:Ph201805201 tornado 项目 第十一课 项目改进和优化(课堂笔记)

    使用  Bootstrap 前端框架 可以在 bootCDN 这里找 jquery ,poppe.js 文件 当聊天室发来一第图片链接时,自动保存图片到服务器,并保存相关信息到数据库,系统向该用户发出 ...

  6. 潭州课堂25班:Ph201805201 tornado 项目 第六课 用户和图片分享的集成(课堂笔记)

    tornado 相关说明 改善图片上传功能 ,生成唯一的 ID ,与路径拼接,生成 URL, 这里引用 uuid 的 python 库 在 photo.py 中创建个类,用来  辅助用户上传的图片,生 ...

  7. 潭州课堂25班:Ph201805201 tornado 项目 第三课 项目 图片上传,展示 (课堂笔记)

    tornado 相关说明 f增加图片上传功能, 在 main.py ,文件中创建个  UploadHandler 类,用来处理图片上传 上传图片之前,要先渲染这个页面,所以定个 get 方法,把这个页 ...

  8. 潭州课堂25班:Ph201805201 django 项目 第五课 静态页面转为模板 (课堂笔记)

    一.分析静态页面   1.静态vs动态 条目 静态页面 动态页面 网站内容 固定不变 经常变动 浏览器加载速度 更快(无需向服务器发起请求) 更慢 改变网站内容 很难(修改或者创建新的html页面) ...

  9. 潭州课堂25班:Ph201805201 爬虫基础 第五课 (案例) 豆瓣分析 (课堂笔记)

    动态讲求 , 翻页参数: # -*- coding: utf-8 -*- # 斌彬电脑 # @Time : 2018/9/1 0001 3:44 import requests,json class ...

随机推荐

  1. 题解-洛谷P1981 表达式求值(模拟+处理优先级的递归)

    https://www.luogu.org/problemnew/show/P1981 (原题链接) 显然乘法的优先级高与加法,因此碰到乘号就要优先把一连串与乘号相连的数算出,很容易想到递归.可用普通 ...

  2. 洛谷P1233 木棍加工题解 LIS

    突然发现自己把原来学的LIS都忘完了,正好碰见这一道题.|-_-| \(LIS\),也就是最长上升子序列,也就是序列中元素严格单调递增,这个东西有\(n^{2}\)和\(nlog_{2}n\)两种算法 ...

  3. 彻底理解cookie,session,token

    发展史 1.很久很久以前,Web 基本上就是文档的浏览而已, 既然是浏览,作为服务器, 不需要记录谁在某一段时间里都浏览了什么文档,每次请求都是一个新的HTTP协议, 就是请求加响应,  尤其是我不用 ...

  4. JS学习笔记Day9

    一.BOM (一)概念:是 Browser object model 的缩写,简称浏览器对象模型. BOM 提供了独立于内容而与浏览器窗口进行交互的对象 由于 BOM 主要用于管理窗口与窗口之间的通讯 ...

  5. Pandas系列(十)-转换连接详解

    目录 1. 拼接 1.1 append 1.2 concat 2. 关联 2.1 merge 2.2 join 数据准备 # 导入相关库 import numpy as np import panda ...

  6. OpenStack虚拟机冷迁移与热迁移

    一.虚拟机迁移分析 openstacvk虚拟机迁移分为冷迁移和热迁移两种方式. 1.1冷迁移: 冷迁移(cold migration),也叫静态迁移.关闭电源的虚拟机进行迁移.通过冷迁移,可以选择将关 ...

  7. [物理学与PDEs]第2章习题11 Lagrange 形式的一维理想流体力学方程组在强间断线上的间断连接条件

    对由第 10 题给出的 Lagrange 形式的一维理想流体力学方程组, 给出解在强间断线上应满足的间断连接条件 (假设体积力 $F\equiv 0$). 解答: $$\beex \bea \sez{ ...

  8. Chrome 禁止从页面打开 Data URI 网址了

    现如今,网民的网络账户被盗,很有可能是被“钓鱼”了.去年的一份安全报告中指出:“近85%的资金损失是通过钓鱼网址泄露支付信息造成的”. 传统的钓鱼网站通常是申请一个和被冒充网站相似的域名,比如 tao ...

  9. C++自定义String字符串类,支持子串搜索

    C++自定义String字符串类 实现了各种基本操作,包括重载+号实现String的拼接 findSubStr函数,也就是寻找目标串在String中的位置,用到了KMP字符串搜索算法. #includ ...

  10. Mysql的跨服务器 关联查询--Federated引擎

    1.确认开启Federated引擎     查询FEDERATED功能是否开启: show ENGINES;       2.如果状态为NO则需修改my.ini文件,增加一行federated配置: ...