Django-1

Django-1

静态文件配置

静态文件:指网站所用到的,如js/css/第三方框架......

​ 通常情况下,网站所用到的静态文件资源,统一都放到static文件夹下

STATIC_URL = '/static/':是访问静态资源的接口前缀

只要你想访问静态资源,你就必须以static开头

# 手动配置静态文件访问资源
STATICFILES_DIRS = [
        os.path.join(BASE_DIR,'static'),
        os.path.join(BASE_DIR,'static1'),
    ]
# 接口前缀 动态解析
    {% load static %}
    <link rel="stylesheet" href="{% static 'bootstrap/css/bootstrap.min.css' %}">
    <script src="{% static 'bootstrap/js/bootstrap.min.js' %}"></script>

form表单

form表单 action参数可以写的形式

  • 不写,默认朝当前地址提交
  • 只写后缀/login/
  • 写全路径

form表单默认朝后端提交数据的方式是:get请求

  • get请求携带参数的方式,是在url后面

    如:url?username=admin&password=213213213213213

  • 缺点

    • 不安全,如密码等参数全暴露在地址栏里
    • 携带参数的大小有限制,2083个字符

如果要提交post请求,需要在settings中注释掉一个中间件

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',
        ]

request对象及方法

如何获取请求方式

request.method

获取post请求携带的数据

request.POST

获取get请求携带的数据

request.GET

get和post在后端获取用户数据的时候,规律是一样的

<QueryDict: {'username': ['admin', 'tank'], 'password': ['123']}>
tank <class 'str'>
123 <class 'str'>
request.POST.get('username') 默认只取列列表的最后一个元素
如果你想将列表完整的取出 你必须用getlist()

Django连接数据库

第一步配置文件

DATABASES = {
    'default': {
    'ENGINE': 'django.db.backends.mysql',  # 指定数据库 MySQL postgreSQL
    'NAME': 'day56',  # 到底使用哪个库
    'USER':'root',
    'PASSWORD':'root',
    'HOST':'127.0.0.1', 
    'PORT':3306,
    CHARSET':'utf8'
	}
}

第二步更换数据库连接模块

django默认使用的是mysqldb连接数据库  但是该模块不支持了
所以你要告诉django不要用mysqldb该用pymysql连接
你可以在项目名下面的__init__.py也可以在应用名下面的__init__.py文件中指定
import pymysql
pymysql.install_as_MySQLdb()

Django orm 简介

orm:对象关系映射

面向对象 数据库
对象 表的记录
对象获取属性 记录的某个字段对应的值
  • 优点:去除了繁琐的sql语句,只需会面向对象即可简单快捷的操作数据库
  • 缺点:由于封装程度太高,可能会导致程序的执行效率偏低

注意事项:

​ django的orm不会自动帮你创建数据库,需要手动创建

orm的运用

第一步:

在应用下所在的models.py中写类:

from django.db import models

# Create your models here.
class Userinfo(models.Model):
    # 设置id字段为userinfo表的主键  id int primary key auto_increment
    id = models.AutoField(primary_key=True)  # 在django中 你可以不指定主键字段 django orm会自动给你当前表新建一个名为id的主键字段
    # 设置username字段  username varchar(64)  CharField必须要指定max_length参数
    username = models.CharField(max_length=64)  # 在django orm中 没有char字段  但是django 暴露给用户 可以自定义char字段
    # 设置password字段  password int
    password = models.IntegerField()

第二步:

数据库迁移命令:

python manage.py makemigrations 不会创建表,仅仅是生产一个记录,将你当前的操作做记录

python manage.py migrate 将你的orm语句真正迁移到数据库中

只要你在models.py中修改了与数据库相关的代码,你就必须重新开始执行上面两条命令

posted @ 2019-10-21 22:33  SweetJack  阅读(130)  评论(0编辑  收藏  举报