Django知识点:认识Django

web开发

1.web全球广域网,万维网,给用户提供可视化页面

  • web前端开发:是对页面的开发,为了给用户提供更好的页面
  • web后端开发:给页面提供数据支持,处理用户的请求,处理用户的业务逻辑
    • request:用户发起的请求
    • response:响应,服务器处理,构造的响应
    • url:资源在服务器上的位置
    • 视图views:处理请求的地方,可以是函数,也可以是类方法

2.域名规则
https://www.baidu.com/

  • https 协议 http
  • 域名:代表服务器的根目录
  • 路径
  • 文件名,资源的名称

Django的简介

1.简介
python 框架的一种,完成了对同一类代码的封装

2. 优点
重量级的框架,提供丰富的功能组件,让开发边的简单,快捷,开发效率快

3. 缺点
开发不够灵活,不够自由,不能胜任高度定制开发任务,执行速度相对慢

Django环境的安装

  1. 如何选择虚拟环境
    anaconda:不需要安装python,在创建虚拟环境的时候可以选择python版本。解决包用来关系的问题。(python3.5.2 + django2.2.1 + anaconda)

    • 安装-在命令窗口下执行:
      创建环境:conda create -n 虚拟环境的名字 python=3.5.2
      激活虚拟环境:activate DjangoPath(虚拟环境的名字)
      安装Django:pip install django==2.2.1
      测试django是否安装成功
      进入python环境:python
      导包:import django
      查看django版本号:django.VERSION # 如果出现django的版本信息则说明安装成功
      退出python环境:exit()

    virtualenv:

    安装python
    virtualenvwarpper
    workon 虚拟环境的名字
    makevirtualenv 虚拟环境的名字
    
  2. 创建工程并启动工程

    • 创建一个project 文件夹,打开进入这个文件夹,在目录下执行cmd 进入DOC窗口
    • 激活虚拟环境:activate DjangoPath
    • 创建一个demo的工程:django-admin startproject demo(工程名)
  3. 启动服务

    • 在自己的主机启动
      python manage.py runserver
    • 指定主机和指定端口号
      python manage.py runserver 127.0.0.1:9000
    • 任何主机和端口号都可以访问
      python manage.py runserver 0.0.0.0:8000
      这一步需要修改settings 中的配置信息
    • 启动的服务是使用django自带的一个服务器,轻量,方便使用,最高并发量 200 ,经常用来做开发测试
  4. pycharm 打开项目

    • 第一次打开的工程的时候需要选择编译环境,这里选择Anaconda3
      Anaconda\envs\DjangoPath\python.exe
      在这里插入图片描述
      在这里插入图片描述

    • pycharm启动服务
      在这里插入图片描述

  5. 工程目录介绍
    在这里插入图片描述

    |-Demo     项目工程目录
    	|-Demo    项目的主目录
    		|- __init__.py   项目初始化文件 
    		|- settings.py   项目的配置文件
    		|_ urls.py       项目的路由文件
    		|- wsgi.py       项目的部署服务文件
    	|- db.sqllit3        数据库
    	|- manage.py         项目的管理文件,负责:启动项目,数据迁移
    
  6. 配置文件的介绍,相关配置信息解释已经在注释当中说明

"""
Django settings for Demo project.

Generated by 'django-admin startproject' using Django 2.2.1.

For more information on this file, see
https://docs.djangoproject.com/en/2.2/topics/settings/

For the full list of settings and their values, see
https://docs.djangoproject.com/en/2.2/ref/settings/
"""

import os

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
# 项目的根目录,方便开发人员使用
# os.path.abspath  绝对路径
# os.path.dirname  文件所在目录
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
# print(BASE_DIR)
#

# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/2.2/howto/deployment/checklist/

# SECURITY WARNING: keep the secret key used in production secret!
## 秘钥
# SECRET_KEY = '#0^_--5gljl*@sp!x8grz*whz@@%-rqd!wan8rdzx6_$qx_afk'
SECRET_KEY = 'fdsfds111'

# SECURITY WARNING: don't run with debug turned on in production!
## 调试模式
## True 开启调试模式
## 开启调试模式: 1.更改django代码,自动重启服务   2. 显示错误信息,请求信息
DEBUG = True

# 允许访问的主机
ALLOWED_HOSTS = ['*']


# Application definition
## 注册app的   注册子应用
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
]

## 中间件  中间人
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 = 'Demo.urls'

### 模板的配置
TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

## django内置服务器
WSGI_APPLICATION = 'Demo.wsgi.application'


# Database
# https://docs.djangoproject.com/en/2.2/ref/settings/#databases

## 数据库相关的配置
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}


# Password validation
# https://docs.djangoproject.com/en/2.2/ref/settings/#auth-password-validators

## 权限认证
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',
    },
]


# Internationalization
# https://docs.djangoproject.com/en/2.2/topics/i18n/

## 语言
# LANGUAGE_CODE = 'en-us'
LANGUAGE_CODE = 'zh-hans'
## 时区
# TIME_ZONE = 'UTC'
TIME_ZONE = 'Asia/Shanghai'   ## 上海时区

## 翻译系统 
USE_I18N = True
## 数据本地化配置
USE_L10N = True
## 是否使用指定的时区
## True 使用django 默认时区   内置时区
## Flase 使用指定的时区
USE_TZ = True


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

## 静态文件的配置
STATIC_URL = '/static/'


  1. 全局配置文件的目录
    在这里插入图片描述

设计模式

  1. django是一个MVT设计模式,同时遵循MVC模式
    MVC模块的核心宗旨就是:解耦,模型的复用,让不同的代码之间的耦合度降低,增强代码的扩展性和可移植性还有方便 维护,模型不用关心处理结果展现,比如模型返回一些数据,然后交给不用的视图展现,可以使用不同的视图来访问同一个模型。方便测试, 比如,将业务逻辑代码写在servlet里面,需要部署到容器上,然后才能测试。而将业务逻辑代码写在类里面,可以直接用main()测试(不依赖容器)。
    MVC
    在这里插入图片描述
    • M:全拼为Model(模块),主要封装对数据库层的访问, 数据处理,对数据库中的数据进行增、删、改、查操作。
    • V:全拼为View(视图),界面显示,用于封装结果,生成页面展示的html内容。
    • C:全拼为Controller(控制器),逻辑处理,用于接收请求,处理业务逻辑,与Model和View交互,返回结果。
      MVT
      在这里插入图片描述
    • M:全拼为Model(模块),主要封装对数据库层的访问, 数据处理,对数据库中的数据进行增、删、改、查操作。
    • V:和MVC 的C相似,接收和处理请求,处理业务逻辑,和Model,Views交互,返回结果
    • T:和MVC 中的V相似,界面显示,封装结果,提供html页面支持
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值