Django简介

Django是使用Python编写的一个开源Web框架。可以用它来快速搭建一个高性能的网站。

Django也是一个MVC框架。但是在Django中,控制器接受用户输入的部分由框架自行处理,所以 Django 里更关注的是模型(Model)、模板(Template)和视图(Views),称为 MTV模式:
    M 代表模型(Model),即数据存取层。 该层处理与数据相关的所有事务: 如何存取、如何验证有效性、包含哪些行为以及数据之间的关系等。
    T 代表模板(Template),即表现层。 该层处理与表现相关的决定: 如何在页面或其他类型文档中进行显示。
    V 代表视图(View),即业务逻辑层。 该层包含存取模型及调取恰当模板的相关逻辑。 你可以把它看作模型与模板之间的桥梁。

django 架构图 界面 django框架mvt_python

需要注意的是,不能简单的把MVC控制器,把MVC视图。
区别在于:

Django视图指定的数据。
或者说, Django将MVC中的视图进一步分解为“展现哪些数据”“如何展现”,使得Django的模板可以根据需要随时替换,而不仅仅限制于内置的模板。

至于MVC控制器部分,由Django框架的URLconf来实现。URLconf设计非常巧妙,其机制是使用正则表达式匹配URL,然后调用合适的Python函数。虽然一开始有些不习惯,但是你很快就会喜欢上它,因为URLconf对于URL的规则没有任何限制,你完全可以设计成任意的URL风格,不管是传统的,RESTful的,或者是另类的。

 Django基本命令

1、下载Django:

pip3 install diango

2、创建一个django project

django-admin.py startproject mysite

当前目录下会生成mysite的工程,目录结构如下:

django 架构图 界面 django框架mvt_django_02

manage.py ----- Django项目里面的工具,通过它可以调用django shell和数据库等。

settings.py ---- 包含了项目的默认设置,包括数据库信息,调试标志以及其他一些工作的变量。

urls.py ----- 负责把URL模式映射到应用程序。

wsgi.py------遵循WSGI规范,上线一般使用uwsgi+nginx

3、在mysite目录下创建应用

python manage.py startapp blog

django 架构图 界面 django框架mvt_django_03

migrations        #数据库修改表结构记录
admin.py          #Django提供的后台管理
apps.py           #当前app配置文件
models.py         #Django中的ORM,写指定的类  通过命令可以创建数据库结构
tests.py          #项目的单元测试
views.py          #MTV中的视图,用于写业务逻辑

4、启动django项目

python manage.py runserver 8080

这样我们的django就启动起来了!当我们访问:http://127.0.0.1:8080/时就可以看到:

 

django 架构图 界面 django框架mvt_django 架构图 界面_04

django常用命令

#创建django命令
django-admin.py startproject project-name
#创建django的app
python manage.py startapp app-name
或 django-admin.py startapp app-name
#同步数据库
python manage.py syncdb
#注意:Django 1.7.1及以上的版本需要用以下命令
python manage.py makemigrations
python manage.py migrate
#命令行调试模式
python manage.py runserver 8001
python manage.py runserver 0.0.0.0:8000
#清除数据库
python manage.py flush
#创建超级管理员
python manage.py createsuperuser
按照提示输入
#修改管理员密码
python manage.py changepassword username(需要修改的用户名)
#导入和导出数据
python manage.py dumpdata appname > appname.json
python manage.py loaddata appname.json
#进入数据库
python manage.py dbshell

在windows下推荐使用Pycharm创建Django项目

在Pycharm中创建Django项目的方法。

启动Pycharm后,点击file-->new project,出现下面的对话框。

django 架构图 界面 django框架mvt_html_05

选择Django栏目,输入项目名称,按照惯例的mysite。选择Python解释器版本,点击create创建。

Django将自动生成下面的目录结构:

django 架构图 界面 django框架mvt_django 架构图 界面_06

不用手动调用diango-admin命令。同样的是,会自动创建与项目同名的目录,包含了配置文件。templates目录是Pycharm自动安装,HTML文件存放处,也就是MTV中的T的目录。manage.py则一样是Django项目管理文件。

