默认状况下全部html文件都是放在templates文件夹内css
什么是静态文件:网站所使用到的提早写的CSS、js、 第三方的前端模块 图片 都叫静态资源html
默认状况下网站所用到的静态文件资源所有会放在static文件夹下前端
STATIC_URL = '/static/' #访问静态文件资源接口前缀 一般状况下接口前缀的名字也叫staticpython
手动开设静态文件访问资源mysql
STATIC_URL = '/static/' # 访问静态文件资源接口前缀 一般状况下接口前缀的名字也叫static # 手动开设静态文件访问资源 STATICFILES_DIRS = [ # 静态资源所在的文件夹路径 os.path.join(BASE_DIR,'static'), # 将static文件里面全部的资源暴露给用户 os.path.join(BASE_DIR,'static1'), # 将static文件里面全部的资源暴露给用户 # os.path.join(BASE_DIR,'static2'), # 将static文件里面全部的资源暴露给用户 ]
静态文件动态绑定(****)sql
{% load static %} <link rel="stylesheet" href="{% static 'bootstrap-3.3.7-dist/css/bootstrap.min.css' %}"> <script src="{% static 'bootstrap-3.3.7-dist/js/bootstrap.min.js' %}"></script>
form表单默认朝后端发的是get请求数据库
http://127.0.0.1:8000/login/?username=jason&password=jason123 特色:url?xxx=xxx&yyy=yyy
1.携带的数据不安全django
2.携带的数据大小有限制bootstrap
3.一般只会携带一些不是很重要的数据后端
action
1.不写 默认朝当前地址提交
2.只写后缀/index
3.写全路径
# 中间件 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', ]
不管是发get请求仍是post请求 都会执行视图函数
def login(request): print('来啦 老弟~') return render(request,'login.html')
get请求只想拿到login页面
post请求想提交数据 而后后端作校验
request.method 拿到的是字符串大写的请求方式 GET POST def login(request): # if request.method == 'GET': # print('来啦 老弟~') # print(request.method,type(request.method)) # 获取前端请求方式 # return render(request,'login.html') # elif request.method == 'POST': # print('post业务逻辑') # return HttpResponse('收到了') if request.method == "POST": return HttpResponse('收到了') return render(request,'login.html')
request.method 获取请求方式 而且纯大写的字符串 request.POST 获取用户提交的post请求数据 如何获取用户数据(******) request.POST.get() # 默认只会获取列表最后一个元素 request.POST.getlist() # 若是你想获取列表 用getlist() request.GET 获取用户提交的get请求数据 如何获取用户数据(******) request.GET.get() # 默认只会获取列表最后一个元素 request.GET.getlist() # 若是你想获取列表 用getlist()
django链接MySQL
必需要有两部操做 1.配置文件配置 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', # 指定数据库类型 'NAME': 'day49', # 指定库的名字 'USER':'root', # 注意 键必须是全大写 'PASSWORD':'123qwe', 'HOST':'127.0.0.1', 'PORT':3306, 'CHARSET':'utf8' } } 2.主动告诉django 不要用默认的mysqldb链接 而是用pymysql 你能够在项目名下的__init__.py中书写 也能够在应用名下的__init__.py中书写 import pymysql pymysql.install_as_MySQLdb()
django orm简介
为何使用orm
orm的缺点
django中如何操做orm
书写模型类
去应用下的model.py中书写模型类
以后在写django项目的时候 一个django就对应一个数据库
不要出现多个项目使用同一个数据的状况
1.python3 manage.py makemigrations # 将数据库的修改 记录到小本本上(migrations文件内) 2.python3 manage.py migrate # 将修改操做真正的同步到数据库中 上面两条命令必须是成双成对出现 只要修改了models里面跟数据库相关的代码 你就必须从新执行上面两条命令 ***************************
# 方式1 设置默认值 email = models.EmailField(default='123@qq.com') # varchar # 方式2 容许字段为空 phone = models.BigIntegerField(null=True) # 直接在提示中给默认值 gender = models.CharField(max_length=32)
查 data = models.User.objects.filter(username=username) # <QuerySet [<User: User object>]> """ filter返回的结果是一个"列表",里面才是真正数据对象 filer括号内能够放多个关键字参数 这多个关键字参数在查询的时候 是and关系 """ user_list = models.User.objects.all() # models.User.objects.filter() """ 结果是一个"列表" 里面是一个个的数据对象 """ 增 user_obj = models.User.objects.create(username=username,password=password) print(user_obj,user_obj.username,user_obj.password) # create方法会有一个返回值 返回值就是当前被建立的对象自己 改 models.User.objects.filter(id=edit_id).update(username=username,password=password) """ 批量操做 会将filter查询出来的列表中全部的对象所有更新 """ 删(通常状况下不会使用) models.User.objects.filter(id=delete_id).delete() """ 批量操做 会将filter查询出来的列表中全部的对象所有删除 """