基于 Flask 框架开发的微信小程序后端项目,用于构建小程序商城后台 (电商相关;附带自动生成Swagger 风格的API 文档;可作「Python 项目毕设」;慕课网系列)---- 相关博客链接:?
Mini Shop Server 是一个基于现代化 Flask 框架构建的微信小程序商城后端系统,专为中小型企业和开发者提供完整、可靠、易扩展的电商后端解决方案。
$ sudo apt-get install mysql-server
安装过程中,会让你输入密码。
请务必记住密码!
务必记住密码!
记住密码!
查看是否安装成功
$ sudo netstat -tap | grep mysql
$ mysql -u root -p # 执行完毕后输入密码
$ mysql -u root -p123456 # 直接输入密码,进入(我的密码是: 123456)
-u
表示选择登陆的用户名, -p
表示登陆的用户密码
上面命令输入之后,会提示输入密码(Enter password)
下载 MySQL数据 SQL文件
mysql的每条执行以「分号」结尾
mysql> create database zerd; # 建立数据库(zerd)
mysql> use zerd; # 进入该数据库
mysql> source /home/ubuntu/mini-shop-server/zerd.sql; # 导入「mini-shop-server」目录下的sql文件
Tips: 其他数据库操作
// 1. 获取存在的所有表
show tables;
// 2. 导入成功,可以直接查询(user表)
mysql> select * from user;
// 3. 删除数据库(zerd库)
mysql> drop database zerd;
// 4. 导出数据库
mysql>
查询本地的python3的版本 $ python3 --version
如果不是python3.8的版本,则如下操作
$ sudo apt-get update
$ sudo apt-get install software-properties-common
$ sudo add-apt-repository ppa:jonathonf/python-3.8
$ sudo apt-get install python3.8
安装 uv 包管理工具 (推荐方式)
$ curl -LsSf https://astral.sh/uv/install.sh | sh
或者使用 pip 安装
$ pip install uv
Tips: uv 常用操作命令
$ uv --version # 查看版本
$ uv sync # 安装依赖
$ uv add flask # 添加依赖
$ uv add flask==2.0.3 # 添加指定版本依赖
$ uv remove flask # 删除依赖
$ uv run python server.py # 在虚拟环境中运行命令
$ source .venv/bin/activate # 激活虚拟环境
$ source .venv/Scripts/activate # windows 上激活虚拟环境
$ uv python list # 查看可用Python版本
$ uv venv --python 3.8 # 创建指定Python版本的虚拟环境
$ git clone https://github.com/Allen7D/mini-shop-server.git
$ git clone --depth=1 -b master --single-branch git@github.com:Allen7D/mini-shop-server.git # 浅克隆(只克隆指定分支,且只下载最近的提交历史)
$ cd mini-shop-server
$ uv sync # 创建虚拟环境并安装所有依赖
$ uv run python server.py run # 启动方式1:默认5000端口
$ uv run python server.py run -p 8080 # 启动方式2:改为8080端口
$ uv run python server.py run -h 0.0.0.0 -p 8080 # 启动方式3:以本地IP地址访问
# 或者激活虚拟环境后运行
$ source .venv/bin/activate # 激活虚拟环境
$ source .venv/Scripts/activate # windows 上激活虚拟环境
$ python server.py run # 在虚拟环境中直接运行
$ uv run python fake.py
获取 uv 虚拟环境的 Python 解释器路径
$ uv run which python
# 或者
$ uv python find
PyCharm 中配置 Python 解释器
File > Settings > Project > Python Interpreter
Add Interpreter > Existing environment
.venv/bin/python
(Linux/Mac)或 .venv/Scripts/python.exe
(Windows)配置运行配置
Run > Edit Configurations
server.py
run -h 0.0.0.0 -p 8080
Ctrl+Shift+P
)Python: Select Interpreter
.venv/bin/python
解释器创建 .vscode/settings.json
配置文件:
{
"python.defaultInterpreterPath": "./.venv/bin/python",
"python.terminal.activateEnvironment": true
}
.
├── app
│ ├── init.py
│ ├── api
│ │ ├── v1 # v1的API接口
│ │ │ ├── init.py
│ │ │ ├── address.py # 用户地址
│ │ │ ├── banner.py # 推广横幅
│ │ │ ├── category.py # 分类
│ │ │ ├── client.py
│ │ │ ├── order.py # 订单
│ │ │ ├── pay.py # 支付
│ │ │ ├── product.py # 产品
│ │ │ ├── theme.py # 主题
│ │ │ ├── token.py # 令牌
│ │ │ └── user.py # 用户
│ │ └── v2 # v2的API接口
│ │ ├── init.py
│ │ └── file.py # 文件上传
│ ├── apidocs # 对应的 API文档
│ ├── config # 配置文件
│ │ ├── secure.py
│ │ ├── setting.py
│ │ └── wx.py
│ ├── libs # 自己的库
│ │ ├── enums.py
│ │ ├── error.py
│ │ ├── errorcode.py
│ │ ├── httper.py
│ │ ├── limiter.py
│ │ ├── redprint.py
│ │ ├── scope.py
│ │ ├── swaggerfiled.py
│ │ ├── tokenauth.py
│ │ └── utils.py
│ ├── models # Model 层
│ ├── service # Service 层
│ │ ├── init.py
│ │ ├── app_token.py
│ │ ├── order.py
│ │ ├── pay.py
│ │ ├── token.py
│ │ └── wx_token.py
│ ├── validators # 参数校验层
│ │ ├── __init.py
│ │ ├── base.py
│ │ ├── forms.py
│ │ └── params.py
│ ├── web # 网页文件
│ │ ├── __init.py
│ │ └── auth.py
│ └── app.py
├── fake.py # 生成临时用户
├── server.py # 启动程序(项目入口)
├── config.ini
├── pyproject.toml # uv 项目配置和依赖文件
├── uv.lock # uv 锁定文件 (自动生成)
├── Pipfile # 旧的 pipenv 配置文件 (可删除)
├── code.md # 错误码(用于前后端开发)
├── README.md # 项目说明文档
├── zerd.sql
└── LICENSE
业务逻辑主要放在 Model 层
项目架构体系
DAO层(数据访问层),全称为data access object
属于一种比较底层,比较基础的操作,对于数据库的操作,具体到对于某个表的增删改查。
DAO一定是和数据库的某一张表一一对应的,其中封装了增删改查基本操作,建议DAO只做原子操作,增删改查。
Service层(服务层)
是对一个或多个DAO进行的再次封装,封装成一个服务,因此不只是一个原子操作,需要事务控制。
Controller层(业务层)
管理用户的操作,用户界面传过的请求,调用对应的服务(service),完成用户请求的处理.
Swagger 是一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful风格的 Web 服务。
本项目使用 Flasgger库自动生成 Swagger 风格(Demo)的API文档。
查阅 API文档(本项目)
启动服务(DEBUG 模式下)
在浏览器端输入:http://localhost:8080/apidocs/#/
基于 HTTPBasicAuth 来传递token
所以, Postman 中 Authorization 设置使用 Basic Auth;
Flassger 中 securityDefinitions 设置使用 basicAuth (详见config/setting.py)
本项目选择在 Ubuntu 16.04+ 上,用 Nginx + Gunicorn + uv 部署[3],其中 Gunicorn 取代 uWsgi。
Flask 与 uWsgi 结合有许多难以处理的 bug
curl -LsSf https://astral.sh/uv/install.sh | sh
# 1. 克隆项目
git clone https://github.com/Allen7D/mini-shop-server.git
cd mini-shop-server
# 2. 使用 uv 安装依赖
uv sync
# 3. 运行服务
uv run gunicorn -w 4 -b 127.0.0.1:8080 server:app # 在8080端口开启 gunicorn
fuser -k 8080/tcp # 关闭占用8080端口的服务
本地与线上的 Swagger API 文档的接口的地址是不同的,但都依赖同一个配置文件 app\config\setting.py
。
而个人项目有着本地和线上同步,开发和测试同步的需求,会不断修改 app\config\setting.py
文件。
本地
和 线上
自动根据所处的环境变量「ENV_MODE」决定,选择不同的配置文件。
具体查看 app/api/v2/file.py
的 upload_file
视图函数
默认下载路径前缀 http://0.0.0.0:8080/static/
访问 app/static/images
目录下的资源
http://0.0.0.0:8080/static/images/1@theme.png
访问 app/static/files
目录下的资源
http://0.0.0.0:8080/static/files/Python面向对象编程指南.epub
具体查看 app/lib/redprint.py
的 doc
函数
不改动第三方库 Flasgger的 swag_from(装饰器函数)的源码,对其进行了功能的扩展
$ nginx -s stop # 停止 nginx
$ nginx -s reload # 重启 nginx
建立 文件A
快捷方式 文件B
: ln –s 源文件A 目标文件B
以 /etc/nginx/sites-available/server
为源文件,以 /etc/nginx/sites-enabled/server
为目标文件,使得2个文件同步。ln -s /etc/nginx/sites-available/server /etc/nginx/sites-enabled/server
/etc/nginx/sites-available/server
配置如下:
server {
listen 443 default;
server_name www.ivinetrue.com ivinetrue.com;
ssl on;
root html;
index index.html index.htm;
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
ssl_certificate cert/ivinetrue.pem;
ssl_certificate_key cert/ivinetrue.key;
ssl_session_timeout 10m;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
location / {
include proxy_params;
proxy_pass http://unix:/home/workspace/mini-shop-server/server.sock;
# proxy_pass http://127.0.0.1:8080; # 弃用
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_headers_hash_max_size 51200;
proxy_headers_hash_bucket_size 6400;
}
location /static/ {
alias /home/workspace/mini-shop-server/app/static/; # 静态资源文件路径
}
}
server {
listen 80;
server_name www.ivinetrue.com ivinetrue.com;
rewrite ^(.*)$ https://$host$1 permanent; # https 代理
}
Nginx 的公共配置(例如: gzip)需要修改 /etc/nginx/nginx.conf
路径 /etc/supervisor/conf.d/server.conf
配置文件
[program:server]
environment=PATH='/root/.local/share/virtualenvs/server-4o3oDD8t/bin/python'
command = /root/.local/share/virtualenvs/server-4o3oDD8t/bin/gunicorn -w 4 -b unix:/home/workspace/morning-star/server/server.sock server:app
directory = /home/workspace/morning-star/server
user = root
#日志输出
stderr_logfile=/tmp/blog_stderr.log
stdout_logfile=/tmp/blog_stdout.log
运行supervisorctl restart server
微信小程序链接。
基于 Flask框架构建 RESTful API。
点击查阅 API文档(Swagger风格)
基于 Vue.js框架和Element-UI组件库 链接
路线: 1 -> 2 -> 3 -> 4
【1】PyCharm配置使用Flask-Script启动以及开启Debug模式
【2】Flask 上传文件
【3】Flask + Gunicorn + Nginx 部署
【4】centos7 下通过nginx+uwsgi部署django应用
【5】Nginx的https配置记录以及http强制跳转到https的方法梳理
【6】Nginx配置HTTPS
【8】Automatically enable HTTPS on your website with EFF’s Certbot.
【9】ubuntu16.04 64bit 升级 python3.5 python3.6
【10】Lin-CMS:优秀的 Flask & Vue 结合的前后端分离的 CMS 解决方案
【11】基于Linux环境搭建Nginx+uWSGI+Python框