wx供重浩:创享日记
对话框发送:python社区
获取完整源码源文件+说明文档+配置教程等
授权模块
问题模块
答案模块
标签模块
标签列表(按照问题和用户数量排列)
用户模块
其他功能
在虚拟环境中运行命令“python manage.py run”启动项目。启动成功后,在浏览器中输入网址“127.0.0.1:9000”即可进入BBS问答社区首页。如图1所示。
在首页可以根据状态和标签过滤帖子列表,按状态查看如图2所示,按标签查看如图3所示。
选中一个帖子,单击可以查看帖子详情,如图4所示。
只有在用户登录后,才能发帖和回帖。所以需要用户先来注册,然后再登录。注册和登录在一个页面,单击“注册”按钮实现注册功能,单击“登录”按钮实现登录功能,如图5所示。
用户发帖页面如图6所示,回帖页面如图7所示。
答案采纳页面如图8所示,显示回复数量页面如图9所示。
部分源码如下,其余完整详见下载。
# -*- coding: utf-8 -*-import os
import sys
import socketfrom tornado import web, ioloop, httpserver, process, netutilfrom router import ROUTERS
from conf import SETTINGS, DATABASEfrom utils.logger import loggerlog = logger('admin')class Application(web.Application): # 应用类def __init__(self):super(Application, self).__init__(ROUTERS, **SETTINGS)if __name__ == '__main__':args = sys.argv[1:]if args[0] == 'run': # 运行项目app = Application()print('Starting server on port 9000...')# sockets = netutil.bind_sockets(9000, '127.0.0.1', socket.AF_UNSPEC)# process.fork_processes(5)server = httpserver.HTTPServer(app)server.listen(9000) # 端口# server.start(num_processes=4) # 进程数server.start() # 进程数# server.add_sockets(sockets)ioloop.IOLoop.instance().start() # 启动实例elif args[0] == 'dbshell': # 连接数据库config = DATABASE.get('default', {})os.system('mysql -u{user} -p{password} -D{database} -A'.format(user=config.get('user', 'root'),password=config.get('password', ''),database=config.get('database', 'tequila')))elif args[0] == 'migrate': # 迁移config = DATABASE.get('default', {})init_sql = 'mysql -u{user} -p{password} -D{database} -A < database/migration.sql'.format(user=config.get('user', 'root'),password=config.get('password', ''),database=config.get('database', 'tequila'))print('Initializing tables to database {}...'.format(config.get('database')))data = os.system(init_sql)if data == 256:log.info('Seems like you havent\'t create the database, try:\n \'create database tequila default character set utf8;\'')print('Seems like you havent\'t create the database, try:\n \'create database tequila default character set utf8;\'')print('Completed.')elif args[0] == 'shell': # 打开ipythona = os.system('pip list | grep -w "ipython " 1>/dev/null')if a:print('Installing ipython...')os.system('pip install ipython')os.system('ipython')elif args[0] == 'help': # 帮助print(""" following arguments available: for migrating tables to your database, for using ipython shell, connect current database, run a tornado web server.""")else:print('Arguments Error. using \'help\' get help.')