tornado之日记本——
 
1、diary.py:
 
import time
from model.database import DataBase
from tornado import web, httpserver, ioloop
 
def getDiaryInfo(self):
    t = self.get_argument('time',time.strftime('%Y-%m-%d %X', time.localtime()))
    weather = self.get_argument('weather')
    mood = self.get_argument('mood')
    content = self.get_argument('content')
    return dict(time=t, weather=weather, mood=mood, content=content)
 
class IndexHandler(web.RequestHandler):
    def get(self, *args, **kwargs):
        search=self.get_argument('search','')   #初始搜索词为空,列出所有日记
        diaries=DataBase().getDiaries(search)
        self.render('index之日记本.html',diaries=diaries)
 
class CreateDiaryHandler(web.RequestHandler):
    def get(self, *args, **kwargs):
        self.render('createDiary.html')
    def post(self, *args, **kwargs):
        item=getDiaryInfo(self)
        DataBase().createDiary(item)
        self.redirect('/')
 
class UpdateDiaryHandler(web.RequestHandler):
    def get(self, *args, **kwargs):
        diary=DataBase().getDiaryByID(self.get_argument('id'))
        self.render('updateDiary.html',diary=diary)
    def post(self, *args, **kwargs):
        item=getDiaryInfo(self) #id是get的参数,其他来自post请求
        item.update({'id':self.get_argument('id')})
        DataBase().updateDiary(item)
        self.redirect('/')
 
class DeleteDiaryHandler(web.RequestHandler):
    def get(self, *args, **kwargs):
        id=self.get_argument('id')
        self.write(f'''<form method="post">
        <input type="submit" value="确认删除日记{id}" name="deleteDiary">
        <input type="submit" value="取消删除{id}" name="deleteDiary"></form>''')
    def post(self, *args, **kwargs):
        if '确认' in self.get_argument('deleteDiary'):
            DataBase().deleteDiary(self.get_argument('id'))
        self.redirect('/')
 
class InfoDiaryHandler(web.RequestHandler):
    def get(self, *args, **kwargs):
        diary=DataBase().getDiaryByID(self.get_argument('id'))
        self.render('infoDiary.html',diary=diary)
 
app = web.Application([
    (r'/', IndexHandler),
    (r'/createDiary', CreateDiaryHandler),
    (r'/updateDiary', UpdateDiaryHandler),
    (r'/deleteDiary', DeleteDiaryHandler),
    (r'/infoDiary', InfoDiaryHandler),
],**{'template_path':'templates','static_path':'static'})
 
if __name__ == '__main__':
    httpServer = httpserver.HTTPServer(app)
    httpServer.listen(8080)
    print('http://127.0.0.1:8080')
    ioloop.IOLoop.current().start()
***************分割线***************
2、model文件夹中的database.py:
 
import pymysql
 
class DataBase:
    def __init__(self):
        self.conn=pymysql.connect(host='localhost',port=3306,user='chengy',password='',
            db='tornado之日记本',charset='utf8mb4')
        self.cur=self.conn.cursor(pymysql.cursors.DictCursor)
 
    def operateDatabase(self,sql,insertValues=None):
        self.cur.execute(sql,insertValues)
        self.conn.commit()
        self.cur.close()
        self.conn.close()
 
    def createDiary(self,item):
        sql='insert into diaries(time,weather,mood,content) values(%s,%s,%s,%s)'
        insertValues=(item['time'],item['weather'],item['mood'],item['content'])
        self.operateDatabase(sql,insertValues)
 
    def updateDiary(self,item):
        sql=f'''update diaries set time="{item['time']}",weather="{item['weather']}",
          mood="{item['mood']}",content="{item['content']}" where id={item['id']}'''
        self.operateDatabase(sql)
 
    def deleteDiary(self,id=''):
        sql=f'delete from diaries where id={id}'
        self.operateDatabase(sql)
 
    def getDiaries(self,search=''):
        sql=f'select * from diaries where content like "%{search}%" \
        or weather like "%{search}%" or mood like "%{search}%" limit 25'
        self.operateDatabase(sql)
        return self.cur.fetchall()
 
    def getDiaryByID(self,id=''):
        sql=f'select * from diaries where id={id}'
        self.operateDatabase(sql)
        return self.cur.fetchone()
