用scala实现一个基于TCP Socket的快速文件传输程序
这是用scala实现的一个简单的文件传输程序。
服务端
package jpush import java.io.{DataInputStream, File, FileOutputStream} import java.net.ServerSocket import scala.collection.JavaConversions._ /** * Created by dingb on 2016/6/3. */ object Server extends App { def port = 8899 override def main(args: Array[String]) { val roots = args.toList match { case Nil => List(new File(System.getProperty("user.dir"))) case _ => args.map(new File(_)).toList } printf("dst root is %s\n", roots.mkString(",")) val ss = new ServerSocket(port) def accept: Unit = { val s = ss.accept() printf("%s in \n", s.getRemoteSocketAddress); async { val dis = new DataInputStream(s.getInputStream) val fn = dis.readUTF val size = dis.readLong printf("loading %s %d\n", fn, size); if(size > 0) { roots.foreach(new File(_, fn).getParentFile.mkdirs()) val oses = roots.map(new File(_, fn)).map(new FileOutputStream(_)) val buf = new Array[Byte](1024) var done = false while(!done) { val r = dis.read(buf) if(r <= 0) done = true else oses.foreach(_.write(buf, 0, r)) } oses.foreach(_.close) } } accept } accept } def async(body : => Unit) = { val t = new Thread(new Runnable { override def run(): Unit = { body } }) t.start() } }
客户端
package jpush import java.io.{DataOutputStream, File, FileInputStream} import java.net.Socket /** * Created by dingb on 2016/6/3. */ object Client extends App{ def send_file(ip: String, file: File, top: String): Unit = { val fis = new FileInputStream(file) val s = new Socket(ip, Server.port) val dos = new DataOutputStream(s.getOutputStream) val remotename = top + File.separator + file.getName printf("sending %d bytes %s to %s\n", file.length(), file.getAbsolutePath, remotename) dos.writeUTF(remotename) dos.writeLong(file.length()) val buf = new Array[Byte](1024) var done = false while(!done) { val r = fis.read(buf) if(r <= 0) done = true else dos.write(buf, 0, r) } dos.close() fis.close() s.close() } def send(ip: String, file: File, top: String): Unit = { if(file.isDirectory) file.listFiles().foreach(send(ip, _, "" + File.separator + file.getName)) else send_file(ip, file, top) } override def main(args: Array[String]) { if(args.length < 1) usage() else args.drop(1).map(new File(_)).foreach(send(args(0), _, "")) } def usage(): Unit = { println("usage: jpsh.Client <ip> [file]...") System.exit(-1) } }
源代码下载
https://github.com/dingbig/jpush
用scala实现一个基于TCP Socket的快速文件传输程序的更多相关文章
- 标准C实现基于TCP/IP协议的文件传输
上学期集成程序设计的课堂作业,对于理解TCP/IP实现还是挺有帮助的. TCP/IP编程实现远程文件传输在LUNIX中一般都采用套接字(socket)系统调用. 采用客户/服务器模式,其程序编写步骤如 ...
- 标准C语言实现基于TCP/IP协议的文件传输
TCP/IP编程实现远程文件传输在LUNIX中一般都采用套接字(socket)系统调用. 采用客户/服务器模式,其程序编写步骤如下: 1.Socket系统调用 为了进行网络I/O,服务器和客户机两 ...
- 基于TCP协议的大文件传输(粘包问题处理)
基于TCP的大文件上传服务端实现 # 服务端 # -*- coding: utf-8 -*- from socket import * import json, struct server = soc ...
- python基于并发与socket实现远程文件传输程序
FTP程序 Client: * bin/start.py 程序入口 * conf/配置文件存放 * core/ * auth.py 登陆,注册以及上传下载查看当前文件夹下文件以及删除功能存放 * cl ...
- 写一个基于TCP协议套接字,服务端实现接收客户端的连接并发
''' 写一个基于TCP协议套接字,服务端实现接收客户端的连接并发 ''' client import socket import time client = socket.socket() clie ...
- [网络编程之Socket套接字介绍,套接字工作流程,基于TCP协议的套接字程序]
[网络编程之Socket套接字介绍,套接字工作流程,基于TCP协议的套接字程序] 为何学习socket套接字一定要先学习互联网协议: 1.首先:要想开发一款自己的C/S架构软件,就必须掌握socket ...
- 10.17小作业 基于TCP开发一款远程CMD程序
基于TCP开发一款远程CMD程序 客户端连接服务器后,可以向服务器发送命令 服务器收到命令后执行,无论执行是否成功,无论执行几遍,都将执行结果返回给客户端 注意: 执行系统指令使用subprocess ...
- python基础--基于套接字进行文件传输、异常处理、socketserver模块
异常处理: 什么是异常处理: 程序在运行过程中出现了不可预知的错误,并且该错误没有对应的处理机制,那么就会以异常的形式表现出来,造成的影响就是整个程序无法再正常运行 异常的结构: 异常的类型.异常的信 ...
- 利用Socket进行大文件传输
分类: WINDOWS 最近接触到利用socket进行大文件传输的技术,有些心得,与大家分享.首先看看这个过程是怎么进行的(如下图): 所以,我们需要三个socket在窗体加载的时候初始化: ...
随机推荐
- css 内联与块
内联元素可以理解为不能直接设置宽度和高度元素,比如span,你为他设置宽度和高度没有效果,除非你把它设置成块级元素. 如下面的代码把display:block;属性值去掉的话,宽度和高度都不会起作用了 ...
- winxp iis5中修改最大连接数及添加多个站点
winxp iis5中修改最大连接数及添加多个站点 最 近用asp做一些东西,需要用到iis,还需要用photoshop做一些图片.以前都是在win2003下面做,可是photoshop里面很多中文字 ...
- 关于svn的安装问题
直接把安装包放在 MyEclipse的安装目录下 如果 报错 那么就重装MyEclipse 半个小时左右就OK了不然调错太浪费时间了
- 转 Goldengate常用命令
1.Goldengate的起停 启动goldengate a> 启动goldengate时最好先从target节点开始,然后是source节点.否则data pump进程可能会由于没有收到t ...
- FACE++学习一、detect接口
/detection/detect 描述 检测给定图片(Image)中的所有人脸(Face)的位置和相应的面部属性 目前面部属性包括性别(gender), 年龄(age), 种族(race), 微笑程 ...
- Sping中的IOC四种注解的简单记录
@Component 通用注解,不推荐使用,要用的话,任何类的头上都能使用,但是这个类到底是干嘛用得就不知道了. @Controller 控制层使用,也就是MVC中的C,主要的时候使用的时候注意配合@ ...
- highcharts 去掉打印和链接
1)去掉或更改图片右下角的链接 在highcharts.js文件中搜索credits字符串,找到如下的字符串, enabled:设置是否显示链接 text:设置链接显示的名称 href:设置链接的ur ...
- python第三方扩展库及不同类型的测试需安装相对应的第三方库总结
如何安装第三方库 1.通过python的第三方仓库pypi中查找想要的第三方库 pypi地址:https://pypi.python.org/pypi pip是一个安装和管理Python包的工具,通过 ...
- Polipo
polipo代理服务器简介 HTTP代理polipo的配置与使用:http://wuwei5460.blog.51cto.com/2893867/1407369/
- 【安卓手机通用】android adb shell 命令大全
浏览:3116 | 更新:2013-10-17 17:05 | 标签:安卓 android 一.[什么是shell] Linux系统的shell作为操作系统的外壳,为用户提供使用操作系统的接口.它是命 ...