一、项目架构:

研习了多天flask,今天终于按照标准流程写了一个实验demo,并实现了ORM调用,一起喜欢自己写原生SQL。废话不多说,来看项目文件结构

 mysite/
./config/
default.py#默认上线的配置文件
development.py#开放过程的配置文件
debug.py#调试过程的配置文件
./instance/
config.py#特殊的复写的配置文件
./utils/#自定义的lib库
tools1.py
tools2.py
./main/#app所在库
__init__.py#app定义
modles.py#ORM数据库代码文件
./views/#视图(路由)代码文件
user.py#模块一的蓝图文件,定义视图路由函数
./static/#静态文件所在文件夹
./templates/#模板文件所在文件夹
./docs/#文档文件文件夹
./libs/#css/js/ca等类型文件文件夹
requestment.py#以来库要求文件夹
manage.py#启动脚本

二、多层文件架构需要注意的坑

1、引入本文件夹下的__init__.py下的对象from . import xxx

2、引入文件寻址路径添加方式:

 import sys
sys.path.append(filepath)

3、注意互相引用时候的定义以来,比如A引用B的m,B引用的A的n,m需要n去定义,那么A中引入m一定要在n定义之后。

三、default.py的内容:

 DEBUG = True
SECRET_KEY = 'xxxx'
SQLALCHEMY_DATABASE_URI ="mysql://root:root@127.0.0.1:3306/webuser"#mysql连接的定义mysql://user:pass@host:port/databasename
SQLALCHEMY_TRACK_MODIFICATIONS = True

四、__init__.py app定义、数据库对象创建、蓝图函数注册:

 # -*- encoding:utf-8 -*-
import sys
sys.path.append("./")
from flask import Flask
from flask_sqlalchemy import SQLAlchemy myapp = Flask(__name__)
myapp.config.from_pyfile("../config/default.py")#读取配置文件
userdb = SQLAlchemy(myapp)#创建数据库连接对象
from views.user import User#引入模块User
myapp.register_blueprint(User)#蓝图注册函数

五、ORM定义数据库的方式modles.py

 # -*- encoding:utf-8 -*-

 #import lib files
from . import userdb#从__init__.py引入userdb对象 class UserTable(userdb.Model):
id = userdb.Column(userdb.Integer,primary_key=True,autoincrement=True)
name = userdb.Column(userdb.String(20))
def __init__(self,name):
self.name = name
def __repr__(self):
return '<UserTable %r>'%self.name
def show(self):
return self.name #创建表(一个类一个表):
"""
#类的属性就是表的列字段 创建函数就是数据库连接对象.Column(约束)
id = userdb.Column(userdb.Integer,primary_key=True,autoincrement=True)
name = userdb.Column(userdb.String(20))
"""

六、user.py模块 定义视图路由函数的文件

 # -*- encoding:utf-8 -*-
import sys
sys.path.append("../")
sys.path.append("../../")
from . import userdb#引入数据库连接对象
from models import UserTable#引入数据表对象
from flask import Blueprint,request,jsonify User = Blueprint("user",__name__)#创建蓝图 @User.route("/register",methods=["GET","POST"])#蓝图路由
def register():
if request.method == "GET":
user = request.args.get("username")
else:
user = request.forms.get("username")
try:
userdb.create_all()
except Exception,ex:
pass
retlist = UserTable.query.filter_by(name=user).all()
if len(retlist) > 0:
return jsonify({"message":"failed","reason":"username repeat!"})
else:
userobj = UserTable(user)
userdb.session.add(userobj)
userdb.session.commit()
return jsonify({"message":"success","reason":"Hello %s"%user})

七、启动脚本manage.py

 from mainapp.app import myapp

 if __name__ == "__main__":
myapp.run("127.0.0.1",port=5443)
#另外一种方式:
"""
from flask_script import Manager
manager = Manager(app)
#...
if __name__ == '__main__':
manager.run()"
(venv) $ python hello.py runserver --host 0.0.0.0 -p 5443
* Running on http://0.0.0.0:5000/ (Press CTRL+C to quit)
"""

八、requestments.txt

 pip freeze > requestments.txt

