Skip to content

高仿慕课网:py3.5 + Django1.10 + xadmin 搭建的在线课程教育平台

Notifications You must be signed in to change notification settings

chuangll/imooc-django

 
 

Repository files navigation

IMOOC

环境

  • Python 3.5
  • Django 1.10.5
  • xadmin 0.6

网站功能

网站功能脑图

快速启动该项目

  1. 安装 mysql
  2. 安装 python3
  3. 建立虚拟环境(可选步骤)
git clone https://github.com/zaxlct/MxOnline_Django
cd MxOnline_Django
make dev
# 建立一个名为 imooc 数据库
make migrate
make run

因为此时数据库为空,所以页面看起来没什么东西,需要手动往数据库里加数据,或者登陆 admin ,添加数据。

使用 docker 快速部署/开发项目

Linux/Mac/Windos 用 Docker 部署项目步骤

Pycharm 启动项目详细步骤

  • 克隆项目
git clone https://github.com/zaxlct/MxOnline_Django
  • 下载项目依赖
make dev
  • 配置数据库
  1. 确保你已经安装了 MySQL
  2. settingsdev.py里的 DATABASES 填入你的本地的数据库信息(开发环境),settings.py 里填入你服务器的数据库信息(部署环境)。
# 这是我本机的数据库信息,仅提供参考
DATABASES = {
   'default': {
       'ENGINE': 'django.db.backends.mysql',
       'NAME': 'imooc',
       'USER': 'root', 
       'PASSWORD': 'root',
       'HOST': '127.0.0.1',
   }
}
  • 创建数据表
make migrate
  • 配置 PyCharm 项目环境变量

    1. 第一步:点击 Edit Config

    点击 Edit Config

    1. 第二步:点击 环境变量配置

    点击 环境变量配置

    1. 第三步:输入环境变量

    输入环境变量

Name:   DJANGO_SETTINGS_MODULE
Value:  imooc.settingsdev
  • 启动 Django 的 server
make run

settingsdev.py 有什么用?

项目上线时 settings.py 必须设置 DEBUG=False,这时 Django 不会用自带的 server 去加载 js/css/img 等静态文件,需要用 nginx 之类的去做静态文件的 server。     为了避免来回的修改 setting.py,项目开发时的配置在 settingsdev.py 里,项目部署上线时的配置在 settings.py 里。不要随意修改 setting.py

** 注意:PyCharm 默认 settings.py 为配置文件,所以才需要配置 PyCharm 项目环境变量 **

Django 操作 MySql 配置

# 安装 PyMySQL
pip install PyMySQL

# settings.py
import pymysql
pymysql.install_as_MySQLdb()

python3 的一些坑

models.pydef __unicode__(self): => def __str__(self):

Django 1.10 的一些坑

In Django 1.10 django.core.context_processors has been moved to django.template.context_processors

xadmin 不支持 Django 1.11

django 1.11 Lib\site-packages\django\forms\widgets.py 中已经没有了 RadioFieldRenderer 这个类,故 xadmin-python3 分支只支持到 django 1.10

About

高仿慕课网:py3.5 + Django1.10 + xadmin 搭建的在线课程教育平台

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 37.0%
  • CSS 29.0%
  • JavaScript 18.2%
  • HTML 15.7%
  • Other 0.1%