zoukankan      html  css  js  c++  java
  • Djang原理

    Django简介

      Django是一个使用python语言编写的web开发框架。Django是MVC模式的框架,由于一些用法,也通常被认为是MTV模式。

      MVC模型: 即 model(M)、view(V)、control(C)。model即数据库模型,对数据库表结构的定义;view即视图逻辑程序;control即控制器,根据用户的输入的URL来指定将调用的视图。由于control的部分由框架自行处理,因此也会被认为是MTV模式。

      MTV模型: 即 model(M)、template(T)、view(V)。其中template即HTML模板,页面展示的HTML代码。

      当用户输入一个URL即网址时,该URL找到相应的视图,执行视图的某部分,如需查询数据库,则会使用数据库模型获取数据,在视图程序中通过指定的HTML文件,以页面的形式显示给用户。

    Django流程图

    用户通过浏览器请求一个页面
    
    请求到达Request Middlewares中间件,中间件对request做一些预处理或者直接response请求
    
    URLConf通过urls.py文件和请求的URL找到相应的View
    
    View Middlewares被访问,它同样可以对request做一些处理或者直接返回response
    
    调用View中的函数
    
    View中的方法可以选择性的通过Models访问底层的数据
    
    所有的Model-to-DB的交互都是通过manager完成的
    
    如果需要,Views可以使用一个特殊的Context
    
    Context被传给Template用来生成页面
    
    Template使用Filters和Tags去渲染输出
    
    输出被返回到View
    
    HTTPResponse被发送到Response Middlewares
    
    任何Response Middlewares都可以丰富response或者返回一个完全不同的response
    
    Response返回到浏览器,呈现给用户

    文件目录解释

    	在将Django安装完之后,创建一个项目mysite,使用命令:django-admin.py startproject mysite,此时会在当前的目录下自动创建一些目录和文件,以最外层的mysite 为基本目录(/……/mysite)。
    	在base_dir下(/……/mysite/):
    	manage.py        # 自动创建的
    	mysite               # 自动创建的
    	TestModel         # 执行 python manage.py startapp TestModel ,创建一个app,存放数据库模型,这里计划存放test库的表模型
    	templates          # 手动创建,计划存放HTML模板
    	在/……/mysite/mysite/:
    
    	__init__.py           # 让python把它该目录当做一个开发包所需要的文件,即当做一组模块
    	settings.py          # 项目的配置文件,其中有一些项目的基本设置
    	urls.py                 # URL和视图函数的映射文件
    	wsgi.py                # web服务器网关接口配置文件
    	forms.py              # 手动创建的,利用Django.forms,创建HTML表单模型,由Django系统检查错误,便于简化视图函数和HTML代码的简化
    	hello_email.py     # 手动创建的视图函数,执行一些逻辑操作
    	在/……/mysite/TestModel/:
    
    	admin.py              # 启用该文件,将表模型导入,可以使用Django自带的admin页面操作这些表
    	apps.py                # 存放app信息
    	models.py            # 定义表的模型(和表的数据结构相似)
    

    settings.py介绍

      包含了对整个项目的基本配置,如以后需要增加一些配置也可以在该文件添加,比如相关发送邮件的配置等。

    	# 定义了基本目录,当在视图中导入某些文件的函数或类时需要注意它
    	BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
    
    	# 允许哪些地址访问web服务器,‘*’允许任何地址访问
    	ALLOWED_HOSTS = ['*']
    
    	# 创建数据库模型(TestModel)时,需要在这里添加一下才可以识别到
    	INSTALLED_APPS = [
    		'django.contrib.admin',
    		'django.contrib.auth',
    		'django.contrib.contenttypes',
    		'django.contrib.sessions',
    		'django.contrib.messages',
    		'django.contrib.staticfiles',
    		'TestModel',   
    	]
    
    	# 指定了url配置文件的位置(.../mysite/mysite/urls.py)
    	ROOT_URLCONF = 'mysite.urls'
    
    	# 在要创建HTML模板文件时,将存放HTML模本的目录添加到这里
    	TEMPLATES = [
    		{
    			'BACKEND': 'django.template.backends.django.DjangoTemplates',
    			'DIRS': [BASE_DIR+"/templates",],
    			'APP_DIRS': True,
    		}
    
    	# 在创建一个APP时,需要添加数据库的信息,才可以使用数据库模型
    	DATABASES = {
    		'default': {
    			'ENGINE': 'django.db.backends.mysql',      # 使用是哪种数据库
    			'NAME': 'test',                            # 使用的哪个库
    			'USER': 'guotest',                         # 使用哪个用户登录数据库
    			'PASSWORD': 'guotest',                     # 数据库的密码
    			'HOST': '',                                # 指定数据库的host
    			'PORT': '3306',                            # 数据库的端口
    		}
    	}  

    urls.py介绍

      包含了URL 与 视图函数 的映射关系。

    from django.contrib import admin
    from django.conf.urls import *
    from mysite import hello_email
    from mysite import insert_post 
    
    urlpatterns = [
        url(r'^admin/$', admin.site.urls),                 
        url(r'^hello-email/$',hello_email.HelloEmail),
        url(r'^hello-email/success/$',hello_email.success),
        url(r'^insert/$',insert_post.insert),
        url(r'^insert/success/$',insert_post.success),
    ]
    比如:url(r'^hello-email/$',hello_email.HelloEmail) ,第一项是对URL的设定,支持正则表达式,第二项是URL对应的视图函数,即在浏览器打开http://域名或IP:端口号/hello-email/ 会使用视图hello_email.HelloEmail。

    models.py介绍

      存放了数据库中表模型。

    # -*- coding: utf-8 -*-
    from __future__ import unicode_literals
    
    from django.db import models
    
    class User(models.Model):
        class Meta:
            db_table = 'user'                            # 表名:user
        first_name = models.CharField(max_length=30)     # 表字段:first_name
        last_name = models.CharField(max_length=40)
        email = models.EmailField()
    
        def __unicode__(self):
            return u'first_name:%s last_name:%s email:%s' %(self.first_name,self.last_name,self.email) 

    工作原理

    从页面获取URL;
    从settings.py中找到的urls.py的位置;
    从urls.py中搜索到/hello-email/对应的视图hello_email.HelloEmail;
    执行该视图hello_email.HelloEmail,将URL信息传给函数HelloEmail的request对象;
    在视图中如需数据库里的数据,根据models.py,从数据库里获取数据,然后将数据返回给视图;
    经过视图函数HelloEmail的一系列操作,会将 要显示的数据返回给模板templates中的HTML文件;
    最后,用户会看到返回的页面,页面中包含了用户需要的数据。
    以上是大致的工作原理。
    

      

  • 相关阅读:
    pyinstaller 打包后无法运行
    Android Uiautomator2 gradlew 坑
    JNDI 在 J2EE 中的角色
    23种设计模式
    Struts2工作原理
    SpringMVC工作原理
    堆内存设置
    安装和使用 memcached
    SQL面试题及答案
    30多条mysql数据库优化方法,千万级数据库记录查询轻松解决
  • 原文地址:https://www.cnblogs.com/sshcy/p/8980209.html
Copyright © 2011-2022 走看看