Django基础

Django框架的介绍

  • 2005年发布,采用Python语言编写的开源web框
  • 早期的时候Django主做新闻和内容管理的网站
  • 一个重量级的 Python Web框架,Django 配备了常用的大部分组件
    1. 基本配置
    2. 路由系统
    3. 原生HTML模板系统
    4. 视图 view
    5. Model模型,数据库连接和ORM数据库管理
    6. 中间件
    7. Cookie & Seesion
    8. 分页
    9. 数据库后台管理系统admin
  • Django的用途
    • 网站后端开发
    • 微信公众号、微信小程序等后台开发
    • 基于HTTP/HTTPS协议的后台服务器开发(tornado/gevent四层)
      • 在线语音/图像识别服务器
      • 在线第三方身份验证服务器等
  • Django的版本
    • 最新版本:2.2.x
    • 当前教学版本:1.11.8
  • Django的官网

Django的安装

  • 查看已安装的版本
    python >>> import django >>> print(django.VERSION) (1, 11, 8, 'final', 0)
  • 安装
    1. 在线安装
      • $ sudo pip3 install django 安装django的最新版本
      • $ sudo pip3 install django[==版本] 安装django的指定版本
      • 如:
        • $ sudo pip3 install django==1.11.8
    2. 离线安装
      • 下载安装包:
      • 安装离线包
        • $ tar -xvf Django-1.11.8.tar.gz
        • $ cd Django-1.11.8
        • $ sudo python3 setup.py install
    3. 用wheel离线安装
      • 下载安装包:
        • pip3 download -d /home/tarena/django_packs django==1.11.8
      • 安装离线包
        • $ pip3 install Django-1.11.8.whl
  • Django的卸载

  • $ pip3 uninstall django

  • Django 的开发环境
    • Django 1.11.x 支持 Python 2.7, 3.4, 3.5 和 3.6(长期支持版本 LTS)
    • 注: Django 1.11.x 不支持 Python 3.7

Django框架开发

创建项目的指令

  • $ django-admin startproject 项目名称
  • 如:

    • $ django-admin startproject mysite1
  • 运行

    $ cd mysite1
    $ python3 manage.py runserver
    # 或
    $ python3 manage.py runserver 5000  # 指定只能本机使用127.0.0.1的5000端口访问本机

    Django项目的目录结构

  • 示例:
    ```shell
    $ django-admin startproject mysite1
    $ tree mysite1/
    mysite1/
    ├── manage.py
    └── mysite1
    ├── init.py
    ├── settings.py
    ├── urls.py
    └── wsgi.py

    1 directory, 5 files
    ```
  • 项目目录结构解析:
    • manage.py
      • 此文件是项目管理的主程序,在开发阶段用于管理整个项目的开发运行的调式
      • manage.py 包含项目管理的子命令, 如:
        • python3 manage.py runserver 启动服务
        • python3 manage.py startapp 创建应用
        • python3 manage.py migrate 数据库迁移
        • ...
    • mysite1 项目包文件夹
      • 项目包的主文件夹(默认与项目名称一致)
      1. __init__.py
        • 包初始化文件,当此项目包被导入(import)时此文件会自动运行
      2. wsgi.py
        • WSGI 即 Web Server Gateway Interface
        • WEB服务网关接口的配置文件,仅部署项目时使用
      3. urls.py
        • 项目的基础路由配置文件,所有的动态路径必须先走该文件进行匹配
      4. settings.py
        • Django项目的配置文件, 此配置文件中的一些全局变量将为Django框架的运行传递一些参数
        • setting.py 配置文件,启动服务时自动调用,
        • 此配置文件中也可以定义一些自定义的变量用于作用全局作用域的数据传递
  • settings.py 文件介绍

    1. BASE_DIR

      • 用于绑定当前项目的绝对路径(动态计算出来的), 所有文件都可以依懒此路径
    2. DEBUG

      • 用于配置Django项目的启用模式, 取值:
        1. True 表示开发环境中使用 调试模式(用于开发中)
        2. False 表示当前项目运行在生产环境中(不启用调试)
    3. ALLOWED_HOSTS

      • 设置允许访问到本项目的网络地址列表,取值:
        1. [] 空列表,表示只有127.0.0.1, localhost能访问本项目
        2. ['*'],表示任何网络地址都能访问到当前项目
        3. ['192.168.1.3', '192.168.3.3'] 表示只有当前两个主机能访问当前项目
        • 注意:
          • 如果要在局域网其它主机也能访问此主机,启动方式应使用如下模式:
      • python3 manage.py runserver 0.0.0.0:5000 # 指定网络设备所有主机都可以通过5000端口访问(需加ALLOWED_HOSTS = ['*'])
    4. INSTALLED_APPS

      • 指定当前项目中安装的应用列表
    5. MIDDLEWARE

      • 用于注册中间件
    6. TEMPLATES

      • 用于指定模板的配置信息
    7. DATABASES

      • 用于指定数据库的配置信息
    8. LANGUAGE_CODE

      • 用于指定语言配置
      • 取值:
        • 英文 : "en-us"
        • 中文 : "zh-Hans"
    9. TIME_ZONE

      • 用于指定当前服务器端时区
      • 取值:
        • 世界标准时间: "UTC"
        • 中国时区 : "Asia/Shanghai"
    10. ROOT_URLCONF

      • 用于配置根级 url 配置 'mysite1.urls'
      • 如:
        • ROOT_URLCONF = 'mysite1.urls'

          注: 此模块可以通过 from django.conf import settings 导入和使用

