初始Django

初始Django

一、Django的历史

​ Django 是从真实世界的应用中成长起来的,它是由堪萨斯(Kansas)州 Lawrence 城中的一个网络开发小组编写的。它诞生于 2003 年秋天,那时 Lawrence Journal-World 报纸的程序员 Adrian Holovaty 和 Simon Willison 开始用 Python 来编写程序。
​ 当时他们的 World Online 小组制作并维护当地的几个新闻站点,并在以新闻界特有的快节奏开发环境中逐渐发展。这些站点包括有 LJWorld.com、Lawrence.com 和 KUsports.com,记者(或管理层) 要求增加的特征或整个程序都能在计划时间内快速的被建立,这些时间通常只有几天或几个小时。因此,Adrian 和 Simon 开发了一种节省时间的网络程序开发框架,这是在截止时间前能完成程序的唯一途径。
​ 2005 年的夏天,当这个框架开发完成时,它已经用来制作了很多个 World Online 的站点。当时 World Online 小组中的 Jacob Kaplan-Moss 决定把这个框架发布为一个开源软件。
​ 从今往后数年,Django是一个有着数以万计的用户和贡献者,在世界广泛传播的完善开源项目。原来的World Online的两个开发者(Adrian and Jacob)仍然掌握着Django,但是其发展方向受社区团队的影响更大。
这些历史都是相关联的,因为她们帮助解释了很重要的两点。
​ 第一,Django最可爱的地方。Django 诞生于新闻网站的环境中,因此它提供很多了特性(如管理后台),非常适合内容类的网站(不要看到这就感到沮丧,尽管Django擅长于动态内容管理系统,但并不表示Django主要的目的就是用来创建动态内容的网站。某些方面特别高效与其他方面不高效是有区别的,Django在其他方面也同样高效。)
​ 第二,Django的起源造就了它的开源社区的文化。因为Django来自于真实世界中的代码,而不是来自于一个科研项目或者商业产品,她主要集中力量来解决Web开发中遇到的问题,同样也是Django的开发者经常遇到的问题。这样,Django每天在现有的基础上进步。框架的开发者对于让开发人员节省时间,编写更加容易维护的程序,同时保证程序运行的效率具有极大的兴趣。无他,开发者动力来源于自己的目标:节省时间,快乐工作。

二、Django介绍

Django是由Python编写的Web框架,遵循 MVC 设计模式。MVC是Model、View、Controller三个单词的简写,分别代表模型、视图、控制器。Django其实也是一个MTV 的设计模式。MTV是Model、Template、View三个单词的简写,分别代表模型、模版、视图。但是在Django中,控制器接受用户输入的部分由框架自行处理,所以 Django 里更关注的是模型(Model)、模板(Template)和视图(Views),称为 MTV模式。

Django 框架的核心组件有:

  • 用于创建模型的对象关系映射
  • 为最终用户设计较好的管理界面
  • URL 设计
  • 设计者友好的模板语言
  • 缓存系统

三、Django的架构模式

MVC架构模式

mvc是由美国的施乐公司(代表产品是打印机、复印机产业)旗下的帕罗奥多研究中心一位程序员发明了smalltalk语言(第二个面向对象的语言),simula67(第一个面向对象的语言)

MVC的产生理念:分开。专门的人做专门的事(像公司中各部门一样,不同的部门做着不同的事)

MVC的核心思想:解藕。(例如:电脑硬盘坏了,不需要把整个电脑换掉,只需要把硬盘换了,就可以正常使用了。)

MVC是一种使用MVC(Model View Controller 模型-视图-控制器)设计创建 Web 应用程序的模式:

  • M为Model(模型), 主要是对数据库的交互,对数据库中的数据进行增删改查操作。
  • V为View,主要是用于封装,来生成展示给浏览器的html用户
  • C为Controll,主要是用于接受请求,处理业务逻辑,返回结果,与Model和View交互调度

在这里插入图片描述

MVT架构模式

