python框架Django实战商城项目之工程搭建过程图文详解

作者:zyjImmortal 的个人博客 时间:2022-12-16 16:25:57 

项目说明

该电商项目类似于京东商城,主要模块有验证、用户、第三方登录、首页广告、商品、购物车、订单、支付以及后台管理系统。项目开发模式采用前后端不分离的模式,为了提高搜索引擎排名,页面整体刷新采用jinja2模板引擎实现,局部刷新采用vue.js实现。

项目运行机制如下:

python框架Django实战商城项目之工程搭建过程图文详解

项目搭建

工程创建

项目使用码云进行源代码版本控制,在码云创建好后直接克隆到本地即可,然后在项目根目录下执行virtualenv venv创建虚拟环境,source venv/bin/activat激活虚拟环境后,安装django后,执行 django-admin startproject immortal_mall创建django工程。

配置开发环境

商城项目有两个环境,分别为测试环境和开发环境,django项目在创建完成后只有一个settings配置文件,但是两个环境需要两个配置文件,这里需要修改django获取配置文件的方式。新建settings包,再新建dev和pro两个配置文件,将默认生成的settings文件里面的内容拷贝至dev和pro文件里,结果如下

python框架Django实战商城项目之工程搭建过程图文详解

再在mange.py文件里指定开发环境需要的配置文件,生成环境的后面再说

python框架Django实战商城项目之工程搭建过程图文详解

配置jiaja2模板引擎

安装jinja2扩展包pip install jinja2,然后在dev文件中配置一下

python框架Django实战商城项目之工程搭建过程图文详解

这里有个注意的点,如果在运行的时候报错了,提示

python框架Django实战商城项目之工程搭建过程图文详解

这时是因为注释掉了django默认的模板配置,需要去掉注释,只添加新的版本引起即可。

配置mysql数据库

新建数据库

新建数据库

create database meiduo charset=utf8;

新建mysql用户

create user mall identified by '123456';

授权用户只能访问immortal_mall数据库

grant all on immortal_mall.* to 'mall'@'%';

刷新授权

flush privileges;

配置数据库


DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'immortal_mall',
'HOST': '127.0.0.1',
'USER': 'zhouyajun',
'PASSWORD': '12345678',
'PORT': '3306'
}
}

django默认使用的是mysqlclient工具,需要单独安装,这里用pymysql代替,在工程同名子目录的__init__.py文件中,写入下面代码


import pymysql
pymysql.install_as_MySQLdb()

在启动项目对的时候可能会报错,提示mysql

File "/Users/lixiang/.env/lib/python3.6/site-packages/django/db/backends/mysql/base.py", line 36, in <module> raise ImproperlyConfigured('mysqlclient 1.3.13 or newer is required; you have %s.' % Database.__version__) django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.13 or newer is required; you have 0.9.3.

具体解决方式可以参考这里https://zhuanlan.zhihu.com/p/76920424

配置redis

商城采用redis作为缓存服务

pip install django-redis

这里是django-redis的使用文档https://django-redis-chs.readthedocs.io/zh_CN/latest/,在dev文件中配置redis

缓存配置


CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://127.0.0.1:6379/2",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
}
},
"session": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://127.0.0.1:6379/3",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
}
}
}
SESSION_ENGINE = "django.contrib.sessions.backends.cache"
SESSION_CACHE_ALIAS = "session"

default是redis采用的默认配置,用的是2号数据库,session是redis保持保持状态的配置项,用的是3号数据库,

日志配置


