python使用socket實(shí)現(xiàn)圖像傳輸功能
在python中使用socket進(jìn)行l(wèi)inux服務(wù)器與win10主機(jī)間的圖像傳輸,供大家參考,具體內(nèi)容如下
前提:服務(wù)器與主機(jī)需要在同一局域網(wǎng)內(nèi)
使用方法:
(1)分別將下面兩段代碼存入對(duì)應(yīng)位置
(2)先運(yùn)行服務(wù)器端代碼,顯示Wait for Connection.....................
(3)在運(yùn)行客戶端代碼,顯示input the file:
(4)在(3)的輸出后面復(fù)制想需要傳輸?shù)膱D像地址即可
1.服務(wù)器端(我的是Linux服務(wù)器)
# 服務(wù)器端server.py import socket import os import sys import struct def socket_service_image(): try: s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) # s.bind(('127.0.0.1', 8001)) s.bind(('改成你的服務(wù)器ip地址', 8001)) s.listen(10) except socket.error as msg: print(msg) sys.exit(1) print("Wait for Connection.....................") while True: sock, addr = s.accept() # addr是一個(gè)元組(ip,port) deal_image(sock, addr) def deal_image(sock, addr): print("Accept connection from {0}".format(addr)) # 查看發(fā)送端的ip和端口 while True: fileinfo_size = struct.calcsize('128sq') buf = sock.recv(fileinfo_size) # 接收?qǐng)D片名 if buf: filename, filesize = struct.unpack('128sq', buf) fn = filename.decode().strip('\x00') new_filename = os.path.join(r'G:\reseive_images\\' + fn) # 在服務(wù)器端新建圖片名(可以不用新建的,直接用原來的也行,只要客戶端和服務(wù)器不是同一個(gè)系統(tǒng)或接收到的圖片和原圖片不在一個(gè)文件夾下) recvd_size = 0 fp = open(new_filename, 'wb') while not recvd_size == filesize: if filesize - recvd_size > 1024: data = sock.recv(1024) recvd_size += len(data) else: data = sock.recv(1024) recvd_size = filesize fp.write(data) # 寫入圖片數(shù)據(jù) fp.close() sock.close() break if __name__ == '__main__': socket_service_image()
2.客戶端(我的是win10主機(jī))
# 客戶端client.py import socket import os import sys import struct def sock_client_image(): while True: try: s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) s.connect(('改成服務(wù)器ip地址', 8001)) # 服務(wù)器和客戶端在不同的系統(tǒng)或不同的主機(jī)下時(shí)使用的ip和端口,首先要查看服務(wù)器所在的系統(tǒng)網(wǎng)卡的ip # s.connect(('127.0.0.1', 8001)) #服務(wù)器和客戶端都在一個(gè)系統(tǒng)下時(shí)使用的ip和端口 except socket.error as msg: print(msg) print(sys.exit(1)) filepath = input('input the file: ') # 輸入當(dāng)前目錄下的圖片名 xxx.jpg fhead = struct.pack(b'128sq', bytes(os.path.basename(filepath), encoding='utf-8'), os.stat(filepath).st_size) # 將xxx.jpg以128sq的格式打包 s.send(fhead) fp = open(filepath, 'rb') # 打開要傳輸?shù)膱D片 while True: data = fp.read(1024) # 讀入圖片數(shù)據(jù) if not data: print('{0} send over...'.format(filepath)) break s.send(data) # 以二進(jìn)制格式發(fā)送圖片數(shù)據(jù) s.close() # break #循環(huán)發(fā)送 if __name__ == '__main__': sock_client_image()
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python 進(jìn)程的幾種創(chuàng)建方式詳解
這篇文章主要介紹了python 進(jìn)程的幾種創(chuàng)建方式詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08Keras多線程機(jī)制與flask多線程沖突的解決方案
這篇文章主要介紹了Keras多線程機(jī)制與flask多線程沖突的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-05-05python web自制框架之接受url傳遞過來的參數(shù)實(shí)例
今天小編就為大家分享一篇python web自制框架之接受url傳遞過來的參數(shù)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-12-12