***************分割线***************
3、templates文件夹
 
index之日记本.html:
 
<h2>日行一事</h2>
<div><a href="/createDiary">新建日记</a><br></div>
<form action="" method="get">
    搜索日记:<input type="text" name="search">
    <input type="submit" value="搜索">
</form>
<br><br>
{% if diaries %}
    <table cellspacing="0" cellpadding="0" border="9">
        <tr><th>修改</th><th>删除</th><th>id</th><th>时间</th>
            <th>天气</th><th>心情</th><th>内容</th></tr>
        {% for diary in diaries %}
            <tr><td><a href="/updateDiary?id={{diary['id']}}">修改</a></td>
            <td><a href="/deleteDiary?id={{diary['id']}}">删除</a></td>
            <td>{{diary['id']}}</td><td>{{diary['time']}}</td><td>{{diary['weather']}}</td>
            <td>{{diary['mood']}}</td>
            <td><a href="/infoDiary?id={{diary['id']}}">{{diary['content'][:20]}}</a></td>
            </tr>   <!--显示前9个字符,tornado用[:9],django用|truncatechars:'9'-->
        {% end %}
    </table>
{% end %}
*****分割线*****
createDiary.html:
 
<h2>新建日记</h2>
<form action="" method="post">
    天气:<input type="text" name="weather"><br>
    心情:<input type="text" name="mood"><br>
    内容:<textarea rows="10" cols="30" name="content"></textarea><br>
    <input type="submit" value="保存">
</form>
*****分割线*****
updateDiary.html:
 
<h2>更新日记</h2>
{% if diary %}
<form action="" method="post">
    时间:<input type="text" name="time" value="{{diary['time']}}"><br>
    天气:<input type="text" name="weather" value="{{diary['weather']}}"><br>
    心情:<input type="text" name="mood" value="{{diary['mood']}}"><br>
    内容:<textarea rows="10" cols="30" name="content">{{diary['content']}}</textarea><br>
    <input type="submit" value="更新">    <!--textarea无value属性,直接写在标签之间-->
</form>
{% end %}
*****分割线*****
infoDiary.html:
 
<h2 style="color: red;">日记详情</h2>
<h3><a href="/">返回首页</a><br><br></h3>
{% if diary %}
    标识:{{diary['id']}}<br>
    时间:{{diary['time']}}<br>
    天气:{{diary['weather']}}<br>
    心情:{{diary['mood']}}<br><br>
    <!--把字符当html解析:对它用raw语法,或在head中加句{% autoescape None %}-->
    {%raw diary['content'].replace('\r\n','<br>').replace(' ',' ')%}
{% end %}   <!--使用时,各篇html代码替换回半角的&及左尖角符-->

