默認狀況下全部html文件都是放在templates文件夾內css
什麼是靜態文件:網站所使用到的提早寫的CSS、js、 第三方的前端模塊 圖片 都叫靜態資源html
默認狀況下網站所用到的靜態文件資源所有會放在static文件夾下前端
STATIC_URL = '/static/' #訪問靜態文件資源接口前綴 一般狀況下接口前綴的名字也叫staticpython
手動開設靜態文件訪問資源mysql
STATIC_URL = '/static/' # 訪問靜態文件資源接口前綴 一般狀況下接口前綴的名字也叫static # 手動開設靜態文件訪問資源 STATICFILES_DIRS = [ # 靜態資源所在的文件夾路徑 os.path.join(BASE_DIR,'static'), # 將static文件裏面全部的資源暴露給用戶 os.path.join(BASE_DIR,'static1'), # 將static文件裏面全部的資源暴露給用戶 # os.path.join(BASE_DIR,'static2'), # 將static文件裏面全部的資源暴露給用戶 ]
靜態文件動態綁定(****)sql
{% 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請求數據庫
http://127.0.0.1:8000/login/?username=jason&password=jason123 特色:url?xxx=xxx&yyy=yyy
1.攜帶的數據不安全django
2.攜帶的數據大小有限制bootstrap
3.一般只會攜帶一些不是很重要的數據後端
action
1.不寫 默認朝當前地址提交
2.只寫後綴/index
3.寫全路徑
# 中間件 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', ]
不管是發get請求仍是post請求 都會執行視圖函數
def login(request): print('來啦 老弟~') return render(request,'login.html')
get請求只想拿到login頁面
post請求想提交數據 而後後端作校驗
request.method 拿到的是字符串大寫的請求方式 GET POST def login(request): # if request.method == 'GET': # print('來啦 老弟~') # print(request.method,type(request.method)) # 獲取前端請求方式 # return render(request,'login.html') # elif request.method == 'POST': # print('post業務邏輯') # return HttpResponse('收到了') if request.method == "POST": return HttpResponse('收到了') return render(request,'login.html')
request.method 獲取請求方式 而且純大寫的字符串 request.POST 獲取用戶提交的post請求數據 如何獲取用戶數據(******) request.POST.get() # 默認只會獲取列表最後一個元素 request.POST.getlist() # 若是你想獲取列表 用getlist() request.GET 獲取用戶提交的get請求數據 如何獲取用戶數據(******) request.GET.get() # 默認只會獲取列表最後一個元素 request.GET.getlist() # 若是你想獲取列表 用getlist()
django鏈接MySQL
必需要有兩部操做 1.配置文件配置 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', # 指定數據庫類型 'NAME': 'day49', # 指定庫的名字 'USER':'root', # 注意 鍵必須是全大寫 'PASSWORD':'123qwe', 'HOST':'127.0.0.1', 'PORT':3306, 'CHARSET':'utf8' } } 2.主動告訴django 不要用默認的mysqldb鏈接 而是用pymysql 你能夠在項目名下的__init__.py中書寫 也能夠在應用名下的__init__.py中書寫 import pymysql pymysql.install_as_MySQLdb()
django orm簡介
爲何使用orm
orm的缺點
django中如何操做orm
書寫模型類
去應用下的model.py中書寫模型類
以後在寫django項目的時候 一個django就對應一個數據庫
不要出現多個項目使用同一個數據的狀況
1.python3 manage.py makemigrations # 將數據庫的修改 記錄到小本本上(migrations文件內) 2.python3 manage.py migrate # 將修改操做真正的同步到數據庫中 上面兩條命令必須是成雙成對出現 只要修改了models裏面跟數據庫相關的代碼 你就必須從新執行上面兩條命令 ***************************
# 方式1 設置默認值 email = models.EmailField(default='123@qq.com') # varchar # 方式2 容許字段爲空 phone = models.BigIntegerField(null=True) # 直接在提示中給默認值 gender = models.CharField(max_length=32)
查 data = models.User.objects.filter(username=username) # <QuerySet [<User: User object>]> """ filter返回的結果是一個"列表",裏面纔是真正數據對象 filer括號內能夠放多個關鍵字參數 這多個關鍵字參數在查詢的時候 是and關係 """ user_list = models.User.objects.all() # models.User.objects.filter() """ 結果是一個"列表" 裏面是一個個的數據對象 """ 增 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查詢出來的列表中全部的對象所有刪除 """