用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在窗体加载的时候初始化: ...
随机推荐
- 我也谈javascript闭包
1.什么是闭包呢?Whenever you see the function keyword within another function, the inner function has acces ...
- gdb 远程调试android进程 -转
什么是gdb 它是gnu组织开发的一个强大的unix程序调试工具,我们可以用它来调试Android上的C.C++代码. 它主要可以做4件事情: 随心所欲地启动你的程序. 设置断点,程序执行到断点处会停 ...
- CodeForces 139C Literature Lesson(模拟)
这个题,读懂了就是水,读不懂就没办法下手,论英语阅读的重要性...只有五种形式,第一种万能型aaaa,是另外3种的特殊情况,第二种克莱里林四行打油诗aabb形式,第三种是交替的abab形式,第四种是封 ...
- Hadoop webHDFS设置和使用说明
1.配置 namenode的hdfs-site.xml是必须将dfs.webhdfs.enabled属性设置为true,否则就不能使用webhdfs的LISTSTATUS.LISTFILESTATUS ...
- HttpClient 教程 (二)
第二章 连接管理 HttpClient有一个对连接初始化和终止,还有在活动连接上I/O操作的完整控制.而连接操作的很多方面可以使用一些参数来控制. 2.1 连接参数 这些参数可以影响连接操作: 'ht ...
- web项目编译出错时,原因之一,可能是build path 中order and Export引起
build path中的order and Export,如果两个libarary中有相同功能的jar包,则编译器会选择顺序在前的jar包中相应的类作为编译所需. 所以,当项目jar包较多的时候,如果 ...
- Ubuntu和win10双系统Grup无法引导解决方案
通常我们经常安装双系统, 但是有时候安装完系统无法正常引导, 以下就说明Ubuntu和win10双系统, win10在grub界面不断循环的解决方案 直接在win10启动项目上按e进入编辑模式 在文档 ...
- Docker Swarm集群
Docker Swarm集群 IP 10.6.17.11 管理节点 IP 10.6.17.12 节点A IP 10.6.17.13 节点B IP 10.6.17.14 节点C 安装 Sw ...
- 模块之dir函数
dir()函数你可以使用内建的dir函数来列出模块定义的标识符.标识符有函数.类和变量.当你为dir()提供一个模块名的时候,它返回模块定义的名称列表.如果不提供参数,它返回当前模块中定义的名称列表. ...
- Linux下Nginx、PHP、MySQL、Redis开机自启动设置
一.Nginx开机启动设置 1.在/etc/init.d/目录下创建脚本 vi /etc/init.d/nginx 2.更改脚本权限 chmod 775 /etc/init.d/nginx 3.编写脚 ...