小白必会三板斧、静态文件配置、request对象及方法、pycharm和django连接数据库、字段的增删改查和数据的增查 1021 小白必会三板斧、静态文件配置、request对象及方法、pycharm和django连接数据库、字段的增删改查和数据的增查 一、三板斧 二、静态文件配置 三、request对象及方法 四、pycharm连接数据库和django连接数据库 五、django orm简介 字段的增删改查和数据的增和查
一、三板斧
用户能够访问到的所有资源吗,都是程序员提前暴露好的,如果没有暴露,用户就永远访问不了
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参数可以写的形式
- 不写,默认朝当前地址提交
- 只写后缀/index/
- 写全路径
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')