网络编程之socket

时间:2024-01-21 11:01:47
网络编程之socket
socket:在网络编程中的一个基本组件,也称套接字。
一个套接字就是socket模块中的socket类的一个实例。
套接字包括两个:
  服务器套接字和客户机套接字
套接字的实例化需要3个参数:
  1.地址簇:socket.AF_INET
  2. 流:socket.SOCK_STREAM
  3.使用的协议: 默认为0
服务器套接字:以下简称socket_server
客户端套接字:以下简称socket_client
地址:address=('127.0.0.1',8000)
socket_server使用bind方法绑定address,再调用listen方法去监听,控制排队等候连接的最大数
socket_client使用connect方法连接到服务器,使用的地址与服务器bind的地址相同
套接字有两个方法:
  send(1024) #发送数据,每次最多发送1024bytes
  recv(1024) #接收数据,每次最多接收1024bytes
sk = socket.socket()
sk的方法:
  sk.bind(address)
    s.bind(address) 将套接字绑定到地址。address地址的格式取决于地址族。在AF_INET下,以元组(host,port)的形式表示地址。   sk.listen(backlog)
    监听传入连接,backlog指定在拒绝连接之前,可以挂起等待的连接数
    backlog需要在内核中维护连接队列,所以该值不能过大
  sk.accept()
    接受连接并返回(conn,address),其中conn是新的套接字对象,可以用来接收和发送数据。address是连接客户端的地址。
    接收TCP 客户的连接(阻塞式)等待连接的到来
  sk.connect(address)
    连接到address处的套接字。一般,address的格式为元组(hostname,port),如果连接出错,返回socket.error错误。
  sk.connect_ex(address)
    同上,只不过会有返回值,连接成功时返回 0 ,连接失败时候返回编码,例如:10061   sk.close()
    关闭套接字
  
**python库相关参考文档地址:http:python.org/doc/lib/module_socket.html
*****简单的套接字交互*****
server端:
import socket
# #family type
sk=socket.socket()
print(sk)
address=('127.0.0.1',8000)
sk.bind(address)
sk.listen(3)
print('waiting......') while 1:
conn, addr = sk.accept()
print(addr)
while 1:
try:
data = conn.recv(1024)
except Exception:
break
if not data: break
print('.........', str(data, 'utf8'))
inp=input('>>>')
conn.send(bytes(inp,'utf8')) sk.close() client端:
import socket sk=socket.socket()
print(sk) address=('127.0.0.1',8000)
sk.connect(address) while True:
inp=input('>>>')
if inp == 'exit':
break
sk.send(bytes(inp,'utf8'))
data=sk.recv(1024)
print(str(data,'utf8'))
sk.close() *****在client端输入shell命令,在服务器端执行命令后,返回结果*****
server端:
import subprocess
import socket
# #family type
sk=socket.socket()
print(sk)
address=('127.0.0.1',8000)
sk.bind(address)
sk.listen(3)
print('waiting......') while 1:
conn, addr = sk.accept()
print(addr)
while 1:
try:
data = conn.recv(1024)
except Exception:
break
if not data: break
print('.........', str(data, 'utf8')) obj=subprocess.Popen(data.decode('utf8'),shell=True,stdout=subprocess.PIPE)
cmd_result=obj.stdout.read() result_len=bytes(str(len(cmd_result)),'utf8')
print('>>>>>>',result_len)
conn.sendall(result_len)#粘包现象 1600 conn.recv(1024)#解决粘包 conn.sendall(cmd_result) sk.close() client端:
import subprocess
import socket
# #family type
sk=socket.socket()
print(sk)
address=('127.0.0.1',8000)
sk.bind(address)
sk.listen(3)
print('waiting......') while 1:
conn, addr = sk.accept()
print(addr)
while 1:
try:
data = conn.recv(1024)
except Exception:
break
if not data: break
print('.........', str(data, 'utf8')) obj=subprocess.Popen(data.decode('utf8'),shell=True,stdout=subprocess.PIPE)
cmd_result=obj.stdout.read() result_len=bytes(str(len(cmd_result)),'utf8')
print('>>>>>>',result_len)
conn.sendall(result_len)#粘包现象 1600 conn.recv(1024)#解决粘包 conn.sendall(cmd_result) sk.close() *****ftp*****
server端: import subprocess
import socket
# #family type
import os
sk=socket.socket()
print(sk)
address=('127.0.0.1',8000)
sk.bind(address)
sk.listen(3)
print('waiting......')
BASE_DIR=os.path.dirname(os.path.abspath(__file__)) while 1:
conn, addr = sk.accept()
while 1:
data=conn.recv(1024)
cmd,filename,filesize=str(data,'utf8').split('|')
path=os.path.join(BASE_DIR,'yuan',filename)
filesize=int(filesize) f=open(path,'ab') has_receive=0
while has_receive!=filesize:
data=conn.recv(1024)
f.write(data)
has_receive+=len(data) f.close() client端: import socket
import os
sk=socket.socket()
print(sk) address=('127.0.0.1',8000)
sk.connect(address) BASE_DIR=os.path.dirname(os.path.abspath(__file__)) while True:
inp=input('>>>').strip()# post|11.png cmd,path=inp.split('|') path=os.path.join(BASE_DIR,path)
filename=os.path.basename(path)
file_size=os.stat(path).st_size file_info='post|%s|%s'%(filename,file_size) sk.sendall(bytes(file_info,'utf8')) f=open(path,'rb') has_sent=0
while has_sent!=file_size:
data=f.read(1024)
sk.sendall(data)
has_sent+=len(data) f.close()
print('上传成功')