教你用Django將前端的數(shù)據(jù)存入Mysql數(shù)據(jù)庫(kù)
1.在app下的models.py中創(chuàng)建新的模板

具體代碼如下:
class Apply(models.Model): clas = models.CharField(max_length=32, verbose_name="班級(jí)") name = models.CharField(max_length=32, verbose_name="姓名") number = models.CharField(max_length=15, verbose_name="學(xué)號(hào)") email = models.CharField(max_length=32, verbose_name="郵箱") phone = models.CharField(max_length=11, verbose_name="手機(jī)號(hào)") zhiyuan1 = models.EmailField(max_length=32, verbose_name="志愿一") zhiyuan2 = models.EmailField(max_length=32, verbose_name="志愿二")
Apply類下的clas,name這些通過(guò)數(shù)據(jù)遷移會(huì)變成mysql數(shù)據(jù)庫(kù)中的列表名
2.數(shù)據(jù)遷移(用pycharm自帶的Terminal工具即可)
python manage.py makemigrations finalapp python manage.py migrate finalapp
finalapp是我app的名字,大家數(shù)據(jù)遷移的時(shí)候記得換成自己app的名字
下面是我數(shù)據(jù)遷移之后的mysql數(shù)據(jù)庫(kù),可以看到finalapp_apply表已經(jīng)創(chuàng)建成功,雙擊點(diǎn)開(kāi)就可以查看表,新創(chuàng)建的表是什么數(shù)據(jù)都沒(méi)有的,圖中的是我的前端通過(guò)form表單提交到數(shù)據(jù)庫(kù)的

3.在app下的views.py中創(chuàng)建新的視圖

具體代碼如下:
def apply(request):
if request.method == "POST": # 判斷請(qǐng)求為POST請(qǐng)求則是提交表單
apply = Apply() # 創(chuàng)建一個(gè)apply實(shí)例
clas = request.POST.get("clas") # 獲取提交表單中的clas值,賦值給clas
name = request.POST.get("name") # 獲取提交表單中的name值,賦值給變量name
number = request.POST.get("number")
email = request.POST.get("email")
phone = request.POST.get("phone")
zhiyuan1 = request.POST.get("zhiyuan1")
zhiyuan2 = request.POST.get("zhiyuan2")
apply.clas = clas #給實(shí)例賦值
apply.name = name
apply.number = number
apply.email = email
apply.phone = phone
apply.zhiyuan1 = zhiyuan1
apply.zhiyuan2 = zhiyuan2
apply.save() # 保存實(shí)例,把數(shù)據(jù)存到數(shù)據(jù)庫(kù)
return render(request, 'applysuccessful.html') #數(shù)據(jù)保存之后,從apply網(wǎng)頁(yè)跳轉(zhuǎn)到成功的頁(yè)面
else:
return render(request, 'apply.html') #沒(méi)有數(shù)據(jù)的時(shí)候,跳轉(zhuǎn)到apply網(wǎng)頁(yè)
4.前端

具體代碼如下:
<form action="/apply/" method="post" style="padding-top: 30px">
{% csrf_token %}
<p>
<label>班 級(jí):<input type="text" name="clas"></label>
</p>
<p>
<label>姓 名:<input type="text" name="name"></label>
</p>
<p>
<label>學(xué) 號(hào):<input type="text" name="number"></label>
</p>
<p>
<label>郵 箱:<input type="text" name="email"></label>
</p>
<p>
<label>手機(jī)號(hào):<input type="text" name="phone"></label>
</p>
<p>
<label>志愿一:<input type="text" name="zhiyuan1"></label>
</p>
<p>
<label>志愿二:<input type="text" name="zhiyuan2"></label>
</p>
<input type="submit" value="提交">
</form>
form表單必須寫(xiě) action 屬性,它規(guī)定當(dāng)提交表單時(shí),向何處發(fā)送表單數(shù)據(jù)。
{%csrf_token%}:在Django中我們需要在templates的form中加入{%csrf_token%}這串內(nèi)容,它的作用是當(dāng)我們get表單頁(yè)面時(shí),服務(wù)器返回頁(yè)面的同時(shí)也會(huì)向前端返回一串隨機(jī)字符,post提交時(shí)服務(wù)器會(huì)驗(yàn)證這串字符來(lái)確保用戶是在服務(wù)端返回的表單頁(yè)面中提交的數(shù)據(jù),防止有人通過(guò)例如jquery腳本向某個(gè)url不斷提交數(shù)據(jù),是一種數(shù)據(jù)提交的驗(yàn)證機(jī)制。
5.效果


可以看到前端提交的數(shù)據(jù)已經(jīng)存入到數(shù)據(jù)庫(kù)中
希望這篇文章可以幫助到你?。?!
版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。
關(guān)注官方微信