一个tornado项目的大体结构

142 篇文章 0 订阅
40 篇文章 0 订阅

主要结构

这里写图片描述

下面进行解释。

App目录职责

app用于存放程序需要运行的逻辑。
如下:
这里写图片描述
common里面是通用的函数及方法。
business用于存放业务逻辑
dal专门用于数据库读写
db是数据库操作辅助类
modules用于存放tornado的handler,即页面控制器。
viewhelper是用于页面的一些辅助方法,譬如,页面上面需要裁剪字符串,需要获取通用页脚的文章数据,需要获取页头的通用分类数据等等。
值得注意的是BaseHandler这个类,这个类可以自定义404错误,也可以自定义采用的模板,所有handler都继承这个BaseHandler。
代码如下:

#coding:utf-8
#这是一份默认的handler,用于替换掉默认的模板引擎为mako。
import tornado.web
import os.path
import tornado.ioloop
import mako.lookup
import tornado.httpserver
import mako.template

import app.common.commons

class BaseHandler(tornado.web.RequestHandler):
    def initialize(self):
        template_path = self.get_template_path()
        self.lookup = mako.lookup.TemplateLookup(directories=[template_path], input_encoding='utf-8', output_encoding='utf-8')
        #self._config = Config()
        #self.lookup = mako.lookup.TemplateLookup(directories=[template_path])

    #def get_conf(self,field,key):
    #    return self._config.get(field,key)
    def render_string(self, template_path, **kwargs):

        try:
            _debug=self.get_argument("debug","false")
            template = self.lookup.get_template(template_path)
            namespace = self.get_template_namespace()
            namespace.update(kwargs)

            #siteConfig=WebConfig()
            env_kwargs = dict(
                    handler = self,
                    request = self.request,
                    locale = self.locale,
                    _ = self.locale.translate,#国际化i18n的支持
                    static_url = self.static_url,
                    xsrf_form_html = self.xsrf_form_html,
                    reverse_url = self.application.reverse_url,
                    jsDebug=_debug,
                    #get_conf = self.get_conf,
                    #加一个我们的相关设定下去。
                    #conf=siteConfig

            )
            env_kwargs.update(kwargs)
            return template.render(**env_kwargs)
        except Exception as e:
            print("服务端错误")
            print(e)
            pass

Conf目录职责

conf目录用于存放程序的相关配置文件及信息,例如:
这里写图片描述

其中一份配置如下:

# -*- coding: utf-8 -*-
#开发环境
#--总体设置
[global]
db_prefix=ecs_
[web]
template_path=views
static_path=static

#--数据库设置
[db]
#mysql ip
host = localhost
#mysql port
port = 3306
#db name
db = ectouch
user = root
password = root
#--mongo数据库配置
[mongo]
#host
host=127.0.0.1
#port
port=27017
#db
db=base_db



都差不多的。

views职责

views是存放控制器需要渲染的模板的目录,例如:
这里写图片描述

static职责

static是静态文件目录,包含了样式,脚本,页面的前端逻辑等东西,同时也有一些第三方插件在。例如:
这里写图片描述

upload职责

你还看到了upload这个文件夹,请注意,tornado除了static目录是默认可以在外面直接访问到以外,其余文件夹下面的文件都没办法直接通过http访问的,假如要添加这种http直接访问,那么需要进行设置,这里先说明一下。upload的职责是小型网站上传图片时候的存放。

application、server及url路径设置

这里写图片描述

这几个文件都是启动tornado服务,设定访问地址的核心文件。

url和url_admin分别是设定前台访问路径和后台访问路径的文件,分开两个是因为便于管理。
内容分别是:

#coding:utf-8
import sys
import tornado.web
import os
from app.web.modules.testModule import index as TestIndex
from app.web.modules.PC import *
url=[
    #(r"/data/(.*)", tornado.web.StaticFileHandler,{"path":"data"})#这是data静态文件,用自定义静态文件的路由。
    (r"/test",TestIndex)
    #pc版页面,
    ,(r"/index\.html",pc_index)

    ]
#coding:utf-8
import sys
import tornado.web
import os

##这是后台相关页面。
from app.web.modules.admin.index import *

