有个需求,就是在windows上看见一篇介绍linux相关的文章,想在局域网内的另外一台linux电脑上尝试一下,

于是就需要把该网页链接发送给linux,不想一点一点敲链接,又苦于没有找到其它好的方法。

想起之前学习计算机网络时了解到的socket,于是再次打开课本,代码(python3)如下:

客户端(windows)代码:


# 局域网内的windows客户端
from socket import *        #导入socket里的所有东西
serverName = '127.0.0.1'    #换成局域网内服务器端IP即可实现局域网内通信
serverPort = 12001            #服务器端口,除了已知的被占用端口都可,一般建议10000-65535
clientSocket = socket(AF_INET,SOCK_DGRAM)    #UDP连接
#ipv4 udp
while 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 = 12001
serverSocket = 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之类!(这一点对于小白来讲怎样强调都不为过,虽然我之前知道也这一点,但是这次在运行该代码时,再次犯了这样的错误,找原因也浪费了挺长时间,最后想起是防火墙的原因又懊恼不已,怀着悲伤的心情写下了这个小结)