Cra*_*ech 5 python sockets python-3.x
我有上述问题。假设客户端要求提供文件名并将文件名发送到服务器,然后服务器将打开文件并显示它。问题是服务器没有打开文件并显示它。
下面是客户端。
#!/usr/bin/env python3
import socket, os.path, datetime, sys
def Main():
host = '127.0.0.1'
port = 50001
s = socket.socket()
s.connect((host, port))
Filename = input("Type in ur file ")
s.send(Filename.encode('utf-8'))
data = s.recv(1024).decode('utf-8')
s.close()
if __name__ == '__main__':
Main()
Run Code Online (Sandbox Code Playgroud)
下面是服务器
#!/usr/bin/env python3
import socket
import os
import sys
def Main():
host = '127.0.0.1'
port = 50001
s = socket.socket()
s.bind((host,port))
print("server Started")
s.listen(1)
c, addr = s.accept()
print("Connection from: " + str(addr))
while True:
data = c.recv(1024).decode('utf-8')
myfile = open(data, "r")
if not data:
break
print("from connected user: " + myfile)
c.close()
if __name__ == '__main__':
Main()
Run Code Online (Sandbox Code Playgroud)
我对它运行的代码做了一些最小的调整,以便server.py连续监听给定的端口并发送回每次调用所要求的数据client.py。
服务器.py
#!/usr/bin/env python3
import socket
import os
import sys
def Main():
host = '127.0.0.1'
port = 50001
s = socket.socket()
s.bind((host,port))
print("server Started")
s.listen(1)
while True:
c, addr = s.accept()
print("Connection from: " + str(addr))
filename = ''
while True:
data = c.recv(1024).decode('utf-8')
if not data:
break
filename += data
print("from connected user: " + filename)
myfile = open(filename, "rb")
c.send(myfile.read())
c.close()
if __name__ == '__main__':
Main()
Run Code Online (Sandbox Code Playgroud)
客户端.py
#!/usr/bin/env python3
import socket, os.path, datetime, sys
def Main():
host = '127.0.0.1'
port = 50001
s = socket.socket()
s.connect((host, port))
Filename = input("Type in ur file ")
s.send(Filename.encode('utf-8'))
s.shutdown(socket.SHUT_WR)
data = s.recv(1024).decode('utf-8')
print(data)
s.close()
if __name__ == '__main__':
Main()
Run Code Online (Sandbox Code Playgroud)
现在做一些解释。
在服务器端。外循环接受一个连接,然后从该连接中读取数据直到完成(稍后会详细介绍)。打印您的调试信息,但请注意您正在尝试print文件对象而不是文件名(尝试连接会失败)。我还以二进制模式打开文件(这样我可以跳过str->bytes翻译。
在客户端。我添加了在发送文件后关闭套接字的写入端。请注意,您可能希望使用sendall而不是send用于此用例:检查这些文档链接以获取详细信息。我print为传入数据添加了一个。
现在,关闭客户端中的写入端和内部循环读取(也与提示相关sendall。顺便说一句,这也适用于服务器端,否则您应该循环,因为您可能会看到内容被截断;其他选项也是有一个发送循环。)。流套接字将保证您按照发送字节的顺序获取字节。它本身不知道您的消息是否完整,也不能保证发送和接收数据的数量和大小。
服务器的内部循环继续读取,直到我们看到EOF(我们在 python 中收到零长度字符串socket)。recv这种情况会发生(当远程套接字(或至少其写入端)关闭时返回。由于我们仍然想重用连接,因此我们只在客户端的发送端执行此操作。希望这可以帮助您前进。
| 归档时间: |
|
| 查看次数: |
8302 次 |
| 最近记录: |