# 日志配置
LOGGING = {
'version': 1,
'disable_existing_loggers': False, # 是否禁用已经存在的日志器
'formatters': { # 日志信息显示的格式
'verbose': {
'format': '%(levelname)s %(asctime)s %(module)s %(lineno)d %(message)s'
},
'simple': {
'format': '%(levelname)s %(module)s %(lineno)d %(message)s'
},
},
'filters': { # 对日志进行过滤
'require_debug_true': { # django在debug模式下才输出日志
'()': 'django.utils.log.RequireDebugTrue',
},
},
'handlers': { # 日志处理方法
'console': { # 向终端中输出日志
'level': 'INFO',
'filters': ['require_debug_true'],
'class': 'logging.StreamHandler',
'formatter': 'simple'
},
'file': { # 向文件中输出日志
'level': 'INFO',
'class': 'logging.handlers.RotatingFileHandler',
'filename': os.path.join(os.path.dirname(BASE_DIR), 'logs/mall.log'), # 日志文件的位置
'maxBytes': 300 * 1024 * 1024,
'backupCount': 10,
'formatter': 'verbose'
},
},
'loggers': { # 日志器
'django': { # 定义了一个名为django的日志器
'handlers': ['console', 'file'], # 可以同时向终端与文件中输出日志
'propagate': True, # 是否继续传递日志信息
'level': 'INFO', # 日志器接收的最低日志级别
},
}
}

这里需要在项目的根目录下手动创建logs文件,写日志的时候呢,我们希望能够自动分日期去写,每天的日志写到不同的文件里,这里可以使用python模块自带的TimedRotatingFileHandler,也可以自定义一个handler类去实现。我这里呢自己实现了一个类叫做MallRotatingFileHandler 效果如下:

python框架Django实战商城项目之工程搭建过程图文详解

该类实现按月划分日志文件,自动按照当天日期命名日志文件,也可以定义文件容量。

配置前端静态文件准备静态文件夹static

python框架Django实战商城项目之工程搭建过程图文详解

指定静态文件加载路径


# 指定加载静态恩建路由前缀
STATIC_URL = '/static/'
# 配置静态文件加载路径
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]

运行项目,请求获取一张图片http://127.0.0.1:8989/static/images/adv01.jpg,成功获取表示配置正确。

最终项目各个目录展示成果:

python框架Django实战商城项目之工程搭建过程图文详解

来源:https://www.immortalp.com/articles/2020/03/08/1583673760687.html

标签:python,Django,项目,搭建
0
投稿

猜你喜欢

  • 我的ImageMagick使用心得

    2008-10-21 11:05:00
  • Python光学仿真教程实现光线追踪

    2023-08-12 00:27:39
  • JSON.stringify转换JSON时日期时间不准确的解决方法

    2014-07-20 13:25:07
  • asp组件上传

    2010-05-27 12:16:00
  • Web页脚设计的版权格式规范

    2009-07-22 20:52:00
  • javascript中实现override,overload和类似c#中的property

    2008-05-16 12:01:00
  • 对django2.0 关联表的必填on_delete参数的含义解析

    2023-04-01 22:59:28
  • 注册表单的规则——读《Patterns for Sign Up &Ramp Up》

    2008-07-17 12:51:00
  • asp 去掉html中的table正则代码函数

    2011-04-06 10:48:00
  • 通过实例解析Python RPC实现原理及方法

    2022-06-19 00:50:38
  • python使用rabbitmq实现网络爬虫示例

    2022-04-20 20:11:58
  • Mootools 1.2教程(23)——滑动效果(Slide)

    2009-03-04 12:33:00
  • JScript 的内存回收

    2007-10-16 20:02:00
  • 简单掌握Python的Collections模块中counter结构的用法

    2023-05-17 00:20:13
  • Opencv实现二维直方图的计算及绘制

    2023-07-18 23:34:52
  • Oracle SQL中实现indexOf和lastIndexOf功能的思路及代码

    2023-07-14 10:26:52
  • 兼容所有浏览器的设为首页与显示小策略

    2009-01-12 18:50:00
  • 浅析python标准库中的glob

    2023-08-04 02:39:10
  • php strstr查找字符串中是否包含某些字符的查找函数

    2023-11-17 01:42:23
  • 使用Python的Bottle框架写一个简单的服务接口的示例

    2023-09-01 17:29:50
  • asp之家 网络编程 m.aspxhome.com