启动django项目

在pycharm中启动服务器也不需要输入命令,如下图:

在Pycharm的上部工具栏中找到下面图示的图标。

django 架构图 界面 django框架mvt_django_07

点击edit configurations

django 架构图 界面 django框架mvt_django_08

在host中填入127.0.0.1,port中填入8000。

OK确定之后,点击绿色的三角,web服务就运行起来了。

django 架构图 界面 django框架mvt_django 架构图 界面_09

django 架构图 界面 django框架mvt_python_10

按图所示,自动跳转到浏览器程序界面,如果看到下面的界面,程序可以正常使用

 

django 架构图 界面 django框架mvt_html_11

如果想让局域网内其他机器通过IP访问,则需要在全局设置setting中设置 ALLOWED_HOSTS = ['192.168.1.101'],

简单的django编写

创建Django

一个project包含很多个Django app以及对它们的配置。技术上,project的作用是提供配置文件,比方说哪里定义数据库连接信息, 安装的app列表, TEMPLATE_DIRS ,等等。一个app是一套Django功能的集合,通常包括模型和视图,按Python的包结构的方式存在。

创建app blog:

django 架构图 界面 django框架mvt_html_12

django 架构图 界面 django框架mvt_python_13

执行命令后,在项目结构中,可见新增了目录blog

django 架构图 界面 django框架mvt_python_14

编写urls,views,models

编写视图blog/views.py 文件

views:作为MVC中的C,接收用户的输入,调用数据库Model层和业务逻辑Model层,处理后将处理结果渲染到V层中去。

blog/views.py:

from django.http import HttpResponse
# Create your views here.
def index(request):
return HttpResponse("Hello, world 你好")

编写urls

urls,程序的入口,支持正则匹配访问url,将访问url映射到views中的具体某个函数中。

为了能调用到上面这个views,我们需要将views.index函数映射到URL中。

在blog目录没有urls.py 文件,我们在blog目录下创建一个urls.py 文件

blog/urls.py

from django.conf.urls import url
from . import views
urlpatterns = [
    url(r'^$', views.index, name='index'),
]

将创建的urls.py 添加到全局urls.py中 mysite/urls.py

from django.conf.urls import include,url
from django.contrib import admin

urlpatterns = [
    #当用户访问http://127.0.0.1:8000,采用views下面的index函数处理,^表示开头,$表示结尾
    url(r'^blog/', include('blog.urls')),
    #当用户访问http://127.0.0.1:8000/admin/时候使用admin.site.urls处理
    url(r'^admin/', admin.site.urls),
]

通过访问 http://127.0.0.1:8000/blog/ 可以调用到所编写的views

django 架构图 界面 django框架mvt_python_15

通常我们都是将html文件返回给用户。

写这么一个index.html文件:

在templates目录中 编写一个index 文件

django 架构图 界面 django框架mvt_html_16

django 架构图 界面 django框架mvt_django 架构图 界面_17

django 架构图 界面 django框架mvt_django 架构图 界面_18

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<style>
    .classh1{
        color: antiquewhite;
    }
</style>
<body>
    <h1 class="classh1">Hell world!</h1>
</body>
</html>

index 文件

修改一下blog/views.py文件

from django.shortcuts import render #render模块是pycharm自动导入的
from django.http import HttpResponse
# Create your views here.
def index(request):
    #return HttpResponse("Hello, world 你好")
    return render(request,"index.html",)

django 架构图 界面 django框架mvt_django_19

让django知道我们的html文件在哪里,需要修改mysite/settings.py文件的相应内容。默认情况下,无需修改。

django 架构图 界面 django框架mvt_django_20

重新启动web服务。在浏览器刷新一下,你会看到带有样式的“hello world”。

静态文件

在django中,一般将静态文件放在static目录中。接下来,在mysite中新建个static目录。CSS,JS和各种插件都可以放置在这个目录里。

django 架构图 界面 django框架mvt_django_21

让django找到这个目录,需要对mysite/settings进行配置

 

# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.11/howto/static-files/

STATIC_URL = '/static/'

STATICFILES_DIRS=[
            os.path.join(BASE_DIR,"static")
]

django 架构图 界面 django框架mvt_django_22

在index.html文件中,可以引入js文件了:

django 架构图 界面 django框架mvt_django_23

django 架构图 界面 django框架mvt_django 架构图 界面_17

django 架构图 界面 django框架mvt_django 架构图 界面_18

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link href="/static/dist/css/bootstrap.css" rel="stylesheet">
    <style>
        *{
            margin-top: 10px;
        }
    </style>
  </head>
  <body>
    <div class="jumbotron container">
        <h1>Hello world!!</h1>
        <p ><a class="btn btn-primary btn-lg" href="#" role="button">Learn more</a></p>
    </div>

    <script src="/static/dist/js/jquery-3.2.1.min.js"></script>
    <script src="/static/dist/js/bootstrap.min.js"></script>

</body>
</html>

View Code

重新启动web服务,刷新浏览器,查看结果。

django 架构图 界面 django框架mvt_django_26

接收用户发送的数据

web服务器和用户之间没有动态交互。

下面我们设计一个表单,让用户输入用户名和密码,提交给index这个url,服务器将接收到这些数据。

先修改index.html文件

django 架构图 界面 django框架mvt_django 架构图 界面_17

django 架构图 界面 django框架mvt_django 架构图 界面_18

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link href="/static/dist/css/bootstrap.css" rel="stylesheet">
    <style>
        *{
            margin-top: 10px;
        }
    </style>
  </head>
  <body>

  <h1 style="...">用户输入</h1>
  <form action="/index/" method="post">
      <input type="text" name="username"/>  
      <input type="password" name="password"/> 
      <input type="submit" value="提交"/>
  </form>

</body>
</html>

View Code

然后修改blog/views.py文件

django 架构图 界面 django框架mvt_django 架构图 界面_17

django 架构图 界面 django框架mvt_django 架构图 界面_18

def index(request):
    if request.method == "POST":
        username = request.POST.get("username",None)
        password = request.POST.get("password",None)
        print(username,password)
    return render(request,"index.html")

View Code

重启web服务时,会出错,因为django有一个跨站请求保护机制,我们在settings文件中将它关闭。

django 架构图 界面 django框架mvt_html_31

浏览器,刷新页面:

django 架构图 界面 django框架mvt_python_32

输入点内容提交 ,然后我们在pycharm中可以看到相应的数据。

收到了用户的数据,但返回给用户的依然是个静态页面,通常我们会根据用户的数据,进行处理后在返回给用户。

django采用自己的模板语言,根据提供的数据,替换掉html中的相应部分

修改views.py文件:

数据库

支持SQLite 3(默认)、PostgreSQL 、MySQL、Oracle数据库的操作

django 架构图 界面 django框架mvt_django 架构图 界面_17

django 架构图 界面 django框架mvt_django 架构图 界面_18

# 默认是SQLit 3 的配置

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}


# MySQL的配置

DATABASES = {
    'default': {
    'ENGINE': 'django.db.backends.mysql',
    'NAME':'dbname',   #注意这里的数据库应该以utf-8编码
    'USER': 'xxx',
    'PASSWORD': 'xxx',
    'HOST': '',
    'PORT': '',
    }
}

# 对于python3的使用者们还需要再加一步操作
# 由于Django内部连接MySQL时使用的是MySQLdb模块,而python3中还无此模块,所以需要使用pymysql来代替
  
# 如下设置放置的与project同名的配置的 __init__.py文件中
  
import pymysql
pymysql.install_as_MySQLdb()


# PostgreSQL配置
DATABASES = {
    'default': {
        'NAME': 'app_data',
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'USER': 'XXX',
        'PASSWORD': 'XXX'
    }


# Oracle配置
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.oracle',
        'NAME': 'xx',
        'USER': 'xxx',
        'PASSWORD': 'a_xxx',
        'HOST': '',
        'PORT': '',
    }
}

View Code