Tornado project generator. Start a project with tornado, mako/jinjia2 and sqlalchemy/peewee in a minute.
FPage 是一个传统的(即前后端分离之前)tornado项目生成器(CLI)。
能够自动创建基于 tornado + mako/jinja2 + peewee/sqlalchemy 的项目。
实例可参考 StoryNote MyCTF 等项目。
English
使用
通过 pip:pip install fpage
fpage new [项目名]
clone后直接使用:
python fpage.py new [项目名]
然后选择一个模板引擎(Mako/Jinja2/Tornado)
其次是ORM选择(Peewee/SQLChemy)
最后输入 y 确认
生成的目录就是你需要的,你可以试一下 python app.py 来运行他,然后访问 http://127.0.0.1:9000 来查看效果
实例:
# fpage new test_project
Project Name (test_project):
Template Engine [M/J/T]:
Database ORM [P/S]:
Project Name: test_project
Template Engine: mako
Database ORM: peewee
Sure (Y/n)?
Complete.
To get started:
cd test_project
python app.py
Served at http://localhost:9000
特性
-
基于 tornado
-
MVT 架构(Model, View, Template)
-
兼容 python 3 & python 2
-
合理的安全性支持 (secure cookie, xsrf)
-
支持 flask 风格的 url 路由装饰器 @route
-
简单 session 支持(基于 secure cookie)
-
可选择模板引擎 mako 或 jinjia2 或 tornado 默认,已做好配置
-
模板预定义模板变量:req static url_for csrf_token/xsrf_token config
-
集成 sqlalchemy/peewee 支持(二选一)
-
集成消息闪现功能(类似 django 中 messages 或 flask 中 flash)
-
集成简单的用户系统
-
自动生成页面标题
-
可选的 Peewee 序列化扩展组件
-
内置分页工具
目录结构
-
model 数据库交互
-
view 逻辑
-
templates 模板目录
-
lib 存放一些全局使用的工具类
特性说明
-
支持 flask 风格的 url 装饰器 @route
from view import route, url_for, View @route('/') class Index(View): def get(self): self.render() def post(self): pass @route('/about', name='about') class About(View): def get(self): self.render()
-
简单 session 支持(基于 secure cookie)
@route('/') class Index(View): def get(self): self.session['test'] = 'session test 1' del self.session['test'] self.session['test'] = 'session test 2' self.render(s=self.session['test'])
-
可选择模板引擎 mako 或 jinjia2 或 tornado 默认,已做好配置
<body> ${self.body()} <%block name="script"/> </body>
<body> {% block body %}{% endblock %} {% block script %}{% endblock %} </body>
-
模板预定义模板变量:req static url_for csrf_token/xsrf_token
req -> request object
${ req.current_user }
<script src="${ static('js/main.js') }"></script> <link rel="stylesheet" href="${ static('css/style.css') }">
<p><a href="${ url_for('jump') }">Jump Page</a></p> <p><a href="${ url_for('about') }">About Page</a></p>
<form method="post" class="am-form"> ${csrf_token} </form>
-
集成 sqlalchemy/peewee 支持(二选一)
config
DATABASE_URI = "sqlite:///database.db"
from model import BaseModel from sqlalchemy import Column, Integer, String, Float, ForeignKey, Boolean class Test(BaseModel): __tablename__ = 'test' id = Column(Integer, primary_key=True, autoincrement=True) test = Column(String)
from peewee import * from model import BaseModel class Test(BaseModel): test = TextField()
-
集成消息闪现功能(类似 django 中 messages 或 flask 中 flash)
view
@route('/jump_test', name='jump') class Jump(View): def get(self): self.messages.error('Message Test: Error!!') self.redirect(url_for('about'))
% for msg in get_messages(): % if msg.tag == 'success': <div class="ui-green"> ${msg.txt} </div> % elif msg.tag == 'error': <div class="ui-red"> ${msg.txt} </div> % endif % endfor
-
自动生成页面标题
例如:config.TITLE = 'FPage'
渲染模板时写入参数 page_title
self.render(page_title=page_title('测试板块', '社区')
-
内置分页工具
model.pagination_peewee / model.pagination_sqlalchemy
参数大致如此:
def pagination(count_all, query, page_size, cur_page=1, nearby=2): pass
{ 'cur_page': cur_page, 'prev_page': prev_page, 'next_page': next_page, 'first_page': first_page, 'last_page': last_page, 'page_numbers': list(items), 'page_count': page_count, 'items': [...], 'info': { 'page_size': page_size, 'count_all': count_all, } }
FROM https://github.com/fy0/fpage
No comments:
Post a Comment