tornadoの2的更多相关文章

  1. Python(九)Tornado web 框架

    一.简介 Tornado 是 FriendFeed 使用的可扩展的非阻塞式 web 服务器及其相关工具的开源版本.这个 Web 框架看起来有些像web.py 或者 Google 的 webapp,不过 ...

  2. 使用tornado,我们可以做什么?

    以下介绍都是建立在python2.x的基础上面,tornado使用任意版本皆可. 如果我们需要对外提供一个http server(web api)/websocket server时,我们都可以使用t ...

  3. tornado session

    [转]tornado入门 - session cookie 和session 的区别: 1.cookie数据存放在客户的浏览器上,session数据放在服务器上. 2.cookie不是很安全,别人可以 ...

  4. tornado template

    若果使用Tornado进行web开发可能会用到模板功能,页面继承,嵌套... 多页应用模板的处理多半依赖后端(SPA就可以动态加载局部视图),就算是RESTfull的API设计,也不妨碍同时提供部分模 ...

  5. tornado上手

    http://www.tornadoweb.org/en/stable/ http://www.cnblogs.com/fanweibin/p/5418697.html import tornado. ...

  6. tornado+sqlalchemy+celery,数据库连接消耗在哪里

    随着公司业务的发展,网站的日活数也逐渐增多,以前只需要考虑将所需要的功能实现就行了,当日活越来越大的时候,就需要考虑对服务器的资源使用消耗情况有一个清楚的认知.     最近老是发现数据库的连接数如果 ...

  7. centos 6.7 搭建tornado + nginx + supervisor的方法(已经实践)

    首先,本来不想写这篇博客了,但是我测试了很多网上的例子包括简书的,全不行,我总结原因是自己太笨,搞了俩个晚上,后来决定,自己还是写一篇记录下来,保证自己以后使用 环境: centos6.7 64 py ...

  8. tornado中将cookie值设置为json字符串

    不熟悉,找了很久,能FQ的话, https://groups.google.com/forum/#!topic/python-tornado/9Y--NgwjP_w 2楼有解释. tornado.es ...

  9. tornado 异步调用系统命令和非阻塞线程池

    项目中异步调用 ping 和 nmap 实现对目标 ip 和所在网关的探测 Subprocess.STREAM 不用担心进程返回数据过大造成的死锁, Subprocess.PIPE 会有这个问题. i ...

  10. 离线安装 Python 2.7, paramiko 和 tornado

    无非就是离线安装, 步骤比较繁琐, 记录一下. 需求很简单, 一个离线安装的 Python, 能跑 tornado 和 paramiko 1. 离线安装 Python 2.7 .tgz cd Pyth ...

随机推荐

  1. ucos中的中断管理

    一.中断的概念 中断是一种硬件机制,用于处理异步事件.中断的实时性比轮询要好,通过中断,微控制器可以在异常发生的时候立刻进行处理,而不需要不断轮询事件是否发生. CM3支持中断嵌套,使得高优先级异常可 ...

  2. 《Orange‘s》FAT12文件系统

    FAT12 层次 扇区(Sector):磁盘上的最小数据单元 簇(Cluster):一个或多个扇区 分区(Partition):通常指整个文件系统 引导扇区 引导扇区是整块软盘的第0个扇区,在这个扇区 ...

  3. eclipse中的web项目部署路径

    elipse添加了server之后,如果不对tomcat的部署路径做更改,则eclipse默认对工程的部署在 eclipse-workspace\.metadata.plugins\org.eclip ...

  4. 一些用Css实现的效果

    今天写一个笔试题,其中有一个是用css实现直角梯形的效果,我给出的答案是: <style> .wrap{ width: 100px; height: 50px; border-top:90 ...

  5. 记录-eureka

    我的工程目录是这样的: eureka- server:服务端 EurekaServerApplication的内容: 服务端配置文件内容: eureka-server :服务端 pom 文件: < ...

  6. 【Spring学习】Spring的源码解析之路

    缘起:=====>>>> 在项目中实际上是用到了Spring的内容,只是直接用的SpringBoot,不管是Eclipse中还是在Intellig IDEA中,应该都比较容易能 ...

  7. php 积分抽奖活动(大转盘)

    以下是项目代码(公众号,使用积分进行抽奖活动),只可做参考: public function Sncode(){ $tid = I('request.tid', 0, 'intval'); // 大转 ...

  8. Windows单机配置Zookeeper环境

    转自:http://www.jianshu.com/p/f7037105db46 首先要确保机器已经安装好java环境,并且配置好环境变量   http://apache.fayea.com/zook ...

  9. JavaSE基础知识(5)—面向对象(Object类)

    一.包 java.lang包,属于java中的核心包,系统默认导入的,不用手动导入该包中的类:Object.System.String.Integer等 1.包的好处 ①分类管理java文件,查找和管 ...

  10. tiny4412--linux驱动学习(1)

    1,概述 linux设备驱动分为三种:字符驱动设备.块驱动设备.网络设备 架构: 1,字符设备驱动 是指只能一个字节一个字节读写的设备,不能随机读取设备内存中的某一数据,读取数据需要按照先后数据.字符 ...