【Tornado】使用tornado写API的增删改查(一)

Novia ·
更新时间:2024-11-14
· 960 次阅读

安装 pip3 install tornado 项目结构

主函数

我这边是把接口都放在主函数了,大家可以自行拆开,数据库连接用的是pymysql

为了方便处理,这里从mysql中取值采用字典格式,游标需要这么写

cursor = db.cursor(pymysql.cursors.DictCursor)

默认的情况是元组格式,不会携带字段名

cursor = db.cursor()

main.py

# -*- coding:utf-8 -*- import tornado.web import tornado.ioloop from tornado.options import options, define import os import pymysql import json mysqldb = pymysql.Connection(host='127.0.0.1', database='MyBlog', user='root', password='xxxxx', charset='utf8') import datetime class DateEncoder(json.JSONEncoder): def default(self, obj): if isinstance(obj, datetime.datetime): return obj.strftime('%Y-%m-%d %H:%M:%S') elif isinstance(obj, datetime.date): return obj.strftime("%Y-%m-%d") else: return json.JSONEncoder.default(self, obj) # 定义处理类型 class IndexHandler(tornado.web.RequestHandler): # 添加一个处理get请求方式的方法 def get(self): # 向响应中,添加数据 self.write('你都如何回忆我,带着笑或是很沉默') class HelloTornado(tornado.web.RequestHandler): def get(self): self.render("HelloTornado.html") class GetALlBlog(tornado.web.RequestHandler): def initialize(self, db): self.db = db print("db is ok") def get(self): db = self.db cursor = db.cursor(pymysql.cursors.DictCursor) try: cursor.execute( "SELECT A.id, A.title, A.`timestamp`, A.views, A.greats, A.comments,U.name as 'authorname' FROM blog_articles A, blog_bloguser U WHERE A.authorname_id = U.id AND A.STATUS = '有效'LIMIT 10" ) # [{},{},...,{}]字典形式 result = cursor.fetchall() return_data = {} return_data["code"] = 200 return_data["message"] = "success" return_data["data"] = result self.finish(json.dumps(return_data, cls=DateEncoder)) except Exception as e: return self.write(e) db.commit() print("success") cursor.close() settings = dict( template_path=os.path.join(os.path.dirname(__file__), "templates"), static_path=os.path.join(os.path.dirname(__file__), "statics"), debug=True, ) if __name__ == '__main__': # 创建一个应用对象 define("port", default=8088, type=int, help="run server on the given port.") handlers = [ (r'/', IndexHandler), (r'/index', HelloTornado), (r'/api/getallblog', GetALlBlog, dict(db=mysqldb)), ] app = tornado.web.Application( handlers, **settings ) # 绑定一个监听端口 app.listen(8088) # 启动web程序,开始监听端口的连接 tornado.ioloop.IOLoop.current().start() SQL外键查询

如果A表外键关联了B

SELECT A.id, A.title, A.timestamp, A.views, A.greats, A.comments, B.name as "authorname" FROM blog_articles A, blog_bloguser B WHERE A.authorname_id = B.id AND A.STATUS = "有效" LIMIT 10

这里B.name as "authorname"是对字段重命名,字段在B中原来是name

请叫我算术嘉 原创文章 307获赞 115访问量 196万+ 关注 他的留言板 展开阅读全文
作者:请叫我算术嘉



tornado api

需要 登录 后方可回复, 如果你还没有账号请 注册新账号