有个需求,就是在windows上看见一篇介绍linux相关的文章,想在局域网内的另外一台linux电脑上尝试一下,
于是就需要把该网页链接发送给linux,不想一点一点敲链接,又苦于没有找到其它好的方法。
想起之前学习计算机网络时了解到的socket,于是再次打开课本,代码(python3)如下:
客户端(windows)代码:
# 局域网内的windows客户端from socket import * #导入socket里的所有东西serverName = '127.0.0.1' #换成局域网内服务器端IP即可实现局域网内通信serverPort = 12001 #服务器端口,除了已知的被占用端口都可,一般建议10000-65535clientSocket = socket(AF_INET,SOCK_DGRAM) #UDP连接#ipv4 udpwhile True: message = input('please input: \n') if (message == '0'): #输入0时结束发送 break clientSocket.sendto(message.encode(),(serverName,serverPort)) #向服务器发送消息,使用socket时,只能以字节形式传送,故需要encode() reply,serverAddress = clientSocket.recvfrom(2048) #接收服务器返回的消息和地址 print (reply)clientSocket.close() #关闭连接
服务器端(linux)代码:
# 如果是局域网内的linux作为服务器端执行该代码,注意先关闭防火墙from socket import *serverPort = 12001serverSocket = socket(AF_INET,SOCK_DGRAM)serverSocket.bind(('',serverPort)) #注意bind方法括号内为一个元组,引号默认表示为127.0.0.1,即监听本地端口print('ready')while True: message,clientAddress = serverSocket.recvfrom(2048) #接收客户端发来的消息 print(message) serverSocket.sendto('have received'.encode(),clientAddress) #使用socket时,只能以字节形式传送,故需要encode()
上述代码参考《计算机网络自顶向下方法》,代码很简洁,而且基本上能满足需求。
值得强调的一点是,在实现上述代码时,建议先在本机(即在windows上跑上面两个脚本),成功了以后再把serverName从'127.0.0.1' 变为 '局域网内服务器端IP'。
而且在linux端实现服务器端代码时,一定要先关闭防火墙!凡是涉及到局域网内linux与其它主机通信的都要考虑防火墙的问题,比如ftp之类!(这一点对于小白来讲怎样强调都不为过,虽然我之前知道也这一点,但是这次在运行该代码时,再次犯了这样的错误,找原因也浪费了挺长时间,最后想起是防火墙的原因又懊恼不已,怀着悲伤的心情写下了这个小结)