利用django和mysql實現一個簡單的web登錄頁面
前言:
本文從0到1實現django搭建一個web頁面,實現瞭django連接mysql數據庫,簡單的get、post請求等
一、使用pyacharm創建一個django項目
略,專業版直接創建即可
這是初始化創建的第三方庫
二、啟動django項目驗證
pycharm的terminal輸入
python manage.py runserver
訪問:
小插曲:在啟動的時候報錯:‘DIRS’: [os.path.join(BASE_DIR, ‘templates’)]
NameError: name ‘os’ is not defined我的解決方法是:在settings.py文件頭部 import os
網絡上還有其他方法(博主沒有去試):修改默認生成的“‘DIRS’: [os.path.join(BASE_DIR, ‘templates’)]”,修改如下:
‘DIRS’: [Path(BASE_DIR, ‘templates’)]
三、配置mysql數據庫
1、本地安裝mysql數據庫
1)安裝mysql數據庫
我使用的是5.7.22(我的版本),安裝略
2)自己創建一個數據庫
創建一個數據庫名稱: smalldjangodb
2、安裝 pymysql
pip install pymysql
3、配置mysql數據庫
1)在項目同名包下的_init_.py裡面添加
import pymysql pymysql.install_as_MySQLdb()
2)在settings.py文件中,把DATABASES中的內容換掉
先註釋掉默認的數據庫配置下圖部分
將下面部分復制進去,然後進行修改
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql',#數據庫的類型 'NAME': '', #所使用的的數據庫的名字 'USER': 'root', #數據庫服務器的用戶 'PASSWORD': '', #密碼 'HOST': '127.0.0.1', #主機 'PORT': '3306', #端口 } }
4、django默認數據遷移
1)執行遷移,將項目中原有的應用的模型同步遷移到數據庫
pycharm的terminal輸入
python manage.py migrate
2)查看數據遷移結果
5、創建一個後臺超級管理員
pycharm的terminal輸入
python manage.py createsuperuser
用戶名、郵箱(隨便輸,格式正確接口)、密碼
這裡註冊的是super 密碼qq+名字簡寫(給自己一個記錄)
四、登錄後臺系統
1、啟動服務
python manage.py runserver
2、登錄後臺系統
使用上一步創建的超管賬戶登錄系統
http://127.0.0.1:8000/admin
登錄成功頁面:
五、創建app應用
1、命令創建應用
pycharm的terminal輸入
python manage.py startapp lucky
2、在settings中的INSTALLED_APPS中配置應用
將應用lucky加到配置settings中的INSTALLED_APPS
六、配置應用路由
1、配置主路由
在應用文件夾lucky下面創建一個子路由文件urls.py
改成如下圖:
多個應用的話,配置多個主路由
2、配置子應用路由
輸入(這裡views.toLoginView指的是lucky應用下views裡面的方法toLoginView,下一步會說明):
from django.urls import path from . import views urlpatterns = [ path('', views.toLoginView, name='toLoginView'), ]
3、配置views
打開應用lucky目錄下的views
from django.shortcuts import render # Create your views here. def toLoginView(request): return render(request, 'login.html')
七、創建html頁面
1、確定模版配置是否正確
2、創建一個示例html頁面
在templates下創建一個login.html
八、訪問
啟動服務訪問地址:http://127.0.0.1:8000/lucky/
開啟:settings.py開啟debug模式
DEBUG = False
ALLOWED_HOSTS = ['127.0.0.1', 'localhost']
九、優化實現簡單的get與post
1、配置路由
from django.urls import path from . import views urlpatterns = [ path('', views.toLoginView), path('index/', views.loginView), ]
2、使用get方式實現
1)配置views頁面
from django.http import HttpResponse from django.shortcuts import render # Create your views here. def toLoginView(request): return render(request, 'login.html') def loginView(request): username = request.GET.get('user', '') # 後面的''表示獲取不到user就賦值空 password = request.GET.get('pwd', '') if username and password: return HttpResponse("登錄成功") else: return HttpResponse("登錄失敗")
2)優化登錄頁面
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>登錄</title> </head> <body> <form action="/lucky/index/" method="get"> <p><label>用戶名:</label><input name="user" /></p> <p><label>密碼:</label><input name="pwd" /></p> <input type="submit" value="登錄"> </form> </body> </html>
3)展示成果
啟動服務 http://127.0.0.1:8000/lucky/
登錄成功
get請求的缺點是賬戶密碼暴露在URL,所有下面講解post方式
3、使用post方式實現
1)配置views頁面
from django.http import HttpResponse from django.shortcuts import render # Create your views here. def toLoginView(request): return render(request, 'login.html') def loginView(request): username = request.POST.get('user', '') # 後面的''表示獲取不到user就賦值空 password = request.POST.get('pwd', '') # if username=='admin' and password=='1': if username and password: return HttpResponse("登錄成功") else: return HttpResponse("登錄失敗")
2)優化登錄頁面
將上面的get修改為post即可
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>登錄</title> </head> <body> <form action="/lucky/index/" method="post"> <p><label>用戶名:</label><input name="user" /></p> <p><label>密碼:</label><input name="pwd" /></p> <input type="submit" value="登錄"> </form> </body> </html>
3)展示成果
啟動服務 http://127.0.0.1:8000/lucky/
十、繼續優化,使用數據庫方式進行數據判斷
1、在model.py當中添加數據模型
from django.db import models # Create your models here. class UserInfo(models.Model): id = models.CharField(primary_key=True,max_length=20) name = models.CharField(max_length=20) password = models.CharField(max_length=20)
2、將數據模型遷移到數據庫
註意mysql此時要能支持訪問
python manage.py makemigrations lucky
將數據遷移到mysql數據庫
python manage.py migrate
到數據庫驗證:
3、創建數據進行後續操作
4、修改views.py
from django.http import HttpResponse from django.shortcuts import render from .models import * # Create your views here. def toLoginView(request): return render(request, 'login.html') def loginView(request): user_name = request.POST.get('user', '') # 後面的''表示獲取不到user就賦值空 pass_word = request.POST.get('pwd', '') # if user_name=='admin' and pass_word=='1': if user_name and pass_word: exit_user =UserInfo.objects.filter(name= user_name,password = pass_word).count() if exit_user >= 1: return HttpResponse("登錄成功!") else: return HttpResponse("帳號密碼錯誤!") else: return HttpResponse("請輸入正確用戶名和密碼!")
5、驗證
十一、實現註冊
1、註冊頁面
在templates下創建register.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>註冊</title> </head> <body> <form action="/lucky/register/" method="post"> {% csrf_token %} <p><label>用戶名:</label><input name="user" /></p> <p><label>密碼:</label><input name="pwd" /></p> <input type="submit" value="註冊"> </form> </body> </html>
2、配置路由
from django.urls import path from . import views urlpatterns = [ path('', views.toLoginView), path('index/', views.loginView), path('toregister/', views.toRegisterView), path('register/', views.registerView), ]
3、創建註冊方法
到views.py文件當中創建registerView方法和toRegisterView方法
from django.http import HttpResponse from django.shortcuts import render from .models import * # Create your views here. def toLoginView(request): return render(request, 'login.html') def loginView(request): user_name = request.POST.get('user', '') # 後面的''表示獲取不到user就賦值空 pass_word = request.POST.get('pwd', '') # if user_name=='admin' and pass_word=='1': if user_name and pass_word: exit_user = UserInfo.objects.filter(name=user_name, password=pass_word).count() if exit_user >= 1: return HttpResponse("登錄成功!") else: return HttpResponse("帳號密碼錯誤!") else: return HttpResponse("請輸入正確用戶名和密碼!") # 渲染註冊頁面 def toRegisterView(request): return render(request, 'register.html') # 註冊的邏輯判斷 def registerView(request): user_name = request.POST.get('user', '') pass_word = request.POST.get('pwd', '') if user_name and pass_word: register_user = UserInfo(name=user_name, password=pass_word) register_user.save() return HttpResponse("註冊成功!") else: return HttpResponse("請輸入完整的用戶名和密碼!")
4、訪問驗證
註意訪問路徑要加應用名字,這個路由配置有關
訪問 http://127.0.0.1:8000/lucky/toregister/
註冊成功
數據庫驗證
這個是註冊加瞭一個重復的判斷
# 註冊的邏輯判斷 def registerView(request): user_name = request.POST.get('user', '') pass_word = request.POST.get('pwd', '') if user_name and pass_word: exit_user = UserInfo.objects.filter(name=user_name).count() if exit_user: return HttpResponse("對不起,當前賬戶已存在!請換一個id註冊") else: register_user = UserInfo(name=user_name, password=pass_word) register_user.save() return HttpResponse("註冊成功!") else: return HttpResponse("請輸入完整的用戶名和密碼!")
十二、數據庫表反映射到django的models
這個會將數據庫當中的全部表都映射過來
# lucky 是django的應用名 python manage.py inspectdb>lucky/models.py
總結
到此這篇關於利用django和mysql實現一個簡單的web登錄頁面的文章就介紹到這瞭,更多相關django mysql實現web登錄頁面內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- python Django實現增刪改查實戰代碼
- Django框架CBV裝飾器中間件auth模塊CSRF跨站請求問題
- Django路由層如何獲取正確的url
- django實現圖片上傳數據庫並顯示
- 利用Python創建第一個Django框架程序