Django 實(shí)現(xiàn)將圖片轉(zhuǎn)為Base64,然后使用json傳輸
最近使用Django來(lái)進(jìn)行圖像的傳輸,由于要求需要使用Json格式進(jìn)行請(qǐng)求,所以我們嘗試了二進(jìn)制編碼放在json里,發(fā)現(xiàn)bytes格式不能打入json,于是轉(zhuǎn)為了base64
將圖片轉(zhuǎn)為json
圖片轉(zhuǎn)為json有2中方法,一個(gè)是二進(jìn)制后再轉(zhuǎn),一個(gè)是轉(zhuǎn)為矩陣以后再轉(zhuǎn)。
import base64
import cv2
#通過(guò)opencv轉(zhuǎn)base64
img_im= cv2.imread("D://32.png")
aa=base64.b64encode(cv2.imencode('.jpg',img_im)[1]).decode()
print(len(aa)) #17292
#通過(guò)bytes再轉(zhuǎn)base64
bb=base64.b64encode(open("D://32.png", 'rb').read())
print(len(bb)) #43848
最后采用了Opencv的方式,主要發(fā)現(xiàn)opencv的base64編碼比第二種短一半,所以用了第一種。
客戶端請(qǐng)求發(fā)送數(shù)據(jù)格式
客戶端請(qǐng)求服務(wù)器的base64,目前我這里發(fā)現(xiàn)2中,通過(guò)Postman測(cè)試。
第一種 ‘form/data':
#客戶端:
image1= cv2.imread("D://32.png")
aa=base64.b64encode(cv2.imencode('.jpg',image1)[1]).decode()
r = requests.post(url, data={"image": image1})
print(r.content.decode("utf-8"))
#服務(wù)端:
def image_base64(request):
result = request.POST.get("image")
img_byte = base64.b64decode(result)
img_np_arr = np.fromstring(img_byte, np.uint8)
image = cv2.imdecode(img_np_arr, cv2.IMREAD_COLOR)
#image 已經(jīng)轉(zhuǎn)為矩陣了
第二種 ‘a(chǎn)pplication/json':
#客戶端:
image1= cv2.imread("D://32.png")
aa=base64.b64encode(cv2.imencode('.jpg',image1)[1]).decode()
r = requests.post(url, json={"image": image1})
print(r.content.decode("utf-8"))
#服務(wù)端:
def local_ocr_base64(request):
# result = request.POST.get("image")
data = request.body
data_json=simplejson.loads(data) #data是str格式的,需要轉(zhuǎn)為json
result=data_json["image"]
img_byte = base64.b64decode(result)
img_np_arr = np.fromstring(img_byte, np.uint8)
image = cv2.imdecode(img_np_arr, cv2.IMREAD_COLOR)
補(bǔ)充知識(shí):Django將多個(gè)圖片保存成一個(gè)URL串返回給前端
說(shuō)明
Django有ImageField字段,是封裝好的,使用很方便,但是一個(gè)ImageField字段只能保存一張圖片的URL,我現(xiàn)在是想將多張圖片保存在一個(gè)字段里,然后URL和URL之間用一個(gè)自定義的分隔符連接起來(lái),這樣不用為了圖片再設(shè)計(jì)一個(gè)字表。
自定義上傳圖片
設(shè)置settings.py文件,添加如下語(yǔ)句
MEDIA_URL = '/media/'
MEDIA_ROOT = os.path.join(BASE_DIR, 'media/')
IMAGE_ROOT = os.path.join(MEDIA_ROOT, 'images/')
WEB_HOST_MEDIA_URL = os.path.join('http://127.0.0.1:8000', MEDIA_URL[1:], 'images/')
MEDIA_ROOT代表的是用戶上傳后的文件一般保存的地方,一般在放在項(xiàng)目目錄下,例如BASE_DIR就是取得項(xiàng)目絕對(duì)地址。而MEDIA_URL是指URL訪問(wèn)時(shí)的URL。例如,
BASE_DIR: /Users/incisor/VSCodeProjects/python/Notes
那么
MEDIA_ROOT:/Users/incisor/VSCodeProjects/python/Notes/media
假設(shè)media目錄下有一張圖片2019.jpg,那么
MEDIA_URL: http://127.0.0.1:8000/media/
然后再通過(guò)http://127.0.0.1:8000/media/2019.jpg這個(gè)URL是可以直接訪問(wèn)這個(gè)圖片的。
IMAGE_ROOT是我自定義的一個(gè)字段,因?yàn)槲蚁胍院罂赡軙?huì)上傳視頻,或者其他一些文件,想?yún)^(qū)分開(kāi),所以我在media目錄下再建了一個(gè)目錄images,那么
IMAGE_ROOT: /Users/incisor/VSCodeProjects/python/Notes/media/images
WEB_HOST_MEDIA_URL是拼接URL時(shí)使用,因?yàn)槲医酉聛?lái)要自己拼接多個(gè)圖的URL,MEDIA_URL[1:]的原因時(shí)如果不去掉第一個(gè)/,那WEB_HOST_MEDIA_URL會(huì)是/media/images/,這顯然不是我們想要的,所以需要把第一個(gè)/去掉。
views.py文件
前端傳過(guò)來(lái)不定數(shù)量的圖片,可能0張,最多9張,每個(gè)圖片都做base64編碼再傳過(guò)來(lái),POST請(qǐng)求里有個(gè)參數(shù)imgs,是一個(gè)數(shù)組,保存base64編碼。
base64編碼如下圖所示,這只是一部分:
前面的data:image/png;base64, 除了后綴會(huì)不同,其他的是固定的,所以我會(huì)先從這里取得后綴png,再做編碼轉(zhuǎn)換。
import base64
import os
import re
from datetime import date, datetime
from rest_framework import status
from rest_framework.decorators import api_view
from rest_framework.response import Response
from Notes.settings import IMAGE_ROOT, WEB_HOST_MEDIA_URL
@api_view(['POST',])
def images(request):
urls = ''
dir_name = date.today().__str__().replace('-', '_', 2) # 2019_06_21
dirs = os.path.join(IMAGE_ROOT, dir_name) # 將日期作為目錄名
if not os.path.isdir(dirs):
os.makedirs(dirs) # 判斷目錄是否存在,不存在則創(chuàng)建
for img in request.data['imgs']:
strs = img.split(',')
suffix = re.findall(r'/(\w+?);', strs[0])[0] # 取得文件后綴
# 拼接服務(wù)器上的文件名
# datetime.now()取得當(dāng)前時(shí)間,精確到了微秒,一般來(lái)說(shuō)是唯一的了,因?yàn)槟夸浭侨掌?,所以文件名就去掉日期,最后?huì)是一串?dāng)?shù)字
img_name = re.sub(r':|\.', '', datetime.now().__str__().split(' ')[1]) + '.' + suffix
img_path = os.path.join(dirs, img_name)
with open(img_path, 'wb') as out:
out.write(base64.b64decode(strs[1])) # base64解碼,再寫(xiě)入文件
out.flush()
urls += os.path.join(WEB_HOST_MEDIA_URL, dir_name, img_name) + '[/--sp--/]' # 拼接URL,URL與URL之間用[/--sp--/]隔開(kāi)
result = {}
result['status'] = status.HTTP_200_OK
result['message'] = '圖片上傳成功'
result['urls'] = urls[:len(urls) - len('[/--sp--/]')] # 去掉末尾的[/--sp--/]
return Response(data=result)
3、urls.py文件
from django.contrib import admin
from django.urls import path
from django.conf.urls.static import static # 需要添加這句,包含靜態(tài)資源之類的
from note import views
from . import settings
urlpatterns = [
path('notes/images/', views.images),
path('admin/', admin.site.urls),
]
urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT) # 這句不設(shè)置的話,不能通過(guò)URL直接訪問(wèn)到圖片
4、啟動(dòng)服務(wù),python3 manage.py runserver
5、POST請(qǐng)求,然后返回對(duì)應(yīng)的JSON數(shù)據(jù)
{
"status": 200,
"message": "圖片上傳成功",
"urls": "http://127.0.0.1:8000/media/images/2019_06_21/073249204253.png[/--sp--/]http://127.0.0.1:8000/media/images/2019_06_21/073249854323.png"
}
這樣在數(shù)據(jù)庫(kù)方面,就可以直接用一個(gè)varchar類型來(lái)存儲(chǔ)多張圖了,前端收到URL串,再按照定好的分隔符[/–sp–/]切開(kāi)后,就可以顯示了。
以上這篇Django 實(shí)現(xiàn)將圖片轉(zhuǎn)為Base64,然后使用json傳輸就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- 詳解Django自定義圖片和文件上傳路徑(upload_to)的2種方式
- Django實(shí)現(xiàn)前臺(tái)上傳并顯示圖片功能
- Django實(shí)現(xiàn)后臺(tái)上傳并顯示圖片功能
- Django實(shí)現(xiàn)圖片上傳功能步驟解析
- Django {{ MEDIA_URL }}無(wú)法顯示圖片的解決方式
- django 讀取圖片到頁(yè)面實(shí)例
- django中的圖片驗(yàn)證碼功能
- django項(xiàng)目登錄中使用圖片驗(yàn)證碼的實(shí)現(xiàn)方法
- Django 實(shí)現(xiàn)前端圖片壓縮功能的方法
- Django 實(shí)現(xiàn)圖片上傳和下載功能
相關(guān)文章
Python使用文件操作實(shí)現(xiàn)一個(gè)XX信息管理系統(tǒng)的示例
這篇文章主要介紹了Python使用文件操作實(shí)現(xiàn)一個(gè)XX信息管理系統(tǒng)的示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
Python?selenium?get_cookies獲取cookie不全的解決方案
之前使用爬蟲(chóng)時(shí)最讓我頭疼的就是cookie失效的問(wèn)題了,下面這篇文章主要給大家介紹了關(guān)于Python?selenium?get_cookies獲取cookie不全的解決方案,需要的朋友可以參考下2022-10-10
python實(shí)現(xiàn)漫天飄落的七彩花朵效果
要實(shí)現(xiàn)漫天飄落的七彩花朵效果,你可以使用Python的圖形庫(kù),如Pygame或Pyglet,這些庫(kù)可以幫助你創(chuàng)建動(dòng)畫(huà)和圖形效果,本文給大家介紹了如何使用python實(shí)現(xiàn)漫天飄落的七彩花朵效果,感興趣的朋友可以參考下2024-01-01
WxPython界面利用pubsub如何實(shí)現(xiàn)多線程控制
這篇文章主要介紹了WxPython界面利用pubsub如何實(shí)現(xiàn)多線程控制,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11
基于Python實(shí)現(xiàn)DIT-FFT算法
FFT(Fast Fourier Transformation)是離散傅氏變換(DFT)的快速算法。即為快速傅氏變換。本文將用Python語(yǔ)言實(shí)現(xiàn)DIT-FFT算法,感興趣的可以了解一下2022-10-10
python3.5 + PyQt5 +Eric6 實(shí)現(xiàn)的一個(gè)計(jì)算器代碼
這篇文章主要介紹了python3.5 + PyQt5 +Eric6 實(shí)現(xiàn)的一個(gè)計(jì)算器代碼,在windows7 32位系統(tǒng)可以完美運(yùn)行 計(jì)算器,有興趣的可以了解一下。2017-03-03
python神經(jīng)網(wǎng)絡(luò)ResNet50模型的復(fù)現(xiàn)詳解
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)ResNet50模型的復(fù)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05