​ Django在处理的过程中,对于经典的MVC处理模式并不是非常认同,在实际项目开发过程中控制器Controller起到的作用非常的有限,所以Django将控制器部分也进行了封装,但是同时扩展了视图View部分,增加了模板功能实现了前端网页的复用,所以Django的架构模式更加符合MVT处理模式

  • M:model数据模型
  • V:View视图
  • T:Template模板

在这里插入图片描述

安装Django

一、虚拟环境简介

1、什么是虚拟环境?

虚拟环境是用于依赖项管理和项目隔离的Python工具,允许Python站点包(第三方库)安装在本地特定项目的隔离目录中,而不是全局安装。

2、为什么需要虚拟环境?

我们所有的第三方包安装都是直接通过pip install xx的方式进行安装的,这样安装会将那个包安装到你的系统级的Python环境中。但是这样有一个问题,就是如果你现在用Django 2.1.x写了个网站,然后你的领导跟说,之前有一个旧项目是用Django 1.11.x开发的,让你来维护,两个版本的django,有些语法上的差异,可能会导致维护旧项目会出问题,这个时候,就可以通过虚拟环境来解决这个问题。

3、常用的虚拟环境

virtualenv、venv、conda

windows下安装virtualenv
pip install virtualenv
pip install virtualenvwrapper-win

virtualenv创建虚拟环境时,目录是创建在C盘下的用户文件夹下,不方便管理,可以通过更改配置,来更改默认创建位置

二、更改虚拟环境默认创建位置

添加环境变量

在这里插入图片描述

此电脑–>右键属性–>高级系统设置–>高级–>环境变量–>新建,在弹出的对话框中,输入以下内容

变量名:WORKON_HOME

变量值:d:\myenv

变量值后面跟的是一个文件夹的路径

在python的scripts下,找到mkvirtualenv.bat

在这里插入图片描述

修改其中第24行内容

在这里插入图片描述

修改红色方框中,=号后面的内容为环境变量中变量值的内容

三、virtualenv使用

  • 创建虚拟环境

    # mkvirtualenv 环境名
    mkvirtualenv my_env
    

    创建好的虚拟环境,默认已经在虚拟环境当中,不需要再次进入

  • 进入虚拟环境

    # workon 环境名
    workon my_env
    
  • 退出虚拟环境

    deactivate
    
  • 删除虚拟环境

    # rmvirtualenv 环境名
    rmvirtualenv my_env
    
  • 列出所有的虚拟环境

    lsvirtualenv
    
  • 创建虚拟环境的时候指定Python版本

    mkvirtualenv my_env --python==d:\Program Files\Python39\python.exe 
    

四、安装Django

# 创建虚拟环境
mkvirtualenv mydj32

# 进入虚拟环境
workon mydj32

# 在虚拟环境中不指定版本,直接安装,默认安装最新版
pip install django  # [安装最新版本的django, 生产环境当中不适用]

# 安装指定版本的Django
pip install django==3.2.18  # 安装3.2版本当中最新版本

# 如果安装速度慢,可以使用国内镜像安装
pip install django==3.2.18 -i https://pypi.douban.com/simple/

创建项目

1、使用命令创建项目

1)、 使用命令创建项目
# cd 进入到要创建项目的目录下   D:\mycodes\django_code

D:\mycodes\django_code>
    
# 进入虚拟环境   workon myenv
D:\mycodes\django_code>workon mydj32
(mydj32) D:\mycodes\django_code>
    
# 使用命令创建项目
(mydj32) D:\mycodes\django_code>django-admin startproject mysite
2)、 项目目录介绍
mysite
	__init__.py
    asgi.py
    settings.py  	# 项目的整体配置文件
    urls.py			# 项目的URL配置文件
    wsgi.py			# 项目与WSGI兼容的Web服务器入口
manage.py			# 项目管理文件,通过它管理项目
3)、启动项目
# 启动项目的命令
python manage.py runserver  # http://127.0.0.1:8000 默认启动IP和端口

# 批定IP和端口启动项目
python manage.py runserver 192.168.31.100:8080

在这里插入图片描述

2、创建子应用