flask框架实战项目架构的更多相关文章

  1. WinForm企业级框架实战项目演练

    一.课程介绍 我们都知道在软件架构方式分为:C/S和B/S两类.这里阿笨不谈论两种软件架构的优劣之分,因为它们各有千秋,用于不同场合.一位伟大的讲师曾经说过一句话:事物存在即合理!录制这堂课程的目的就 ...

  2. flask框架搭建项目的具体步骤

    flask是一个使用python编写的轻量级Web应用框架.与django不同,Django创建工程时,会直接构架好工程目录.而flask工程几乎是自己创建结构. 1.导入相关模块以及需要使用的模块: ...

  3. Flask框架的学习与实战(二):实战小项目

    昨天写了一篇flask开发环境搭建,今天继续,进行一个实战小项目-blog系统. blog系统很简单,只有一个页面,然而麻雀虽小五脏俱全.这里目的不是为了做项目而做项目,这篇文章本意是通过这次练习传达 ...

  4. .NET开源作业调度框架(Quartz.NET和FluentScheduler)实战项目演练

    一.课程介绍 明人不说暗话,跟着阿笨一起玩NET .本次分享课程属于<C#高级编程实战技能开发宝典课程系列>中的一部分,阿笨后续会计划将实际项目中的一些比较实用的关于C#高级编程的技巧分享 ...

  5. Flask框架2

    Flask框架的学习与实战(二):实战小项目   昨天写了一篇flask开发环境搭建,今天继续,进行一个实战小项目-blog系统. blog系统很简单,只有一个页面,然后麻雀虽小五脏俱全.这里目的不是 ...

  6. 应用程序框架实战二十二 : DDD分层架构之仓储(层超类型基础篇)

    前一篇介绍了仓储的基本概念,并谈了我对仓储的一些认识,本文将实现仓储的基本功能. 仓储代表聚合在内存中的集合,所以仓储的接口需要模拟得像一个集合.仓储中有很多操作都是可以通用的,可以把这部分操作抽取到 ...

  7. 应用程序框架实战十五:DDD分层架构之领域实体(验证篇)

    在应用程序框架实战十四:DDD分层架构之领域实体(基础篇)一文中,我介绍了领域实体的基础,包括标识.相等性比较.输出实体状态等.本文将介绍领域实体的一个核心内容——验证,它是应用程序健壮性的基石.为了 ...

  8. .NET Core实战项目之CMS 第九章 设计篇-白话架构设计

    前面两篇文章给大家介绍了我们实战的CMS系统的数据库设计,源码也已经上传到服务器上了.今天我们就好聊聊架构设计,在开始之前先给大家分享一下这几天我一直在听的<从零开始学架构>里面关于架构设 ...

  9. Flask框架从入门到实战

    Flask简介: Flask是一个使用 Python 编写的轻量级 Web 应用框架,基于 WerkzeugWSGI工具箱和 Jinja2模板引擎.使用 BSD 授权. Flask也被称为 " ...

随机推荐

  1. mysql慢查询日志开启和存储格式

    mysql版本号是mysql5.6.22.安装环境windows7. 1.使用该查询日志能够找到有效率问题的sql语句.并记录下来,进行监控. 能够使用例如以下语句查询和设置慢查询日志 (1) 查看慢 ...

  2. Zookeeper 工作流

    一旦ZooKeeper集合启动,它将等待客户端连接.客户端将连接到ZooKeeper集合中的一个节点.它可以是leader或follower节点.一旦客户端被连接,节点将向特定客户端分配会话ID并向该 ...

  3. 解决ubuntu下mysql不能远程连接数据库的问题【转】

    Ubuntu10.04上自带的MySQL,执行了root@ubuntu:~#sudo apt-get install mysql安装完mysql-server 启动mysqlroot@ubuntu:~ ...

  4. linux -- ubuntu桌面版安装xampp

    首先,请从www.xampp.org下载最新版XAMPP. 安装 如果是xampp压缩文件 将xampp压缩文件复制到/opt下并解压.如果你计算机没有/opt目录,用 “sudo mkdir/opt ...

  5. 教你如何架设linux邮件服务器postfix

    检查linux是否有安装postfix和dovecot 检查命令如下: Rpm  -qa |grep  postfix; Rpm –qa |grep dovecot; 如果没有显示任何数据,表明没有安 ...

  6. oracle用sql 语句如何向表中插入时间?

    有关日期的操作中,更多的是涉及系统当前时间,用sysdate表示即可,如果是插入其他非系统时间的日期类型数据的话,用to_date转换再插入就可以了.例: insert into 表(c_date) ...

  7. 在MathType如何让括号随内容自动调整大小的技巧

    MathType软件是一款数学公式编辑器工具可以轻松输入各种复杂的公式和符号,与Office文档完美结合,显示效果超好,比Office自带的公式编辑器要强大很多.但是很多的新手朋友不知道在MathTy ...

  8. mysql中/*!40000 DROP DATABASE IF EXISTS `top_server`*/;这中注释有什么作用?

    需求描述: 今天在进行mysqldump实验,使用--add-drop-databases参数,于是在生成的SQL文件中,就出现了. /*!40000 DROP DATABASE IF EXISTS ...

  9. List<T>与ObservableCollectio<T> 的区别

    在WPF中绑定通常会使用ObservableCollection,为什么不使用List呢? 简单是解释:List不包含值变通知功能,所以绑定了也许会出现绑定的数据与呈现数据不一致的问题. 通常绑定会使 ...

  10. js timestamp与datetime之间的相互转换

    1.  datetime转换成timestamp strdate = "2015-08-09 08:01:36:"; var d = new Date(strdate); var ...