小編使用python中的django框架來完成!
這里小編默認(rèn)項(xiàng)目都會創(chuàng)建
settings.py中要修改的兩處配置
DATABASES = { 'default': { # 'ENGINE': 'django.db.backends.sqlite3', # 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), 'ENGINE': 'django.db.backends.mysql', 'NAME': 'photos', 'HOST': '127.0.0.1', 'PORT': '3306', 'USER': 'root', 'PASSWORD': '201314', } } STATIC_URL = '/static/' STATICFILES_DIRS = [ os.path.join(BASE_DIR, 'static') ]
①先按鍵盤上win+s鍵,然后輸入cmd,中文輸入法兩下回車,英文輸入法一下回車,即可進(jìn)入dos窗口。
②輸入 mysql -uroot -p密碼 回車進(jìn)入mysql數(shù)據(jù)庫,再輸入 create database 表名; 一個小回車,創(chuàng)建數(shù)據(jù)庫🆗
③在app下的models.py中創(chuàng)建表結(jié)構(gòu)
models.py
from django.db import models # Create your models here. class Images(models.Model): img = models.ImageField(upload_to='static/pictures/') # upload_to='static/pictures/'是指定圖片存儲的文件夾名稱,上傳文件之后會自動創(chuàng)建 img_name = models.CharField(max_length=32) create_time = models.DateTimeField(auto_now_add=True)
④遷移數(shù)據(jù)庫
分別按順序在pycharm下面的Terminal中執(zhí)行下面兩條語句
python manage.py makemigrations python manage.py migrate
urls.py
from django.conf.urls import url from django.contrib import admin from app01 import views urlpatterns = [ url(r'^admin/$', admin.site.urls), url(r'^upload/$', views.upload, name='upload'), ]
views.py
from django.shortcuts import render, redirect from app01 import models # Create your views here. def upload(request): error = '' if request.method == 'POST': img = request.FILES.get('img') pic_name = img.name if pic_name.split('.')[-1] == 'mp4': error = '暫不支持上傳此格式圖片?。?!' else: models.Images.objects.create(img_name=pic_name, img=img) return redirect('show') return render(request, 'upload.html', locals())
前端上傳頁面upload.html
!DOCTYPE html> html lang="en"> head> meta charset="UTF-8"> title>上傳照片/title> /head> body> div style="height: 160px"> form action="" method="post" enctype="multipart/form-data"> {% csrf_token %} h1>上傳圖片頁面/h1> table cellpadding="5px"> tr> td>上傳圖片/td> td>input type="file" name="img">/td> /tr> tr> td> button>上傳/button> /td> td>strong style="color: red">{{ error }}/strong>/td> /tr> /table> /form> /div> div style="text-align: center;color: #2b542c;font-size: 20px;"> a href=" {% url 'show' %} " rel="external nofollow" >返回/a> /div> /body> /html>
urls.py
""" from django.conf.urls import url from django.contrib import admin from app01 import views urlpatterns = [ url(r'^admin/$', admin.site.urls), url(r'^upload/$', views.upload, name='upload'), url(r'^show/$', views.show, name='show'), ]
views.py
from django.shortcuts import render, redirect from app01 import models # Create your views here. def upload(request): error = '' if request.method == 'POST': img = request.FILES.get('img') pic_name = img.name if pic_name.split('.')[-1] == 'mp4': error = '暫不支持上傳此格式圖片?。?!' else: models.Images.objects.create(img_name=pic_name, img=img) return redirect('show') return render(request, 'upload.html', locals()) def show(request): all_images = models.Images.objects.all() # for i in all_images: # print(i.img) return render(request, 'show.html', locals())
前端展示show.html
!DOCTYPE html> html lang="en"> head> meta charset="UTF-8"> title>展示照片/title> /head> body> {% for image in all_images %} img src="/{{ image.img }}" style="width: 240px;height: 240px;"> {% endfor %} br/> p style="text-align: center;color: #2b542c;font-size: 20px;"> a href="{% url 'upload' %}" rel="external nofollow" rel="external nofollow" >返回/a> /p> /body> /html>
urls.py
from django.conf.urls import url from django.contrib import admin from app01 import views urlpatterns = [ url(r'^admin/$', admin.site.urls), url(r'^upload/$', views.upload, name='upload'), url(r'^show/$', views.show, name='show'), url(r'^delete/$', views.delete, name='delete'), ]
views.py
from django.shortcuts import render, redirect from app01 import models # Create your views here. def upload(request): error = '' if request.method == 'POST': img = request.FILES.get('img') pic_name = img.name if pic_name.split('.')[-1] == 'mp4': error = '暫不支持上傳此格式圖片?。。? else: models.Images.objects.create(img_name=pic_name, img=img) return redirect('show') return render(request, 'upload.html', locals()) def show(request): all_images = models.Images.objects.all() # for i in all_images: # print(i.img) return render(request, 'show.html', locals()) def delete(request): pk = request.GET.get('pk') models.Images.objects.filter(id=pk).delete() return redirect('show')
show.html
!DOCTYPE html> html lang="en"> head> meta charset="UTF-8"> title>展示照片/title> /head> body> {% for image in all_images %} img src="/{{ image.img }}" style="width: 240px;height: 240px;"> a href="/delete/?pk={{ image.id }}" rel="external nofollow" >刪除/a> {% endfor %} br/> p style="text-align: center;color: #2b542c;font-size: 20px;"> a href="{% url 'upload' %}" rel="external nofollow" rel="external nofollow" >返回/a> /p> /body> /html>
6,整體演示一遍
因?yàn)闀r間緊,故以最low方式簡要實(shí)現(xiàn),并沒有加上漂亮的頁面和樣式,喜歡美的看客朋友可自行去Bootstrap官網(wǎng)或jq22自行添加!??!
到此這篇關(guān)于將圖片保存到mysql數(shù)據(jù)庫并展示在前端頁面的文章就介紹到這了,更多相關(guān)圖片保存mysql數(shù)據(jù)庫展示前端頁面內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
標(biāo)簽:南充 徐州 龍巖 麗水 西寧 迪慶 無錫 自貢
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《將圖片保存到mysql數(shù)據(jù)庫并展示在前端頁面的實(shí)現(xiàn)代碼》,本文關(guān)鍵詞 將,圖片,保存,到,mysql,數(shù)據(jù)庫,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。