Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xiaowang012/fruitstore
使用Django 写的一个简单的水果商城系统,具有基本的商城功能,还没写完......
https://github.com/xiaowang012/fruitstore
bootstrap3 django mysql nginx python
Last synced: about 1 month ago
JSON representation
使用Django 写的一个简单的水果商城系统,具有基本的商城功能,还没写完......
- Host: GitHub
- URL: https://github.com/xiaowang012/fruitstore
- Owner: xiaowang012
- License: mit
- Created: 2022-04-06T01:23:40.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2022-05-11T13:27:12.000Z (over 2 years ago)
- Last Synced: 2024-10-14T04:21:46.301Z (about 1 month ago)
- Topics: bootstrap3, django, mysql, nginx, python
- Language: HTML
- Homepage:
- Size: 36.4 MB
- Stars: 7
- Watchers: 1
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# 使用 Django + Mysql 写的简单的水果商城系统
## 1.界面截图
### (1)登录界面
![](./img/login.png)
### (2) 注册用户界面
![](./img/register.png)
### (3) 修改密码界面
![](./img/update_password.png)
### (4) 商城主页
![home](./img/index.png)
### (5)商城水果列表页
![](./img/fruit_list.png)
### (6)商城水果详情页
![book](./img/fruit_details.png)
### (7)商城购物车页
![book](./img/shopping_cart.png)
### (8)个人信息页
![](./img/user_info.png)
### (9)确认订单页
![](./img/confirm_order.png)
### (10)用户管理
![](./img/management_user.png)
### (11)权限管理
![](./img/management_permission.png)
### (12)订单管理
![](./img/management_order.png)
### (13)商品管理
![](./img/management_goods.png)
### (14)角色管理
![](./img/management_role.png)
### (15)发货管理
![](./img/management_logistics.png)
### (16)查看发货清单
![](./img/logistics_sheet.png)
## 2.环境配置
### (1)安装Python环境
windows下:
下载Python3.6以上版本(python.org)
Linux(centos8):
自带python3.6.8
![15](./img/python3.png)
### (2) 安装虚拟环境并安装依赖包
windows下:
安装virtualenv模块 :pip install virtualenv
创建虚拟环境文件夹:cmd中输入: virtualenv fruit_ENV(需要创建的虚拟环境文件夹名称)
![15](./img/create_env_win.png)
激活虚拟环境: 在cmd中进入fruit_ENV\Scripts目录,输入:activate即可激活虚拟环境,退出虚拟环境: deactivate
安装依赖包:激活虚拟环境后cd 进入项目目录,里面有一个requirements.txt依赖文件,安装只需要使用:pip install -r requirements.txt即可自动安装所有的依赖包。
Linux下:
创建虚拟环境:virtualenv -p python3.6 django_ENV
![](./img/create_env.png)
激活虚拟环境: source fruit_ENV/bin/activate
除了上述步骤与windows不一样以外其他步骤均相同。
### (3)创建表结构
windows和Linux操作相同:
需要手动创建对应的数据库(使用的是mysql)安装完mysql数据库之后,使用:mysql -u root -p 登录数据库,输入create database django_database 创建名为:django_database (settings.py中的配置数据库名称为这个,也可以改为其他的,修改对应的配置即可)的数据库。然后创建表结构:使用命令:
python manage.py makemigrations
python manage.py migrate
python manage.py makemigrations fruit_app
python manage.py migrate fruit_app
创建完表结构之后,将测试数据(/testdata/django_database)导入到mysql中:
登录mysql数据库进行以下操作:
mysql -u root -p 输入密码
use django_database;
source G:\django_books\testdata\django_database.sql (windows)
或者source /django_books/testdata/django_database.sql (Linux)
创建好测试数据就可以登陆了。
## 3. 运行web应用程序
在登录前可以创建一个超级用户:python manage.py createsuperuser 输入一次用户名,邮箱,两次密码即可创建成功。
进入虚拟环境后:python manage.py runserver 0.0.0.0:5000 (ip和port可以任意指定,port不能被占用)即可运行该应用程序
![](./img/run.png)
## 4.使用nginx +gunicorn 部署
### (1)nginx的配置
#### 安装nginx :yum install nginx
(1)安装完成后查看nginx版本:nginx -v![](./img/nginx_version.png)
(2)在/etc/nginx/nginx.conf中修改配置:vim /etc/nginx/nginx.conf 注:server中的端口为nginx的监听端口, location中的地址为gunicorn 运行django wsgi服务的地址,下面两个location为配置的静态资源地址。如果出现加载静态资源报403的情况,需要把nginx中的配置:user nginx; 改为:user root; 修改完成后按esc 冒号 输入:wq 保存退出vim。
![](./img/nginx_config.png)
(3) 重启nginx : nginx -s reload 查看nginx的服务 :lsof -i:4999 查看到对应的进程即为配置成功 。运行nginx命令:nginx
![](./img/nginx_port.png)
### (2)使用gunicorn 运行服务
(1)安装gunicorn 包:pip install gunicorn
(2)使用gunicorn 运行django项目:进入虚拟环境,项目目录,执行: gunicorn -w 4 -b 127.0.0.1:5001 FruitStore.wsgi & (-w 为进程数,-b 为绑定的host:port FruitStore为项目名称,由django-admin startproject projectname 创建, &表示后台运行)
![2017](./img/gunicorn_run.png)
### (3)测试结果
访问网页并查看接口的服务器是否为nginx,查看到Server: nginx/1.20.2表示部署成功,注册用户后可以尝试登录是否成功。
![ng](./img/ng.png)