视图函数必须返回一个 HttpResponse 对象
def index(request):
print('request')
# return HttpResponse("request") # 它返回的是字符串
# return render(request, 'index.html') # 加载HTML页面的
# return redirect('http://www.baidu.com') # 加载HTML页面的
return redirect('/home/') # 重定向的
LANGUAGE_CODE = 'zh-hans'
TIME_ZONE = 'Asia/Shanghai'
USE_I18N = True
USE_L10N = True
USE_TZ = False
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
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',
]
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'app01.apps.App01Config', # 这是全写
]
我们将html文件默认都放在templates文件夹下
我们将网站所使用的静态文件默认都放在static文件夹下
静态文件:前段已经写好,能直接使用的文件
网站写好的JS文件
网站写好的CSS文件
网站用到的图片文件
第三方框架
...
拿来直接就可以使用的文件
一般情况我们再static文件夹下还会对文件进行划分
在浏览器中输入url能够看到对应的资源
是因为后端提前开设了相关的接口
如果访问不到资源,说明后端没有开设相关资源的端口
STATIC_URL = '/static/' # 类似于访问静态文件的令牌
'''如果想要访问static静态文件,就必须以static开头'''
'''
/static/plugins/Bootstrap/js/bootstrap.js/bootstrap.min.js
/static/ ---- 令牌
允许在以下列表中依次进行查找
如果没有则报错
'''
# 静态文件配置
STATIC_DIRS = [
os.path.join(BASE_DIR, 'static')
]
{% load static %}
STATIC_URL = '/static/' # 类似于访问静态文件的令牌
'''如果想要访问static静态文件,就必须以static开头'''
'''
/static/plugins/Bootstrap/js/bootstrap.js/bootstrap.min.js
/static/ ---- 令牌
允许在以下列表中依次进行查找
如果没有则报错
'''
# 静态文件配置
STATIC_DIRS = [
os.path.join(BASE_DIR, 'static')
]
配置完链接数据的代码之后,Django默认启动不起来了,原因是:内部使用的链接模块用的是mysqldb
我们不使用这个模块,我们使用pymysql模块
如何更换pymysql
在任意的__init__.py文件中添加一下代码
import pymysql
pymysql.install_as_MySQLdb()
orm: 对象映射模型
在Django中操作数据库就不用在写原生的SQL语句,而是使用面向对象的语法和一些方法来操作数据库
缺点:代码的封装程度太高,导致的问题:执行效率下降了,目前可以忽略,需要自己写原生SQL语句
类名 >>> 表名
对象 >>> 一条记录
属性 >>> 一个字段
我们的这些orm在哪里书写呢?
models.py这个文件就是跟数据库打交道的
类名写好之后,一定别忘了做数据库迁移命令
重点:
python38 manage.py makemigrations # 生成迁移的记录(类似以是一个小本本)
python38 manage.py migrate # 这句话才是真正的操作了数据库,然后生成表
当你修改了跟数据量相关的代码之后,都要执行这两句话