Heim  >  Artikel  >  Backend-Entwicklung  >  Detaillierte Einführung in Sockets in Python

Detaillierte Einführung in Sockets in Python

零下一度
零下一度Original
2017-07-18 15:23:352053Durchsuche

Socket wird normalerweise als „Socket“ bezeichnet und bezeichnet die IP-Adresse und den Port. Es ist das Handle einer Kommunikationskette, die normalerweise über „Socket“ Anfragen an das Netzwerk stellt.

Socket stammt von Unix und eine der Grundphilosophien von Unix/Linux lautet „Alles ist eine Datei“. Verwenden Sie für Dateien die Funktion [Öffnen] [Lesen und Schreiben] [Schließen]. ]-Modus zu bedienen. Socket ist eine Implementierung dieses Modus. Einige Socket-Funktionen sind Operationen darauf (E/A lesen/schreiben, öffnen, schließen)

Socket und Der Unterschied zwischen Datei:

Das Dateimodul dient zum [Öffnen] [Lesen und Schreiben] [Schließen] für eine bestimmte Datei

1. Socket-Modul

Socket, allgemein bekannt als Socket, ist eigentlich eine Kombination aus IP-Adresse und Port. Ähnlich wie bei dieser Form (IP, Port), wobei IP einen bestimmten Host und Port eine Anwendung darstellt, können wir über einen Socket mit einem anderen Host kommunizieren.

Die Analyse des Socket-Quellcodes befindet sich in der Tarnado-Artikelserie, die derzeit geschrieben wird. . . . .

1. Kommunikationsmethode

TCP-Kommunikation

UDP-Kommunikation

Unix-basierte Kommunikation

2. Socket-Methode

# 暂时知道的也就这么多,之后要是在用到其他的我会继续进行保存Methods of socket objects (keyword arguments not allowed):
    
    _accept() -- accept connection, returning new socket fd and client address
    bind(addr) -- bind the socket to a local address 给本地地址绑定一个socket套接字
    close() -- close the socket 关闭一个套接字
    connect(addr) -- connect the socket to a remote address     连接到远端主机
    connect_ex(addr) -- connect, return an error code instead of an exception
    dup() -- return a new socket fd duplicated from fileno()
    fileno() -- return underlying file descriptor
    getpeername() -- return remote address [*]
    getsockname() -- return local address
    getsockopt(level, optname[, buflen]) -- get socket options
    gettimeout() -- return timeout or None
    listen([n]) -- start listening for incoming connections
    recv(buflen[, flags]) -- receive data   接受数据
    recv_into(buffer[, nbytes[, flags]]) -- receive data (into a buffer)    接受数据到缓冲区中,
    recvfrom(buflen[, flags]) -- receive data and sender's address    recvfrom_into(buffer[, nbytes, [, flags])      -- receive data and sender's address (into a buffer)sendall(data[, flags]) -- send all data 发送数据给远端主机,3.x之后只能发送字节形式,因此在发送的时候一般要进行转换bytes
    send(data[, flags]) -- send data, may not send all of it 也是发送数据,区别在于send发送的不完整,随机进行发送的,二sendall发送的完整
    sendto(data[, flags], addr) -- send data to a given address 基于udp发送数据的
    setblocking(0 | 1) -- set or clear the blocking I/O flag    是否设置成阻塞模式0 代表阻塞,1代表非阻塞
    setsockopt(level, optname, value) -- set socket options     设置一些socket的桉树
    settimeout(None | float) -- set or clear the timeout    设置超时市场
    shutdown(how) -- shut down traffic in one or both directions    
    if_nameindex() -- return all network interface indices and names
    if_nametoindex(name) -- return the corresponding interface index
    if_indextoname(index) -- return the corresponding interface name
 
     [*] not available on all platforms!

2. Einfacher Chat-Roboter

Wenn Sie Daten senden, antwortet ihm der Server mit einem Daten-Hallo

 1 # -*- coding:utf-8 -*- 2 # zhou 3 # 2017/7/3 4  5 import socket 6 # 创建一个server对象 7 server_obj = socket.socket() 8 # 绑定一下端口 9 server_obj.bind(("127.0.0.1", 8888, ))10 # 设置监听的等待队列长度为5,当大于5的时候就拒绝连接11 server_obj.listen(5)12 13 while True:14     # 等待接受客户端的连接,为阻塞方式15     conn, address = server_obj.accept()16     # 发送欢迎信息17     conn.sendall(bytes("欢迎来到简单的聊天室..", encoding='utf-8'))18     while True:19         # 接受到对面的消息就会把对面消息后面加上你好重新发送回去20         ret = str(conn.recv(1024), encoding='utf-8')21         if ret == 'q':22             # 如果对面发送的为q就退出23             break24         conn.sendall(bytes(ret + ",你好", encoding='utf-8'))
Server
# -*- coding:utf-8 -*-# zhou# 2017/7/3import socket

client = socket.socket()
client.connect(("127.0.0.1", 8888, ))# 接受欢迎信息并打印ret = str(client.recv(1024), encoding='utf-8')print(ret)while True:
    message = input("请输入您要发送的内容:")
    client.sendall(bytes(message, encoding='utf-8'))if message == 'q':breakret = str(client.recv(1024), encoding='utf-8')print(ret)
Client

3. Einfacher FTP-Upload

Hochladen eines Bildes auf den Server implementiert

 1 # -*- coding:utf-8 -*- 2 # zhou 3 # 2017/7/2 4  5 import socket 6  7 server = socket.socket() 8 server.bind(("127.0.0.1", 9998, ))  # 绑定ip 9 server.listen(5)10 11 while True:12     conn, address = server.accept()13     # 连接之后首先接收文件大小14     file_size = int(str(conn.recv(1024), encoding='utf-8'))15     # 用来解决粘包问题的16     conn.sendall(bytes("1001", encoding='utf-8'))17     # 已经接受的文件大小18     has_size = 019     num = 120     # 连接之后接收文件21     f = open("new.jpg", 'wb')22     while True:23         num += 124         if file_size == has_size:25             break26         data = conn.recv(1024)27         f.write(data)28         has_size += len(data)29     f.close()   # 关闭文件
ftpserver

 1 # -*- coding:utf-8 -*- 2 # zhou 3 # 2017/7/2 4  5  6 import os 7 import socket 8  9 client = socket.socket()10 11 client.connect(("127.0.0.1", 9998), )12 # 传送文件大小13 file_size = os.stat("1.jpg").st_size14 print(file_size)15 # 发送文件大小16 client.sendall(bytes(str(file_size), encoding='utf-8'))17 client.recv(1024)   # 解决粘包问题18 # 发送文件19 with open("1.jpg", 'rb') as f:20     for line in f:21         client.sendall(line)22 client.close()
ftpclient

4. Lösung des Sticky-Problems

Bezüglich der Beschreibung des dritten FTP-Uploads oben:

Lösung des Sticky-Problems, wenn wir eine Datei hochladen, laden Sie zuerst deren Größe hoch Wir müssen eine Akzeptanzerklärung schreiben und der Server muss uns nach Erhalt der Dateigröße sofort Daten zur Bestätigung senden, damit wir die Daten perfekt aufteilen können.

 

Das obige ist der detaillierte Inhalt vonDetaillierte Einführung in Sockets in Python. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn