客户端如果直接send两次,一次发文件名,一次发文件内容

服务端接受的时候会一起接收,不知怎么分开发送,或者分开接收, 或者全部接收再解析内容

今天发现传送mp3文件的时候没问题,传送文本文件的话,以前标题和内容就黏糊一块了,今天似乎也没事,搞不懂

1.文件服务端(fileServer.py):

 import sys, os, threading, socket
 from PyQt4 import QtGui, QtCore

 class ListenThread(threading.Thread):
     """监听线程"""
     def __init__(self, server, txt):
         super(ListenThread, self).__init__()
         self.server = server
         self.txt = txt
         self.files = ['FileServer.py']
     def run(self):
         while 1:
             # try:
                 self.client, addr = self.server.accept()
                 self.txt.append('连接来自{}:{}\n'.format(addr[0], addr[1]))
                 data = self.client.recv(1024).decode('utf-8')
                 self.txt.append('收到文件:{}\n'.format(data))
                 file = os.open('D:/'+data[:3], os.O_WRONLY | os.O_CREAT | os.O_EXCL | os.O_BINARY)
                 rdata = self.client.recv(1024)
                 while rdata:
                     os.write(file, rdata)
                     rdata = self.client.recv(1024)
                 os.close(file)
                 self.client.close()
                 self.txt.append('文件接受完成,客户端关闭\n')
             # except:
                 # pass
                 # self.txt.append('连接关闭\n')
                 # break##############

 class ControlThread(threading.Thread):
     """控制线程"""
     def __init__(self, txt):
         super(ControlThread, self).__init__()
         self.txt = txt
         self.event = threading.Event()
         self.event.clear()
     def run(self):
         self.server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
         self.server.bind(('', 1051))
         self.server.listen(1)
         self.txt.append('正在等待连接。。。\n')
         self.lsn = ListenThread(self.server, self.txt)
         self.lsn.setDaemon(True)
         self.lsn.start()
         self.event.wait()
         self.server.close()
     def stop(self):
         self.event.set()
 class MyWindow(QtGui.QWidget):
     def __init__(self):
         super(MyWindow, self).__init__()
         self.setWindowTitle('文件服务器')
         self.resize(485, 300)

         self.btn1 = QtGui.QPushButton('开始监听')
         self.btn2 = QtGui.QPushButton('结束监听')
         self.txt = QtGui.QTextEdit()

         grid = QtGui.QGridLayout()
         grid.addWidget(self.btn1, 0, 0)
         grid.addWidget(self.btn2, 0, 1)
         grid.addWidget(self.txt, 1, 0, 1, 2)
         self.setLayout(grid)

         self.connect(self.btn1, QtCore.SIGNAL('clicked()'), self.onBtn1)
         self.connect(self.btn2, QtCore.SIGNAL('clicked()'), self.onBtn2)
     def onBtn1(self):
         self.ctrl = ControlThread(self.txt)
         self.ctrl.setDaemon(True)
         self.ctrl.start()
     def onBtn2(self):
         self.ctrl.stop()

 app = QtGui.QApplication(sys.argv)
 mywindow = MyWindow()
 mywindow.show()
 app.exec_()

2.文件客户端(fileClient.py):

 import sys, os, socket
 from PyQt4 import QtGui, QtCore

 class MyWindow(QtGui.QWidget):
     def __init__(self):
         super(MyWindow, self).__init__()
         self.setWindowTitle('文件客户端')
         self.resize(485, 300)

         self.lblIp = QtGui.QLabel('IP')
         self.lblPort = QtGui.QLabel('Port')
         self.lblFile = QtGui.QLabel('File')
         self.txtIp = QtGui.QLineEdit('127.0.0.1')
         self.txtPort = QtGui.QLineEdit(')
         self.txtFile = QtGui.QLineEdit()
         self.btnBrowse = QtGui.QPushButton('浏览')
         self.btnSend = QtGui.QPushButton('发送')
         self.btnSend.setMaximumWidth(150)

         grid = QtGui.QGridLayout()
         grid.addWidget(self.lblIp, 0, 0)
         grid.addWidget(self.lblPort, 1, 0)
         grid.addWidget(self.lblFile, 2, 0)
         grid.addWidget(self.txtIp, 0, 1)
         grid.addWidget(self.txtPort, 1, 1)
         grid.addWidget(self.txtFile, 2, 1)
         grid.addWidget(self.btnBrowse, 2, 2)
         grid.addWidget(self.btnSend, 3, 1)
         self.setLayout(grid)

         self.connect(self.btnBrowse, QtCore.SIGNAL('clicked()'), self.onBtnBrowse)
         self.connect(self.btnSend, QtCore.SIGNAL('clicked()'), self.onBtnSend)
     def onBtnBrowse(self):
         filename = QtGui.QFileDialog.getOpenFileName(self, '打开文件', filter='全部文件(*.*)')
         if filename:
             self.txtFile.setText(filename)

     def onBtnSend(self):
         # try:
             ip = self.txtIp.text()
             port = self.txtPort.text()
             filename = self.txtFile.text()
             name = filename.split('/')[-1]
             client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
             client.connect((ip, int(port)))
             client.send(name.encode('utf-8'))
             file = os.open(filename, os.O_RDONLY | os.O_EXCL | os.O_BINARY)
             data = os.read(file, filename)
             while data:
                 client.send(data)
                 data = os.read(file, 1024)
             os.close(file)
             client.close()
         # except:
             # pass
             # print('发送错误!')
 app = QtGui.QApplication(sys.argv)
 mywindow = MyWindow()
 mywindow.show()
 app.exec_()

Python -- 网络编程 -- Socket发送文件的更多相关文章

  1. python网络编程-socket发送大数据包问题

    一:什么是socket大数据包发送问题 socket服务器端或者客户端在向对方发送的数据大于对方接受的缓存时,会出现第二次接受还接到上次命令发送的结果.这就出现象第一次接受结果不全,第二次接果出现第一 ...

  2. Day07 - Python 网络编程 Socket

    1. Python 网络编程 Python 提供了两个级别访问网络服务: 低级别的网络服务支持基本的 Socket,它提供了标准的 BSD Sockets API,可以访问底层操作系统Socket接口 ...

  3. Python网络编程socket

    网络编程之socket 看到本篇文章的题目是不是很疑惑,what is this?,不要着急,但是记住一说网络编程,你就想socket,socket是实现网络编程的工具,那么什么是socket,什么是 ...

  4. python网络编程-socket“粘包”(小数据发送问题)

    一:什么是粘包 “粘包”, 即服务器端你调用时send 2次,但你send调用时,数据其实并没有立刻被发送给客户端,而是放到了系统的socket发送缓冲区里,等缓冲区满了.或者数据等待超时了,数据才会 ...

  5. python网络编程-socket编程

     一.服务端和客户端 BS架构 (腾讯通软件:server+client) CS架构 (web网站) C/S架构与socket的关系: 我们学习socket就是为了完成C/S架构的开发 二.OSI七层 ...

  6. python网络编程socket /socketserver

    提起网络编程,不同于web编程,它主要是C/S架构,也就是服务器.客户端结构的.对于初学者而言,最需要理解的不是网络的概念,而是python对于网络编程都提供了些什么模块和功能.不同于计算机发展的初级 ...

  7. Day8 - Python网络编程 Socket编程

    Python之路,Day8 - Socket编程进阶   本节内容: Socket语法及相关 SocketServer实现多并发 Socket语法及相关 socket概念 socket本质上就是在2台 ...

  8. python --- 网络编程Socket

    网络编程 定义:所为网络编程即是对信息的发送和接收. 主要工作: (1)发送端:将信息以规定的协议组装成数据包. (2)接收端:对收到的数据包解析,以提取所需要的信息. Socket:两个在网络上的程 ...

  9. Day10 Python网络编程 Socket编程

    一.客户端/服务器架构 1.C/S架构,包括: 1.硬件C/S架构(打印机) 2.软件C/S架构(web服务)[QQ,SSH,MySQL,FTP] 2.C/S架构与socket的关系: 我们学习soc ...

随机推荐

  1. Java(Android)线程池[转]

    介绍new Thread的弊端及Java四种线程池的使用,对Android同样适用.本文是基础篇,后面会分享下线程池一些高级功能. 1.new Thread的弊端执行一个异步任务你还只是如下new T ...

  2. 【翻译】使用Vuex解决Vue中的身份验证

    翻译原文链接:https://scotch.io/tutorials/handling-authentication-in-vue-using-vuex 我的翻译小站:https://www.zcfy ...

  3. [转载]HTML5游戏前端开发秘籍

    http://isux.tencent.com/html5-game-development-cheats.html 转载至腾讯ISUX HTML5游戏前端开发秘籍 本文由米随随编写 QQ空间Andr ...

  4. MySQL常用功能语句分类总结

    C(创建型功能) 创建数据库:CREATE DATABASE 创建用户:CREATE USER 用户名@主机 IDENTIFIED BY 密码; -- 如果想让该用户可以从任意远程主机登陆,可以使用通 ...

  5. NET平台开源项目速览(6)FluentValidation验证组件介绍与入门(转载)

    原文地址:http://www.cnblogs.com/asxinyu/p/dotnet_Opensource_project_FluentValidation_1.html 阅读目录 1.基本介绍 ...

  6. ThinkPad T430i,如何将WIN8换成WIN7???

    1. 启动时不断点击键盘上的F1键,进入BIOS 界面选择“Restart”→把 “OS Optimized Default”设置为 “disabled” ,(OS Optimized Default ...

  7. VSTS 更名为 Azure DevOps

    微软正式对外宣布Azure DevOps,其实就是原来的VSTS,我们来看一下Azure DevOps的介绍: 今天我们宣布Azure DevOps.与世界各地的客户和开发人员合作,很明显,DevOp ...

  8. INDEX--创建索引和删除索引时的SCH_M锁

    最近有一个困惑,生产服务器上有一表索引建得乱七八糟,经过整理后需要新建几个索引,再删除几个索引,建立索引时使用联机(ONLINE=ON)创建,查看下服务器负载(磁盘和CPU压力均比较低的情况)后就选择 ...

  9. 3D空间中射线与轴向包围盒AABB的交叉检测算法【转】

    引言 在上一节中,我讲述了如何实现射线与三角形的交叉检测算法.但是,我们应该知道,在游戏开发中,一个模型有很多的三角形构成,如果要对所有的物体,所有的三角形进行这种检测,就算现在的计算机运算能力,也是 ...

  10. select * 和 select 所有字段写出来 ,速度对比!

    从很早时候,听老师说 select * from table  比 select a,b,c,d from table 要慢很多.3年来从未测试.  今天没事测一测, 不测不知道,一测吓一跳. 当然 ...