URL 介绍

  • url 即统一资源定位符 Uniform Resource Locator
  • 作用:

    • 用来表示互联网上某个资源的地址。
  • 说明:

    • 互联网上的每个文件都有一个唯一的URL,它包含的信息指出文件的位置以及浏览器应该怎么处理它。
  • URL的一般语法格式为:
    protocol :// hostname[:port] / path [?query][#fragment]
  • 如:
    ```django
    http://tts.tmooc.cn/video/showVideo?menuId=657421&version=AID201908#subject
    注意:
    “?”后是查询字符串

  • 说明:
    • protocol(协议)
      • http 通过 HTTP 访问该资源。 格式 HTTP://
      • https 通过安全的 HTTPS 访问该资源。 格式 HTTPS://
      • file 资源是本地计算机上的文件。格式: file:///
      • ...
    • hostname(主机名)
      • 是指存放资源的服务器的域名系统(DNS) 主机名、域名 或 IP 地址。
    • port(端口号)
      • 整数,可选,省略时使用方案的默认端口;
      • 各种传输协议都有默认的端口号,如http的默认端口为80,https端口:443
    • path(路由地址)
      • 由零或多个“/”符号隔开的字符串,一般用来表示主机上的一个目录或文件地址。路由地址决定了服务器端如何处理这个请求
    • query(查询) ?key1=value1&key2=value2
      • 可选,用于给动态网页传递参数,可有多个参数,用“&”符号隔开,每个参数的名和值用“=”符号隔开。
    • fragment(信息片断)
      • 字符串,用于指定网络资源中的片断。例如一个网页中有多个名词解释,可使用fragment直接定位到某一名词解释。
    • 注: [] 代表其中的内容可省略

视图函数(view)

  • 视图函数是用于接收一个浏览器请求并通过HttpResponse对象返回数据的函数。此函数可以接收浏览器请求并根据业务逻辑返回相应的内容给浏览器
  • 视图处理的函数的语法格式:
    python def xxx_view(request[, 其它参数...]): return HttpResponse对象
  • 参数:

    • request用于绑定HttpRequest对象,通过此对象可以获取浏览器的参数和数据
  • 示例:
    • 视图处理函数 views.py
      python # file : <项目名>/views.py from django.http import HttpResponse def page1_view(request): html = "<h1>这是第1个页面</h1>" return HttpResponse(html)

Django 中的路由配置

  • settings.py 中的ROOT_URLCONF 指定了主路由配置列表urlpatterns的文件位置
  • urls.py 主路由配置文件
    python # file : <项目名>/urls.py urlpatterns = [ url(r'^admin/', admin.site.urls), ... # 此处配置主路由 ]

    urlpatterns 是一个路由-视图函数映射关的列表,此列表的映射关系由url函数来确定

  1. url() 函数
    • 用于描述路由与视图函数的对应关系
    • 模块
      • from django.conf.urls import url
    • 语法:
      • url(regex, views, name=None)
      • 参数:
        1. regex: 字符串类型,匹配的请求路径,允许是正则表达式
        2. views: 指定路径所对应的视图处理函数的名称
        3. name: 为地址起别名,在模板中地址反向解析时使用

    每个正则表达式前面的r表示'\'不转义的原始字符串

  • 练习1
    • 建立一个小网站:
      #views.py写入:
      from django.http import HttpResponse
      
      def index(request):
          http='<h1>这是主页</h1>'
          return HttpResponse(http)
      
      def page_view(request):
          http="<h1>这是编号为1页面</h1>"
      
          return HttpResponse(http)
      
      def page2_view(request):
          http='<h1>这是编号为2页面</h1>'
      
          return HttpResponse(http)
      
      #urls.py路由配置:
      urlpatterns = [
          url(r'^admin/', admin.site.urls),
          #请求http://127.0.0.1:8000/page1 :交由views.page_view方法处理
          url(r'^$',views.index),
          url(r'^page1$',views.page_view),
          url(r'^page2$',views.page2_view),
      ]
      

      提示: 主面路由的正则是 r'^$'

      • 思考

        • 建立如上一百个网页该怎么办?
        def pagen_view(request,n):
            html = '<h1>这是编号为%s的网页</h1>'%(n)
            return HttpResponse(html)
        
        #url.py路由配置:
        urlpatterns = [
            url(r'^admin/', admin.site.urls),
            #请求http://127.0.0.1:8000/page1 :交由views.page_view方法处理
            url(r'^page(\d+)',views.pagen_view)
        ]
带有分组的路由和视图函数
def pagens_view(request,m,n,i):
    if n == 'add':
        s=int(m)+int(i)
        html = '<h1>结果:%d</h1>'%s
        return HttpResponse(html)
    if n == 'sub':
        s= int(m) -int(i)
        html = '<h1>结果:%d</h1>'%s
        return HttpResponse(html)
    if n == 'mul':
        s= int(m) * int(i)
        html = '<h1>结果:%d</h1>'%s
        return HttpResponse(html)
    
    
    #urls.py路由配置
    urlpatterns = [
    url(r'^admin/', admin.site.urls),
        
    url(r'^(\d+)/(\w+)/(\d+)',views.pagens_view)

]
带有命名分组的路由和视图函数
  • 在url 的正则表达式中可以使用命名分组(捕获分组)

  • 说明:

    • 在视图函数内,可以用正则表达式分组 (?P<name>pattern) 提取参数后用函数关键字传参传递给视图函数
  • 示例:
    • 路由配置文件
      python # file : <项目名>/urls.py # 以下示例匹配 # http://127.0.0.1:8000/person/weimingze/35 # http://127.0.0.1:8000/person/shibowen/29 # http://127.0.0.1:8000/person/xiaowei/9 urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^person/(?P<name>\w+)/(?P<age>\d{1,2})',views.person_view), ]
  • 练习:
    def birth_day(request,year,month,ri):
        html = year + '年' + month + '月' + ri + '日'
        return HttpResponse(html)
    
    #urls.py路由配置
    urlpatterns = [
        #127.0.0.1:8000/birthday/2019/9/5
        url(r'^birthday/(?P<year>\d{4})/(?P<month>\d{1,2})/(?P<ri>\d{1,2})',views.birth_day),
        #127.0.0.1:8000/birthday/9/5/2019
        url(r'^birthday/(?P<month>\d{1,2})/(?P<ri>\d{1,2})/(?P<year>\d{4})',views.birth_day)
    ]
  • PyCharm 社区版针对Django项目调试方法
    1. 添加自己调式配置
      • 选择 Add Configuration...
    2. 点击 + 号添加一个自己的配置
      • 选择运行的项目的主模块位置 manage.py
      • 添加 runserver 命令行参数

HTTP协议的请求和响应

  • 请求是指浏览器端通过HTTP协议发送给服务器端的数据
  • 响应是指服务器端接收到请求后做相应的处理后再回复给浏览器端的数据

[外链图片转存失败(img-RSTOfJS3-1567767958155)(images/request_response.png)]

HTTP 请求

  • 根据HTTP标准,HTTP请求可以使用多种请求方法。
  • HTTP1.0定义了三种请求方法: GET, POST 和 HEAD方法(最常用)
  • HTTP1.1新增了五种请求方法:OPTIONS, PUT, DELETE, TRACE 和 CONNECT 方法。
  • HTTP1.1 请求详述
    | 序号 | 方法 | 描述 |
    |:-:|:-:|:-|
    | 1 | GET | 请求指定的页面信息,并返回实体主体。 |
    | 2 | HEAD | 类似于get请求,只不过返回的响应中没有具体的内容,用于获取报头 |
    | 3 | POST | 向指定资源提交数据进行处理请求(例如提交表单或者上传文件)。数据被包含在请求体中。POST请求可能会导致新的资源的建立和/或已有资源的修改。 |
    | 4 | PUT | 从客户端向服务器传送的数据取代指定的文档的内容。 |
    | 5 | DELETE | 请求服务器删除指定的页面。 |
    | 6 | CONNECT | HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器。 |
    | 7 | OPTIONS | 允许客户端查看服务器的性能。 |
    | 8 | TRACE | 回显服务器收到的请求,主要用于测试或诊断。 |

  • HttpRequest对象
    • 视图函数的第一个参数是HttpRequest对象
    • 服务器接收到http协议的请求后,会根据请求数据报文创建HttpRequest对象
    • HttpRequest属性
属性描述
path字符串,表示请求路由信息
path_infoURL字符串
method字符串,表示HTTP请求方法,常用值:“GET”,“POST”
encoding字符串,表示提交的数据编码方式.(1,如果为None则表示使用浏览器的默认设置,一般为‘UTF-8’。2,这个属性是可写的可以通过修改它来修改访问表单数据使用的编码,接下来对属性的任何访问将使用新的enncoding值)
GETQueryDict查询字典对象,包含get请求方式的所有数据
POSTQueryDict查询字典的对象,包含post请求方式的所有数据
FILES类似于字典的对象,包含所有上传文件信息
COOKIESPython字典,包含所有的cookie,键和值都为字符串
session类似于字典的对象,表示当前的回话
body字符串,请求体的内容(POST和PUT)
environ字符串,客户端运行的环境变量信息
scheme请求协议('HTTP'/'HTTPS')
request.get_full_path()请求的完整路径
request.get_host()请求的主机
request.META请求中的元数据(消息头)

request.META['REMOTE_ADDR'] :
客户端IP地址

HTTP 响应

  • 当浏览者访问一个网页时,浏览者的浏览器会向网页所在服务器发出请求。当浏览器接收并显示网页前,此网页所在的服务器会返回一个包含HTTP状态码的信息头用以响应浏览器的请求。
  • HTTP状态码的英文为HTTP Status Code。
  • 下面是常见的HTTP状态码:
状态码描述
200请求成功
301资源(网页等)被永久转移到其他URL
404请求的资源(网页等)不存在
500内部服务器错误
  • HTTP状态码分类
    • HTTP状态码由三个十进制数字组成,第一个十进制数字定义了状态码的类型,后两个数字没有分类的作用。HTTP状态码共分为5种类型:

      分类分类描述
      1**信息,服务器收到请求,需要请求者继续执行操作
      2**成功,操作被成功接收并处理
      3**重定向,需要进一步的操作以完成请求
      4**客户端错误,请求包含语法错误或无法完成请求
      5**服务器错误,服务器在处理请求的过程中发生了错误
  • Django中的响应对象HttpResponse:
    • 构造函数格式:

      • HttpResponse(content=响应体, content_type=响应体数据类型, status=状态码)
    • 作用:

      • 向客户端浏览器返回响应,同时携带响应体内容
参数描述
content表示返回的内容
status_code返回的HTTP响应状态码(默认为200)
content_type指定返回数据的的MIME类型(默认为"text/html")。浏览器会根据这个属性,来显示数据。如果是text/html,那么就会解析这个字符串,如果text/plain,那么就会显示一个纯文本。
        - 常用的Content-Type如下:
            - `'text/html'`(默认的,html文件)
            - `'text/plain'`(纯文本)
            - `'text/css'`(css文件)
            - `'text/javascript'`(js文件)
            - `'multipart/form-data'`(文件提交)
            - `'application/json'`(json传输)
        - `'application/xml'`(xml文件)
        > 注: 关键字MIME(Multipurpose Internet Mail Extensions)是指多用途互联网邮件扩展类型。
  • HttpResponse 子类
    | 类型 | 作用 | 状态码 |
    |-|-|-|
    | HttpResponseRedirect | 重定响 | 301 |
    | HttpResponseNotModified | 未修改 | 304 |
    | HttpResponseBadRequest | 错误请求 | 400 |
    | HttpResponseNotFound | 没有对应的资源 | 404 |
    | HttpResponseForbidden | 请求被禁止 | 403 |
    | HttpResponseServerError | 服务器错误 | 500 |

GET方式传参

POST传递参数

  • 客户端通过表单等POST请求将数据传递给服务器端,如:
<form method='post' action="/login">
    姓名:<input type="text" name="username">
    <input type='submit' value='登陆'>
</form>
  • 服务器端接收参数

    • 通过 request.method 来判断是否为POST请求,如:
    if request.method == 'POST':
        处理POST请求的数据并响应
    else:
        处理非POST 请求的响应
  • 使用post方式接收客户端数据

    1. 方法
    request.POST['参数名']  # request.POST 绑定QueryDict
    request.POST.get('参数名','')
    request.POST.getlist('参数名')
  • 取消csrf验证,否则Django将会拒绝客户端发来的POST请求

    • 取消 csrf 验证

      • 删除 settings.py 中 MIDDLEWARE 中的 CsrfViewsMiddleWare 的中间件
      MIDDLEWARE = [
          ...
          # 'django.middleware.csrf.CsrfViewMiddleware',
          ...
      ]

form 表单的name属性

  • 在form表单控件提交数据时,会自动搜索本表单控件内部的子标签的name属性及相应的值,再将这些名字和值以键-值对的形式提交给action指定的服务器相关位置

  • 在form内能自动搜集到的name属性的标签的控件有

    <input name='xxx'>
    <select name='yyy'></select>
    <textarea name='zzz'></textarea>
    • 如:
    <form action="/page1" method="POST">
        <input name="title" type="text" value="请输入">
        <select name="gender">
            <option value=1>男</option>
            <option value=0>女</option>
        </select>
        <textarea name="comment" rows="5" cols="10">附言...</textarea>
        <input type="submit" value="提交">
    </form>

转载于:https://www.cnblogs.com/-xiaolong/p/11477847.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Django基础教程PDF是一本详细讲解Django框架的书籍。Django是一个基于Python的高效Web应用开发框架,使用Django可以快速开发高质量、安全且易维护的Web应用程序。这本书从Django基础概念、安装、配置、模型、视图、模板、表单、认证、管理等方面,详细解释了如何使用Django进行Web应用开发。 其中,书籍的第一部分主要讲解了Django框架的基础知识,包括Django的架构、安装配置、虚拟环境、应用以及包管理等等。第二部分则详细阐述了Django的各种模型,包括Model、QuerySet以及Django ORM的操作等。第三部分则重点讲解了Django的视图,包括视图函数、URL路由以及视图的响应等等。第四部分则阐述了Django的模板系统,包括模板语言、模板渲染以及静态文件等。第五部分讲解了Django的表单系统,包括表单类的定义、视图函数的编写以及表单的提交和验证等。第六部分则深入讲解Django的认证系统、权限管理以及用户注册等内容。最后一部分则介绍了Django的管理后台、中间件、缓存、测试和部署等方面的内容。 总之,Django基础教程PDF对于想要学习并掌握Django框架的开发者来说是一本非常好的入门书籍。它详细介绍了Django框架的整个开发流程,给予开发者夯实的理论基础和实操能力,让开发者能够高效地使用Django框架进行Web应用开发。 ### 回答2: Django是一个高效的Python Web应用程序框架,它的特点是快速开发、可拓展性和丰富的功能性。对于初学者来说,学习Django框架并不是一件容易的事情,因此《Django基础教程》成为了很多开发者必备的学习资料。 《Django基础教程》详细介绍了Django框架的各种概念和操作方法,包括了模型、视图、模板、表单、路由等方面的基础知识。这本教程以实践为主,让读者通过自己手写一个简单的博客系统来获取对Django框架的全面认识。 教程的阅读需要基本的Python编程知识,因为它是使用Python语言编写的。在读完本教程后,读者可以掌握Django框架的开发流程,了解Django的中间件和模型、视图、模板的关系,掌握如何与数据库进行交互以及如何使用Django表单等。 值得一提的是,《Django基础教程》是一本中文教程,将一些比较抽象的概念解释得十分清楚易懂。而且它还针对Django 2.x 版本进行了详细介绍,非常贴近当前开发环境,可以让读者快速开发出一个简单的Web应用程序。 总而言之,《Django基础教程》是一本非常优秀、权威、全面的Django框架学习资料,它的内容详尽,范例丰富,让读者学习起来既轻松而又有深度。对于初学者来说,它是一个不容错过的学习宝典。 ### 回答3: Django是一个流行的Python Web框架,已经成为许多Web应用程序开发人员的首选。有很多教程和资源可用,其中包括Django基础教程,可作为入门学习Django的教材。 这本教程的重点是了解Django基础知识,例如Django框架的架构、模型-视图-控制器(MVC)模式、Django模型和Django视图等。它涵盖了创建新的Django项目,如何在Django项目中创建和管理应用程序,以及如何利用Django模板和表单在网页中呈现和处理数据。 该教程还提供了一些简单的应用程序示例,如博客和投票应用程序,这些教程旨在帮助读者嵌入并了解Django的工作原理。 在学习Django基础教程时,读者将学习如何编写干净、可读、可扩展和可维护的代码。这是应用程序开发中的最佳实践之一,有助于确保应用程序的可靠性。 总之,Django基础教程是入门学习Django框架的好材料,它能够为初学者提供一些基本的理解和编程技能,同时也提供了一些实用而有趣的示例,帮助学习者了解和熟悉Django框架的工作方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值