中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何利用django和mysql實現一個簡單的web登錄頁面

發布時間:2023-10-23 16:21:42 來源:億速云 閱讀:158 作者:栢白 欄目:開發技術

本篇文章和大家了解一下如何利用django和mysql實現一個簡單的web登錄頁面。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。

前言:

本文從0到1實現django搭建一個web頁面,實現了django連接mysql數據庫,簡單的get、post請求等

一、使用pyacharm創建一個django項目

略,專業版直接創建即可

這是初始化創建的第三方庫

如何利用django和mysql實現一個簡單的web登錄頁面

二、啟動django項目驗證

pycharm的terminal輸入

python manage.py runserver

如何利用django和mysql實現一個簡單的web登錄頁面

 訪問:

如何利用django和mysql實現一個簡單的web登錄頁面

 小插曲:在啟動的時候報錯:‘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

如何利用django和mysql實現一個簡單的web登錄頁面

3、配置mysql數據庫

1)在項目同名包下的_init_.py里面添加

import pymysql
pymysql.install_as_MySQLdb()

如何利用django和mysql實現一個簡單的web登錄頁面

 2)在settings.py文件中,把DATABASES中的內容換掉

 先注釋掉默認的數據庫配置下圖部分

如何利用django和mysql實現一個簡單的web登錄頁面

 將下面部分復制進去,然后進行修改

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

如何利用django和mysql實現一個簡單的web登錄頁面

 2)查看數據遷移結果

如何利用django和mysql實現一個簡單的web登錄頁面

5、創建一個后臺超級管理員 

pycharm的terminal輸入

python manage.py createsuperuser

 用戶名、郵箱(隨便輸,格式正確接口)、密碼

這里注冊的是super 密碼qq+名字簡寫(給自己一個記錄)

如何利用django和mysql實現一個簡單的web登錄頁面

 四、登錄后臺系統

1、啟動服務

python manage.py runserver

2、登錄后臺系統

使用上一步創建的超管賬戶登錄系統 

http://127.0.0.1:8000/admin

如何利用django和mysql實現一個簡單的web登錄頁面

 登錄成功頁面:

如何利用django和mysql實現一個簡單的web登錄頁面

五、創建app應用

1、命令創建應用

pycharm的terminal輸入

python manage.py startapp lucky

如何利用django和mysql實現一個簡單的web登錄頁面

2、在settings中的INSTALLED_APPS中配置應用

將應用lucky加到配置settings中的INSTALLED_APPS

如何利用django和mysql實現一個簡單的web登錄頁面

六、配置應用路由 

1、配置主路由

 在應用文件夾lucky下面創建一個子路由文件urls.py

如何利用django和mysql實現一個簡單的web登錄頁面

 改成如下圖:

如何利用django和mysql實現一個簡單的web登錄頁面

 多個應用的話,配置多個主路由

2、配置子應用路由

如何利用django和mysql實現一個簡單的web登錄頁面

 輸入(這里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、確定模版配置是否正確

如何利用django和mysql實現一個簡單的web登錄頁面

2、創建一個示例html頁面 

在templates下創建一個login.html

如何利用django和mysql實現一個簡單的web登錄頁面

八、訪問

啟動服務訪問地址:http://127.0.0.1:8000/lucky/

如何利用django和mysql實現一個簡單的web登錄頁面

開啟: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/

如何利用django和mysql實現一個簡單的web登錄頁面

 登錄成功

如何利用django和mysql實現一個簡單的web登錄頁面

 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/

如何利用django和mysql實現一個簡單的web登錄頁面

十、繼續優化,使用數據庫方式進行數據判斷

1、在model.py當中添加數據模型

如何利用django和mysql實現一個簡單的web登錄頁面

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

如何利用django和mysql實現一個簡單的web登錄頁面

 將數據遷移到mysql數據庫

python manage.py migrate

如何利用django和mysql實現一個簡單的web登錄頁面

 到數據庫驗證:

如何利用django和mysql實現一個簡單的web登錄頁面

3、創建數據進行后續操作

如何利用django和mysql實現一個簡單的web登錄頁面

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、驗證

如何利用django和mysql實現一個簡單的web登錄頁面

如何利用django和mysql實現一個簡單的web登錄頁面

十一、實現注冊

1、注冊頁面

如何利用django和mysql實現一個簡單的web登錄頁面

在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/

如何利用django和mysql實現一個簡單的web登錄頁面

 注冊成功

如何利用django和mysql實現一個簡單的web登錄頁面

 數據庫驗證

如何利用django和mysql實現一個簡單的web登錄頁面

這個是注冊加了一個重復的判斷

# 注冊的邏輯判斷
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登錄頁面的簡略介紹,當然詳細使用上面的不同還得要大家自己使用過才領會。如果想了解更多,歡迎關注億速云行業資訊頻道哦!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

黄浦区| 祁门县| 蒙阴县| 历史| 疏勒县| 临潭县| 大竹县| 北碚区| 牙克石市| 镇康县| 宿州市| 鹤庆县| 政和县| 宣汉县| 青河县| 兴城市| 从化市| 三原县| 绥棱县| 敦煌市| 法库县| 庐江县| 莒南县| 沂水县| 泰和县| 漳平市| 万荣县| 禄劝| 普安县| 台南市| 广州市| 扎赉特旗| 宁蒗| 京山县| 包头市| 荣昌县| 句容市| 英吉沙县| 遂平县| 怀柔区| 封丘县|