目录css
默认状况下全部的html文件都是放在templates文件夹内html
网站所使用的提早写的css、js 第三方的前端模块、图片都叫作静态资源前端
默认状况下网站使用的静态资源所有会放到static文件夹下python
一般状况下 在static文件夹内部还会再建其余文件夹 这是为了更加方便地管理文件,在django中 须要你本身手动建立静态文件存放的文件夹mysql
css 文件夹 js 文件夹 font 文件夹 img 文件夹 Bootstrap
注意点:视图函数都必须有返回值,而且返回值都是HttpResponse对象sql
django后端若是想要暴露后端资源,必须去urls里面开设对应的资源接口数据库
在项目文件夹下settings.py
配置:django
STATIC_URL = '/static/' # 访问静态文件资源接口前缀 # 手动开设静态文件访问资源 STATICFILES_DIRS = [ # 静态资源所在的文件所i在文件夹路径 os.path.join(BASE_DIR, 'static'), # 将static里面的全部资源暴露给用户 os.path.join(BASE_DIR, 'static1') # static找不到会往下找,逐层找 ]
{% 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请求,get请求也可以携带参数
格式:http://127.0.0.1:8000/login/?username=cwz&password=123
bootstrap
特色:后端
前期在朝后端提交post请求出现403的状况,须要在配置文件中注释掉一行内容:
'django.middleware.csrf.CsrfViewMiddleware',
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', ]
在django中后端的视图函数,不管是发的get请求仍是post请求,都会执行视图函数,默认处理的是get请求。
判断当前请求方式:
request.method
拿到的字符串大写的请求方式def login(request): # print('哈哈哈') # print(request.method) # print(type(request.method)) if request.method == 'POST': return HttpResponse('收到了') return render(request, 'login.html')
request.method
获取请求方式,获得纯大写的字符串 GET POST
request.POST
获取用户提交的post请求数据
request.POST.get('username') # 默认只取列表最后一个元素 request.POST.getlist('username') # 获取列表
request.GET
获取用户提交的get请求数据
request.GET.get() # 默认只会获取列表最后一个元素 request.GET.getlist() # 若是你想获取列表 用getlist()
pycharm也能够充当MySQL的客户端
django默认的数据库是sqlite3,咱们改成MySQL,须要两步操做
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', # 指定数据库 'NAME': 'test', # 指定库的名字 'HOST': '127.0.0.1', # 要注意键必须大写 'PORT': 3306, 'USER': 'root', 'PASSWORD': '123', 'CHARSET': 'utf8' } }
# 你能够在项目名下的__init__.py中书写 # 也能够在应用名下的__init__.py中书写 import pymysql pymysql.install_as_MySQLdb()
类 | 表 |
---|---|
对象 | 数据 |
对象.属性 | 字段对应的值 |
为何使用ORM
缺点:
去应用下的models.py中写数据模型类
class User(models.Model): # id = models.AutoField(primary_key=True) # django当你不指定主键的时候,会自动帮你建立一个名为id字段,并做为主键 # 若是你本身指定了主键 django就不会再帮你建立 # 对应的是varchar(32) django中默认没有char字段,但支持用户自定义 username = models.CharField(max_length=32) password = models.IntegerField()
python manage.py makemigrations
将数据库的修改 记录到小本本上(migrations文件夹内)python manage.py migrate
将修改操做真正的同步到数据库中注意:
- 上面两条命令必须是成双成对出现
- 只要修改了models里面跟数据库相关的代码 你就必须从新执行上面两条命令
直接修改代码 而后执行数据库迁移命令便可
新增字段,
方式1 设置默认值
email = models.EmailField(default='123@qq.com')
方式2 容许字段为空
phone = models.BigIntegerField(null=True)
方式3 直接在提示中给默认值
直接注释掉对应的字段,而后执行数据库迁移命令(谨慎使用)
data = models.User.objects.filter(username=username) # <QuerySet [<User: User object>]> # 至关于 select * from user where username='neo' """ filter返回的结果是一个"列表",里面才是真正数据对象 filer括号内能够放多个关键字参数 这多个关键字参数在查询的时候 是and关系 """ user_list = models.User.objects.all() """ 结果是一个"列表",里面是一个个的数据对象 """
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查询出来的列表中全部的对象所有删除 """