亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Django 實現將圖片轉為Base64,然后使用json傳輸

瀏覽:84日期:2024-05-28 16:17:44

最近使用Django來進行圖像的傳輸,由于要求需要使用Json格式進行請求,所以我們嘗試了二進制編碼放在json里,發現bytes格式不能打入json,于是轉為了base64

將圖片轉為json

圖片轉為json有2中方法,一個是二進制后再轉,一個是轉為矩陣以后再轉。

import base64import cv2#通過opencv轉base64img_im= cv2.imread('D://32.png')aa=base64.b64encode(cv2.imencode(’.jpg’,img_im)[1]).decode()print(len(aa)) #17292#通過bytes再轉base64bb=base64.b64encode(open('D://32.png', ’rb’).read())print(len(bb)) #43848

最后采用了Opencv的方式,主要發現opencv的base64編碼比第二種短一半,所以用了第一種。

客戶端請求發送數據格式

客戶端請求服務器的base64,目前我這里發現2中,通過Postman測試。

第一種 ‘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'))#服務端: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 已經轉為矩陣了

第二種 ‘application/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'))#服務端:def local_ocr_base64(request): # result = request.POST.get('image') data = request.body data_json=simplejson.loads(data) #data是str格式的,需要轉為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)

補充知識:Django將多個圖片保存成一個URL串返回給前端

說明

Django有ImageField字段,是封裝好的,使用很方便,但是一個ImageField字段只能保存一張圖片的URL,我現在是想將多張圖片保存在一個字段里,然后URL和URL之間用一個自定義的分隔符連接起來,這樣不用為了圖片再設計一個字表。

自定義上傳圖片

設置settings.py文件,添加如下語句

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代表的是用戶上傳后的文件一般保存的地方,一般在放在項目目錄下,例如BASE_DIR就是取得項目絕對地址。而MEDIA_URL是指URL訪問時的URL。例如,

BASE_DIR: /Users/incisor/VSCodeProjects/python/Notes

那么

MEDIA_ROOT:/Users/incisor/VSCodeProjects/python/Notes/media

假設media目錄下有一張圖片2019.jpg,那么

MEDIA_URL: http://127.0.0.1:8000/media/

然后再通過http://127.0.0.1:8000/media/2019.jpg這個URL是可以直接訪問這個圖片的。

IMAGE_ROOT是我自定義的一個字段,因為我想以后可能會上傳視頻,或者其他一些文件,想區分開,所以我在media目錄下再建了一個目錄images,那么

IMAGE_ROOT: /Users/incisor/VSCodeProjects/python/Notes/media/images

WEB_HOST_MEDIA_URL是拼接URL時使用,因為我接下來要自己拼接多個圖的URL,MEDIA_URL[1:]的原因時如果不去掉第一個/,那WEB_HOST_MEDIA_URL會是/media/images/,這顯然不是我們想要的,所以需要把第一個/去掉。

views.py文件

前端傳過來不定數量的圖片,可能0張,最多9張,每個圖片都做base64編碼再傳過來,POST請求里有個參數imgs,是一個數組,保存base64編碼。

base64編碼如下圖所示,這只是一部分:

前面的data:image/png;base64, 除了后綴會不同,其他的是固定的,所以我會先從這里取得后綴png,再做編碼轉換。

import base64import osimport refrom datetime import date, datetimefrom rest_framework import statusfrom rest_framework.decorators import api_viewfrom rest_framework.response import Responsefrom 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) # 判斷目錄是否存在,不存在則創建 for img in request.data[’imgs’]: strs = img.split(’,’) suffix = re.findall(r’/(w+?);’, strs[0])[0] # 取得文件后綴 # 拼接服務器上的文件名 # datetime.now()取得當前時間,精確到了微秒,一般來說是唯一的了,因為目錄是日期,所以文件名就去掉日期,最后會是一串數字 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解碼,再寫入文件 out.flush() urls += os.path.join(WEB_HOST_MEDIA_URL, dir_name, img_name) + ’[/--sp--/]’ # 拼接URL,URL與URL之間用[/--sp--/]隔開 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 adminfrom django.urls import pathfrom django.conf.urls.static import static # 需要添加這句,包含靜態資源之類的from note import viewsfrom . import settingsurlpatterns = [ path(’notes/images/’, views.images), path(’admin/’, admin.site.urls),]urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT) # 這句不設置的話,不能通過URL直接訪問到圖片

4、啟動服務,python3 manage.py runserver

5、POST請求,然后返回對應的JSON數據

{ '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'}

這樣在數據庫方面,就可以直接用一個varchar類型來存儲多張圖了,前端收到URL串,再按照定好的分隔符[/?sp?/]切開后,就可以顯示了。

以上這篇Django 實現將圖片轉為Base64,然后使用json傳輸就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: JavaScript
主站蜘蛛池模板: 黄色网址在线视频 | 欧美黄色片免费观看 | 免费大黄网站在线观看 | 黄色网在线播放 | 福利社区在线观看 | 久久机热一这里只精品 | 日日噜噜夜夜狠狠tv视频免费 | 久久久久久久国产精品影院 | 国产精品福利一区二区 | 99久久综合国产精品免费 | 日韩精品一区二区三区四区 | 国产无套在线观看视频 | 色婷婷综合欧美成人 | 亚拍精品一区二区三区 | 大尺度做爰床戏呻吟免费观 | 军营里娇喘呻吟声乳 | 成人免费在线网站 | 亚洲高清在线天堂精品 | 久久中文字幕综合不卡一二区 | 91丨国产| 欧美伦理三级在线播放影院 | 国产一区二区精品人妖系列 | 99久久精品6在线播放 | 国产一级特黄特色aa毛片 | 亚洲综合国产一区在线 | 91精品国产乱码久久久久久 | 九九热这里只有国产精品 | 日韩欧美亚洲综合一区二区 | 免费一级毛片不卡不收费 | 久久经典免费视频 | 国产闫盼盼私拍福利精品视频 | 日韩一区二区免费看 | 亚洲六月丁香婷婷综合 | 欧美一级久久久久久久大片 | 久热在线播放中文字幕 | 一区二区三区四区在线观看视频 | 日本特黄特黄刺激大片 | 国产精品综合久成人 | 免费自拍视频 | 国产免费又色又爽又黄的网站 | 国产亚洲自拍一区 |