【代码笔记】Java深入学习——实现客户端发送文件到服务器的文件传输
- Server.java
package com.huaxin.lesson02; import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.ObjectInputStream;
import java.net.ServerSocket;
import java.net.Socket;
/**
* @thing 实现客户端发送文件到服务器
* @thing 客户端发送到客户端(本代码未实现)
* @author Administrator
*
*/ public class Severs {
public static void main(String[] args) {
new Severs().initServer();
} public void initServer() {
try {
ServerSocket sSocket = new ServerSocket(9191);
System.out.println("服务器创建成功!");
Socket socket = sSocket.accept();
System.out.println("有客户端链接成功!");
//准备两个流:文件输出流,socket输入流
InputStream ins = socket.getInputStream();
//将客户端上传的文件存到服务器里面
ObjectInputStream ois = new ObjectInputStream(ins);
FileOutputStream fos = new FileOutputStream("C:\\Users\\Administrator\\Desktop\\临时文档\\test\\2016毕晚策划4月19(1).doc");
System.out.println("开始读取文件……"); //1.读取的数组长度
int lenght = ois.readInt();
//2.读取次数
long times = ois.readLong();
//3.读取最后一次字节长度
int lastBytes = ois.readInt();
byte[] bytes = new byte[lenght];
// ois.read(bytes);
/**和read相比,都是读一个字节数组
* read不一定能读完2048个字节里面的全部字节,会继续往下走
* readFully是通信里面才用到的函数,将会判断流里面还有没有字节剩余
* 有一种情况,会在字节数组里面没有将全部字节传送到位,而阻塞在网络上,或者阻塞到发送端的网卡上
* readFully方法,会等大byte数组中所有数据全部读取完毕后,继续往下执行
* read方法,会检测流中是否还有剩余字节,如果没有,则会继续往下执行
*
**/
//循环读取文件
while(times > 1){
ois.readFully(bytes);
fos.write(bytes);
fos.flush();
times -- ;
}
//处理最后一次字节数组
bytes = new byte[lastBytes];
ois.readFully(bytes);
fos.write(bytes);
fos.flush(); // //即将读取的文件字节数
// long fileSize = ois.readLong();
// System.out.println(fileSize);
//
// int value = ins.read();
// while(fileSize > 0){
// fileSize--;
// fos.write(value);
// fos.flush();
// value = ins.read();
// }
System.out.println("文件接收完毕!已保存到服务器。");
ois.close();
fos.close();
socket.close();
} catch (Exception e) {
e.printStackTrace();
}
} }- Client.java
package com.huaxin.lesson02; import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.ObjectOutputStream;
import java.io.OutputStream;
import java.net.Socket; import org.omg.CORBA.portable.InputStream; public class Client {
public int val = 2048;
public static void main(String[] args) {
new Client().initClient();
} public void initClient() {
try {
Socket socket = new Socket("localhost",9191);
//准备两个流,文件输入流,socket输入流
//本地的输入流
FileInputStream fis = new FileInputStream("C:\\Users\\Administrator\\Desktop\\临时文档\\test\\2016毕晚策划4月19.doc");
//把本地的输入流发出去
OutputStream ous = socket.getOutputStream();
ObjectOutputStream oos = new ObjectOutputStream(ous); System.out.println("开始读发送文件……!");
//先获取文件大小
File file = new File("C:\\Users\\Administrator\\Desktop\\临时文档\\test\\2016毕晚策划4月19.doc");
long fileSize = file.length();
byte[] bytes = new byte[val]; //算出即将发送字节数组的字数
long times = fileSize/val+1;
//算出最后一组字节数组的有效字节数
int lastBytes = (int)fileSize%2048;
//1.发送字节数组长度
oos.writeInt(val);
//2.发送次数
oos.writeLong(times);
oos.flush();
//3.最后一次字节个数
oos.writeInt(lastBytes);
oos.flush(); //读取字节数组长度的字节,返回读取字节数中的数据个数
int value = fis.read(bytes);
while(value != -1){
//偏移字节数读取
oos.write(bytes,0,value);
oos.flush();
value = fis.read(bytes);
} // oos.writeLong(fileSize);
// oos.flush();
// System.out.println(fileSize);
//// ous.write((int)fileSize);
//// ous.flush();
//// System.out.println(fileSize);
//// Thread.sleep(2000);
//
// //读取文件中的字节数据
// int value = fis.read();
// while(value != -1){
// ous.write(value);
// ous.flush();
// value = fis.read();
// }
System.out.println("文件发送完毕!");
Thread.sleep(2000);
//关闭流
fis.close();
ous.close();
socket.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}- 笔记都在代码里面
【代码笔记】Java深入学习——实现客户端发送文件到服务器的文件传输的更多相关文章
- 编写Java程序,实现客户端向服务端上传文件的功能
查看本章节 查看作业目录 需求说明: 实现客户端向服务端上传文件的功能 当启动服务端后,运行客户端程序,系统提示客户在客户端输入上传文件的完整路径.当客户在客户端输入完成后,服务端实现文件上传 实现思 ...
- [笨木头FireFly 02]入门篇2_客户端发送请求,服务器处理请求
原地址:http://www.9miao.com/question-15-53940.html 好,经过上一篇不权威的讲解,大家已经能轻易地让客户端和服务端连接起来了. 但是,仅仅是连接了,可它们俩不 ...
- 集合总结(全是代码)----------java基础学习
前言:在刚学习的时候,切记不能粘贴复制,更不能眼高手低,再简单的代码,都要自己独立动手写. 第一步:目录结构 第二步:代码区 Student.java:(一个学生的实体类) package com.m ...
- 学习笔记:oracle学习一:oracle11g体系结构之服务器结构、数据字典
目录 1.服务器架构 1.1 系统全局区SGA 1.1.1 高速数据缓冲区(database buffer cache) 1.1.2 重做日志缓冲区(redo log buffer cache) 1. ...
- Java爬虫学习(2)之用对象保存文件demo(1)
package com.mieba.spider; import java.util.ArrayList; import java.util.List; import java.util.Vector ...
- [原创]java WEB学习笔记18:java EE 中的MVC 设计模式(理论)
本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...
- java web学习笔记-Servlet篇
Servlet基础 1.Servlet概述 JSP的前身就是Servlet.Servlet就是在服务器端运行的一段小程序.一个Servlet就是一个Java类,并且可以通过“请求-响应”编程模型来访问 ...
- Android(java)学习笔记206:利用开源SmartImageView优化网易新闻RSS客户端
1.我们自己编写的SmartImageView会有很多漏洞,但是我们幸运的可以在网上利用开源项目的,开源项目中有很多成熟的代码,比如SmartImageView都编写的很成熟的 国内我们经常用到htt ...
- Android(java)学习笔记205:网易新闻RSS客户端应用编写逻辑过程
1.我们的项目需求是编写一个新闻RSS浏览器,RSS(Really Simple Syndication)是一种描述和同步网站内容的格式,是使用最广泛的XML应用.RSS目前广泛用于网上新闻频道,bl ...
随机推荐
- postgresql中的各种scan的比较
最近在看postgresql的查询计划,在查询中对表的扫描计划大概有如下几种: Seq Scan Index Scan Bitmap Heap Scan Index Only Scan 这里就把自己的 ...
- Python元类__prepare__方法深入理解
学习元类的时候,对__prepare__不是很理解,书上讲解的也不是很详细,最后通过查看stackoverflow的一些帖子对该方法有了一些理解,记录如下: 先看代码: class member_ta ...
- 选择排序 思想 JAVA实现
已知一个数组 9.29.95.47.79.37.18.56.96.22 使用选择排序是数组有序 选择排序同样是一个运行时间为O(N²)的排序算法. 算法思想:(以从小到大为例) 9.29.95.47. ...
- SJTU 机试 最小面积子矩阵 压缩+双指针
链接:https://www.nowcoder.com/questionTerminal/8ef506fbab2742809564e1a288358554来源:牛客网 一个N*M的矩阵,找出这个矩阵中 ...
- 洛谷 P3391【模板】文艺平衡树(Splay)
题目背景 这是一道经典的Splay模板题--文艺平衡树. 题目描述 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1, ...
- samtools软件作用
samtools的说明文档:http://samtools.sourceforge.net/samtools.shtml samtools是一个用于操作sam和bam文件的工具合集,包含有许多命令.以 ...
- HDU - 3336 next运用+递推
题目的匹配应该也要看成一个文本串与另一个模式串的匹配过程 Text是以当前i结尾的后缀来匹配Pattern的前缀(非真) 这里的Pattern肯定是可以匹配成功的,直接由next来保证(next总是当 ...
- display inline-block 间隔
1.如果li横排用display:inline-block; 则li之间不能有间隔 必须连着一起,所以才一般用float:left; .today-wrap{ position: relative; ...
- offset、client、scroll、screen的自己理解
body是DOM对象里的body子节点,即 <body> 标签: documentElement 是整个节点树的根节点root,即<html> 标签: window.scree ...
- Android报错
Error:Execution failed for task ':app:processDebugResources'. > com.android.ide.common.process. ...