【1】三板斧(3个方法)的使用
def index(request): print('request') # return HttpResponse("request") # 它返回的是字符串 # return render(request, 'index.html') # 加载HTML页面的 # return redirect('http://www.baidu.com') # 加载HTML页面的 return redirect('/home/') # 重定向的
【2】settings.py(Django全局配置文件的介绍)
"""
Django settings for myseconddjango project.
Generated by 'django-admin startproject' using Django 2.1.
For more information on this file, see
https://docs.djangoproject.com/en/2.1/topics/settings/
For the full list of settings and their values, see
https://docs.djangoproject.com/en/2.1/ref/settings/
"""
import os
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
#用于绑定项目文件位置的绝对路径,所有文件夹都依赖于此路径(django项目的根路径)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/2.1/howto/deployment/checklist/
# SECURITY WARNING: keep the secret key used in production secret!
# 安全警告:对生产中使用的安全密钥(也可以说是对密码加密使用的盐)
SECRET_KEY = 'rah+wlz=0#)_g=@-n8@gko(0yh*%e1h*1rmr5=!ccpd@df%3oc'
# SECURITY WARNING: don't run with debug turned on in production!
# DEBUG项目的启动模式:
# 1.True:调试模式
# 检测代码改动后,立即重启服务
# 显示报错页面,便于查找错误
# 2.False:正式启动模式或者上线模式
# 不显示错误信息,改为False时,需要指定ALLOWED_HOSTS来过滤一些错误的请求
DEBUG = True
ALLOWED_HOSTS = []
#[]空列表,表示只有请求头中host为127.0.0.1,localhost能访问本项目,-DEBUG=True时有效
#['*'],表示任何请求头的host都能访问当前项目
#['192.168.1.3','127.0.0.1'],表示只有当前两个host的值才能访问当前项目
# Application definition
#注册Django应用
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'app02.apps.App02Config',
]
#注册中间件
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',
]
# 表明Django主路由的位置
ROOT_URLCONF = 'myseconddjango.urls'
# 指定模板配置信息
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR,'templates')]
,
'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',
],
},
},
]
# 正式启动的时候会用
WSGI_APPLICATION = 'myseconddjango.wsgi.application'
# Database
# https://docs.djangoproject.com/en/2.1/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.1/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.1/topics/i18n/
# 语言信息配置
# LANGUAGE_CODE = 'en-us' # 英文
LANGUAGE_CODE='zh-hans' # 中文
# 时区设置
# TIME_ZONE = 'UTC' # 世界标准时区
TIME_ZONE = 'Asia/Shanghai' # 中国时区
USE_I18N = True
USE_L10N = True
USE_TZ = True
# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/2.1/howto/static-files/
# 这个配置是访问静态文件的令牌
STATIC_URL = '/static/'
【3】静态文件的配置
【3.1】 什么是静态文件?
静态文件:能直接拿来使用的都是静态文件
例如:类似HTML文件,类似CSS文件,类似js文件,图片,第三方的前端框架(jQuery,bootstrap等)
静态文件一般写在static文件夹中,但这个文件夹Django项目默认情况下没有,因此我们需要手动创建。静态的HTML文件一般存放在templates文件夹中
【3.2】django地址问题
向django项目中导入static静态文件后,会出现找不到文件地址的情况。
在Django的全局配置文件settings.py中添加一个:
STATICFILES_DIRS = [ os.path.join(BASE_DIR,' static ') ]
【3.3】动态解析
在settings.py这个文件中有:STATIC_URL = ‘ /static/ ‘
STATIC_URL = ‘ /static/ ‘ 是访问静态文件的令牌,没有去访问静态文件必要要有这个令牌,没有这个令牌,直接拒绝访问
{% load static %} <script src="{% static 'js/jquery_3.7.1_jquery.min.js' %}"></script> <link rel="stylesheet" href="{% static 'bootstrap-3.4.1-dist/css/bootstrap.min.css' %}"> <script src="{% static 'bootstrap-3.4.1-dist/js/bootstrap.min.js' %}"></script> ''' {% load static %} ------ load是固定写法,static是令牌 <script src="{% static 'js/jquery_3.7.1_jquery.min.js' %}"></script> static是令牌,后面是文件地址 '''
【4】request对象方法
-
request.method
-
request.POST
-
request.POST.get(‘username‘)
-
request.POST.getlist(‘hobby‘)
-
request.GET
-
request.GET.get(‘a’)
-
request.GET.getlist(‘C’)
【5】django链接数据库
# 数据库配置 DATABASES = { # 'default': { # 'ENGINE': 'django.db.backends.sqlite3', # 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), # } 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'HOST': '127.0.0.1', 'PORT': 3306, 'USER': 'root', 'PASSWORD': '123', 'NAME': 'db1', 'CHARSET': 'UTF8', } }
注意:
配置完链接数据的代码之后,Django默认启动不起来。原因:内部使用的链接模块用的是mysqldb,我们换个模块,使用pymysql模块
import pymysql pymysql.install_as_MySQLdb()
【6】orm介绍
在Django中操作数据库不用写原生的SQL语句,而是使用面向对象的语法和一些方法来操作数据库。
在models.py中写完后,需要在Terminal终端中做数据库迁移命令
python36 manage.py makemigrations # 生成迁移的记录 python36 manage.py migrate # 这句话是真正操作数据库,生成表
原文地址:https://blog.csdn.net/m0_69962105/article/details/134319019
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_32020.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!