[TOC] 靜態文件 預設情況下所有的html文件都是放在templates文件夾內 什麼是靜態文件 網站所使用的提前寫的css、js 第三方的前端模塊、圖片都叫做靜態資源 預設情況下網站使用的靜態資源全部會放到static文件夾下 通常情況下 在static文件夾內部還會再建其他文件夾 這是為了更 ...
目錄
靜態文件
預設情況下所有的html文件都是放在templates文件夾內
什麼是靜態文件
網站所使用的提前寫的css、js 第三方的前端模塊、圖片都叫做靜態資源
預設情況下網站使用的靜態資源全部會放到static文件夾下
通常情況下 在static文件夾內部還會再建其他文件夾 這是為了更加方便地管理文件,在django中 需要你自己手動創建靜態文件存放的文件夾
css 文件夾
js 文件夾
font 文件夾
img 文件夾
Bootstrap
註意點:視圖函數都必須有返回值,並且返回值都是HttpResponse對象
靜態文件的配置
django後端如果想要暴露後端資源,必須去urls裡面開設對應的資源介面
在項目文件夾下settings.py
配置:
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
特點:
- 攜帶的數據不安全
- 攜帶的數據大小有限制
- 通常只會攜帶一些不是很重要的數據
前期在朝後端提交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',
]
request方法初識
在django中後端的視圖函數,無論是發的get請求還是post請求,都會執行視圖函數,預設處理的是get請求。
- get請求指向拿到login頁面
- post請求想提交數據,然後後端做校驗
判斷當前請求方式:
- 利用
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 POSTrequest.POST
獲取用戶提交的post請求數據request.POST.get('username') # 預設只取列表最後一個元素 request.POST.getlist('username') # 獲取列表
request.GET
獲取用戶提交的get請求數據request.GET.get() # 預設只會獲取列表最後一個元素 request.GET.getlist() # 如果你想獲取列表 用getlist()
pycharm連接資料庫
pycharm也可以充當MySQL的客戶端
django連接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'
}
}
- 主動告訴django 不要用預設的mysqldb連接 而是用pymysql
# 你可以在項目名下的__init__.py中書寫
# 也可以在應用名下的__init__.py中書寫
import pymysql
pymysql.install_as_MySQLdb()
django ORM簡介
ORM 對象關係映射
類 | 表 |
---|---|
對象 | 數據 |
對象.屬性 | 欄位對應的值 |
為什麼使用ORM
- 能夠讓不會資料庫操作的人也能夠簡單方便去操作資料庫
缺點:
- 封裝程度太高 有時候會出現查詢效率偏低的問題
django中操作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='[email protected]')
方式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查詢出來的列表中所有的對象全部刪除
"""