• Day 46 Django_wsgirei模块&Django安装


    web框架

    Web框架(Web framework)是一种开发框架,用来支持动态网站、网络应用和网络服务的开发。这大多数的web框架提供了一套开发和部署网站的方式,也为web行为提供了一套通用的方法。web框架已经实现了很多功能,开发人员使用框架提供的方法并且完成自己的业务逻辑,就能快速开发web应用了。浏览器和服务器的是基于HTTP协议进行通信的。也可以说web框架就是在以上十几行代码基础张扩展出来的,有很多简单方便使用的方法,大大提高了开发的效率。

    wsgiref模块

    最简单的Web应用就是先把HTML用文件保存好,用一个现成的HTTP服务器软件,接收用户请求,从文件中读取HTML,返回。

    如果要动态生成HTML,就需要把上述步骤自己来实现。不过,接受HTTP请求、解析HTTP请求、发送HTTP响应都是苦力活,如果我们自己来写这些底层代码,还没开始写动态HTML呢,就得花个把月去读HTTP规范。

    正确的做法是底层代码由专门的服务器软件实现,我们用Python专注于生成HTML文档。因为我们不希望接触到TCP连接、HTTP原始请求和响应格式,所以,需要一个统一的接口协议来实现这样的服务器软件,让我们专心用Python编写Web业务。这个接口就是WSGI:Web Server Gateway Interface。而wsgiref模块就是python基于wsgi协议开发的服务模块。

    本质上讲,这个文件就可以称为一个web框架。

    from wsgiref.simple_server import make_server
    
    def wsg_server(environ,start_response):
        # 按照 http 协议解析数据:environ
        # 按照 http 协议组装数据:start_response
        start_response('200 OK',[('cooker','123131')])
        path = environ.get('PATH_INFO')
        if path == '/index':
            with open('index.html','r') as f:
                data = f.read()
        elif path == '/socket':
            with open('socket.html','r')as f:
                data = f.read()
        else:
            with open('./pic/jingdon.ico', 'rb') as f:
                data = f.read()
            return [data]
        return [data.encode('utf-8')]
    
    # 封装socket
    h5 = make_server('127.0.0.1',8080,wsg_server)
    
    # 等待用户连接:conn,addr = sock.accept()
    h5.serve_forever()

    Django模板安装

    MVC与MTV模型

    MVC
    Web服务器开发领域里著名的MVC模式,所谓MVC就是把Web应用分为模型(M),控制器(C)和视图(V)三层,他们之间以一种插件式的、松耦合的方式连接在一起,模型负责业务对象与数据库的映射(ORM),视图负责与用户的交互(页面),控制器接受用户的输入调用模型和视图完成用户的请求,其示意图如下所示:

    MTV
    Django的MTV模式本质上和MVC是一样的,也是为了各组件间保持松耦合关系,只是定义上有些许不同,Django的MTV分别是值:

    1. M 代表模型(Model): 负责业务对象和数据库的关系映射(ORM)。
    2. T 代表模板 (Template):负责如何把页面展示给用户(html)。
    3. V 代表视图(View): 负责业务逻辑,并在适当时候调用Model和Template。
      除了以上三层之外,还需要一个URL分发器,它的作用是将一个个URL的页面请求分发给不同的View处理,View再调用相应的Model和Template,MTV的响应模式如下所示:

    一般是用户通过浏览器向我们的服务器发起一个请求(request),这个请求回去访问视图函数,(如果不涉及到数据调用,那么这个时候视图函数返回一个模板也就是一个网页给用户),视图函数调用模型,模型去数据库查找数据,然后逐级返回,视图函数把返回的数据填充到模板中空格中,最后返回网页给用户。

    Django的下载与基本命令

    1、下载Django:pip install django

    2、创建一个django project:django-admin startproject mysite

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

    manage.py ----- Django项目里面的工具,通过它可以调用django shell和数据库等。
    settings.py ---- 包含了项目的默认设置,包括数据库信息,调试标志以及其他一些工作的变量。
    urls.py ----- 负责把URL模式映射到应用程序。

    3、在mysite目录下创建应用

    python manage.py startapp blog
    

    4、启动django项目

    python manage.py runserver 8080
    

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

    基于Django实现的一个简单示例

    url控制器

    from django.contrib import admin
    from django.urls import path
    
    from app1 import views
    urlpatterns = [
        path('admin/', admin.site.urls),
        path('login/', views.login),
    ]

    视图

    from django.shortcuts import render
    
    # Create your views here.
    import datetime
    
    
    def login(request):
        now = datetime.datetime.now()
        ctime = now.strftime("%Y-%m%d %X")
        return render(request, "login.html", {"data": ctime})

    模板

    <!DOCTYPE html>
    <html lang="en">
    <script src="/static/jquery-3.4.1.js"></script>
    # <script src="/static/jquery-3.4.1.js"></script>
    # <link rel="stylesheet" href="/static/app1_css/login.css">
    <head>
        <meta charset="UTF-8">
        <title>login</title>
    </head>
    <style type="text/css">
        h3{
            color:dodgerblue;
        }
    </style>
    <body>
        <h3>当前时间:{{ data }}</h3>
        账号 <input type="text">
        密码 <input type="password">
    
    </body>
    <script>
        $("h3").click(function () {
            $(this).css("color","red")
        })
    </script>
    </html>

    配置文件 settings.py

    STATIC_URL = '/static/'
    
    STATICFILES_DIRS =[
        os.path.join(BASE_DIR,'static')
    ]
  • 相关阅读:
    Debugging Kafka connect
    android O 蓝牙设备默认名称更改
    qualcomm sdm450 tinymix mic record
    QACT 在线调试 Android O
    Android O seLinux 编译错误
    Android seLinux 设置
    高通 fastboot 显示
    高通 双MIC 设置
    高通 添加 cmdline
    高通 mixer_paths.xml 音频配置文件 初始化过程
  • 原文地址:https://www.cnblogs.com/ysging/p/12670655.html
Copyright © 2020-2023  润新知