url_admin=[

    (r"/admin/login\.html",admin_login)
    ,(r"/admin/index\.html",admin_index)
    ,(r"/admin/center\.html",admin_center)

    ]

application是设定tornado程序的核心文件,如下:

from url import *
import tornado.web
import os
from app.conf.config import *
from url_admin import *
setting = dict(
  template_path=os.path.join(os.path.dirname(__file__), "views"),
  static_path=os.path.join(os.path.dirname(__file__), "static"),
  )
handlers=[]
##根据web.ini设定相关参数
def application_setting_handle():
    _config=WebConfig()
    setting["template_path"]=_config.cf.get("web","template_path")
    setting["static_path"]=_config.cf.get("web","static_path")
    #--这里要加入静态文件的直接访问。
    handlers.append((r"/data/(.*)", tornado.web.StaticFileHandler,{"path":"data"}))#这是data静态文件,用自定义静态文件的路由。
    handlers.append((r"/images/(.*)", tornado.web.StaticFileHandler,{"path":"images"}))#这是images静态文件,用自定义静态文件的路由。
    handlers.append((r"/upload/(.*)", tornado.web.StaticFileHandler,{"path":"upload"}))#这是上传的静态文件,用自定义静态文件的路由。
    handlers.extend(url)#pc端页面。
    handlers.extend(url_admin)#后台相关页面,




application_setting_handle()
application = tornado.web.Application(
  handlers=handlers,
  **setting
  )

server.py是启动服务器的入口,内容如下:

import os
import tornado.ioloop
import tornado.options
import tornado.httpserver
import sys
from app.conf.config import *
from application import application

from tornado.options import define,options
define("port",default=8123,help="run on th given port",type=int)

def main():
    #读取server的配置文件。
    conf_server=ServerConfig()
    options.port=int(conf_server.getPort())

    tornado.options.parse_command_line()
    http_server = tornado.httpserver.HTTPServer(application)
    http_server.listen(options.port)
    print('Development server is running at http://127.0.0.1:%s/' % options.port)
    print('Quit the server with Control-C')
    tornado.ioloop.IOLoop.instance().start()

if __name__=="__main__" or 1==1:
    main()

总结

一个项目的组织方式是多种多样的,这里只是说一说我自己的组织方式,请指正。

  • 7
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
标准的Tornado项目结构一般包括以下几个主要部分: 1. 主程序文件:通常命名为main.py或app.py,是项目的入口文件,其中包含Tornado应用的创建和配置过程,以及启动服务器的代码。 2. 路由模块:一般以urls.py或routes.py命名,用于定义URL路径和对应的处理函数之间的映射关系。在该模块中,可以使用正则表达式或通配符来匹配URL路径,并将请求转发给相应的处理函数进行处理。 3. 处理函数模块:一般以handlers.py或views.py命名,用于定义处理请求的函数。这些函数可以接收请求参数、访问数据库、调用第三方接口等,并根据业务逻辑进行相应的处理,并返回响应数据。 4. 静态文件目录:一般命名为static,用于存放静态文件,如CSS、JavaScript、图片等。Tornado框架自带了一个静态文件处理器,可以直接通过URL路径访问这些文件。 5. 模板文件目录:一般命名为templates,用于存放HTML模板文件。Tornado支持使用模板引擎来动态生成HTML页面,通过在处理函数中调用模板引擎,将数据传递给模板文件进行渲染。 6. 配置文件:一般命名为config.py或settings.py,用于存放项目的配置信息,如数据库连接信息、Redis配置、日志配置等。可以通过导入该文件,来获取项目的配置信息。 7. 数据库模型模块:如果项目需要使用数据库,通常会创建一个模型模块,用于定义数据库表结构和数据操作方法。一般使用ORM框架来简化数据库操作,如SQLAlchemy。 8. 日志模块:一般以logger.py命名,用于配置和管理日志的输出。可以定义不同的日志级别,并将日志输出到控制台、文件或其他目标。 以上是标准的Tornado项目结构,根据具体项目的需求,可能会有一些变化。同时,在实际开发中,也可以根据团队的需求和习惯进行适当的调整和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值