Django的视图编写都在子应用中完成,在web应用中,通常有一些业务功能模块是在不同的项目中都可以复用的,故在开发中通常将工程项目拆分为不同的子功能模块,各功能模块间可以保持相对的独立。

创建app
# 使用命令创建应用    python manage.py startapp app_name
python manage.py startapp equipment
子应用目录文件说明
equipment
	migrations		# 存放数据库迁移历史文件
	__init__.py
    admin.py		# 网站的后台管理站点配置相关
    apps.py			# 当前子应用的相关信息
    models.py		# 用户保存数据库模型类
    tests.py		# 开发测试用例,编写单元测试
    views.py		# 编写Web应用视图函数

3、settings.py配置

# 项目所在的目录的根目录
BASE_DIR = Path(__file__).resolve().parent.parent

# 项目创建时生成的密钥
SECRET_KEY = 'django-insecure-8!&bnte&q$2g$a%xfds8)-5^1#@ora4)d**%=n59^@7^v7#1wl'

# 允许连接的主机
ALLOWED_HOSTS = []

# 应用列表
INSTALLED_APPS = [
    # 前6项为项目默认的应用
    'django.contrib.admin',  # django后端管理应用
    'django.contrib.auth',  # django认证应用
    'django.contrib.contenttypes',
    'django.contrib.sessions',  # django的session应用
    'django.contrib.messages',  # django的消息应用
    'django.contrib.staticfiles',  # django的静态文件

    # 自建app
    'equipment.apps.EquipmentConfig',
]

# 中间件
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

# 根路由
ROOT_URLCONF = 'mysite.urls'

# 数据库配置
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'mysite',
        'USER': 'root',
        'PASSWORD': 'Root@1234',
        'HOST': '127.0.0.1',
        'PORT': 3307,
    }
}

# 密码验证
AUTH_PASSWORD_VALIDATORS = [
    {
        'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
    },
]

# 语言时区设置
LANGUAGE_CODE = 'zh-hans'

TIME_ZONE = 'Asia/Shanghai'

USE_I18N = True

USE_L10N = True

USE_TZ = False

# 静态文件路由
STATIC_URL = '/static/'


请求和响应

1、基于模板的第一个Hello World

1. 编写FBV视图
from django.shortcuts import render

# Create your views here.


def index(request):
    return render(request, 'equipment/index.html')
2. 编写index.html内容

应用equipment下新建templates文件夹,在templates下新建equipment文件夹,在app同名的目录下新建index.html,写入如下内容:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>第一个Hello World</title>
</head>
<body>
    <h1>Hello world!!</h1>
</body>
</html>
3. 配置路由

在应用equipment下新建urls.py文件,配置如下内容:

from django.urls import path  # 导入django的path函数
from . import views  # 导入应用下的views.py这个文件

app_name = 'equipment'  # app的名称

# 路由配置列表
urlpatterns = [
    path('', views.index, name='index')
]
4. 配置主路由
from django.contrib import admin
from django.urls import path, include

urlpatterns = [
    path('admin/', admin.site.urls),
    path('equip/', include('equipment.urls')),
]
5. 访问页面效果展示

在这里插入图片描述

2、基于Json的第一个Hello world

1. 编写视图

不指定请求方式的话, 默认为GET请求

from django.http.response import JsonResponse


def index_api(request):
    return JsonResponse({
        'message': 'success',
        'code': 200,
        'data': 'Hello World!!'
    })
2. 配置路由
from django.urls import path
from . import views

app_name = 'equipment'

urlpatterns = [
    path('index_api/', views.index_api),
]
3. json请求效果展示

在这里插入图片描述

3、基于CBV的第一个请求

1. 编写请求视图

类视图在编写请求函数时,需要指定请求方式。如: get\post\put\delete\head等

from django.shortcuts import render
from django.views import View


class IndexView(View):
    """
    首页
    """

    def get(self, request):
        return render(request, 'equipment/index.html')
2. 配置路由
from django.urls import path
from . import views

app_name = 'equipment'

urlpatterns = [
    path('index/', views.IndexView.as_view()),
]
3. 页面效果展示

在这里插入图片描述

  • 25
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值