小白必会三板斧、静态文件配置、request对象及方法、pycharm和django连接数据库、字段的增删改查和数据的增查

1021 小白必会三板斧、静态文件配置、request对象及方法、pycharm和django连接数据库、字段的增删改查和数据的增查

一、三板斧

用户能够访问到的所有资源吗,都是程序员提前暴露好的,如果没有暴露,用户就永远访问不了

django是可以自动重启的,但是有时候反映速度比较慢,也有可能在你代码没写完的时候重启

三板斧需要导入:from django.shortcuts import render,HttpResponse,redirect

HttpResponse(返回字符串)

render(返回html页面)

redirect(重定向)

二、静态文件配置

静态文件

网站所用到的自己写好的js、自己写好的css、第三方的框架bootstrap、fontawesome、sweetalert

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

STATIC_URL = '/static/' # 是访问静态资源的接口前缀
"""只要你想访问静态资源 你就必须以static开头"""
手动配置静态文件访问资源
STATICFILES_DIRS = [
os.path.join(BASE_DIR,'static'),
os.path.join(BASE_DIR,'static1'),
os.path.join(BASE_DIR,'static2'),
]

接口前缀的动态解析

<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
{#    <link rel="stylesheet" href="/static/bootstrap/css/bootstrap.css">#}
{#    <script src="/static/bootstrap/js/bootstrap.js"></script>#}
{#    这种注释不会在页面显示#}    <!--这种注释会在页面显示-->
{#    静态文件的动态解析#}  
    {% load static %}
    <link rel="stylesheet" href="{% static 'bootstrap/css/bootstrap.min.css' %}">
    <script src="{% static 'bootstrap/js/bootstrap.min.js' %}"></script>
</head>

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

  1. 不写,默认朝当前地址提交
  2. 只写后缀/index/
  3. 写全路径

form表单默认朝后端提交的方式,默认是get请求,可以在class属性的method修改为post,就可以改为post请求。

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

​ url?username=admin&password=213213213213213

​ 缺点:

​ 1.不安全

​ 2.get请求携带的参数有大小限制(最大不能超过4KB左右)

前期如果要提交post请求,得去settings的MIDDLEWARE中注释掉一个中间件

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()

四、pycharm连接数据库和django连接数据库

pycharm连接数据库

点击窗口右侧的database,选择MySQL,选择要连接的库名,输入用户名和密码,点击apply,ok就可以

django连接数据库

第一步:要到settings.py文件中配置,在DATABASES中修改

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',  # 指定数据库 MySQL postgreSQL
        'NAME': 'getdb',  # 到底使用哪个库
        '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注意事项:

1、django的orm不会自动帮你创建库,库需要自己手动创建;但是表会自动帮你创建,只需要书写符合django的orm语法的代码即可。

去应用下所在的models.py中书写类来创建表

class Userinfo(models.Model):
    # 设置id字段为userinfo表的主键  id int primary key auto_increment
    id = models.AutoField(primary_key=True)  # 在django中,可以不指定主键字段,django orm会自动创建
    # 设置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 # 不会创建表,仅仅是生成一个记录,将你当前的操作记录到一个小本本上(migrations文件夹)

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

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

字段的增删改查和数据的增和查

字段的增删改查

增:

class Userinfo(models.Model):
    # 设置id字段为userinfo表的主键  id int primary key auto_increment
    id = models.AutoField(primary_key=True)  # 在django中,可以不指定主键字段,django orm会自动创建
    # 设置username字段,相当于username varchar(64),CharField必须要指定max_length参数
    username = models.CharField(max_length=64)  # 在django orm中没有char字段,但是django暴露给用户,可以自定义char字段
    # 设置password字段,相当于password int
    password = models.IntegerField()
    phone = models.BigIntegerField(default=110)  # 新增的字段,可以提前设置默认值
    addr = models.CharField(max_length=64, null=True)  # 新增的字段可以设置为空

改:改了字段后一定要执行数据库迁移的两条命令

删:注释掉要删的字段的代码,然后执行数据库迁移命令,但是这个千万不要去删

数据的增和查

查:

def login(request):
    if request.method == 'POST':
        username = request.POST.get("username")
        password = request.POST.get("password")
        # 先以用户名为依据查询数据
        # 1.get()  当查询条件不存在的时候 会直接报错   如果存在会直接给你返回 数据对象本身        不推荐使用
        # res = models.Userinfo.objects.get(username=username)  # select id,username,password from userinfo where username='jason'
        # print(res)
        # print(res.username)
        # print(res.password)
        # 2.filter()   当查询条件不存在的时候  不会报错而是返回一个空
        # 当条件存在的情况下 无论数据有几条返回的都是列表套对象的数据格式
        # filter可以当多个查询条件 并且是and关系
        res = models.Userinfo.objects.filter(username=username)  # select * from userinfo where username='jason' and password=123;
        # user_obj = res[0]
        # user_obj = res[0:3]
        # user_obj = res[-1]  # 你可以将filter查询出来的结果当做列表去对待 支持正数的索引取值和切片 不支持负数
        user_obj = res.first()  # 取queryset第一个元素
        print(user_obj)
    return render(request,'login.html')

增:

def reg(request):
    if request.method == 'POST':
        username = request.POST.get("username")
        password = request.POST.get("password")
        # 直接将用户名和密码写入数据库
        user_obj = models.Userinfo.objects.create(username=username,password=password)
        # 相当于insert into userinfo(username,password) values('admin','666');
        # create方法会有一个返回值  返回值就是当前被创建的数据对象
        print(user_obj)
    return render(request,'register.html')
原文地址:https://www.cnblogs.com/zhuangyl23/p/11716993.html