`

使用Java实现网络传输数据压缩

    博客分类:
  • Java
阅读更多

1:选择或者创建一个新的套接字。(可以参看SUN´S的"创建一个典型的套接字")。

2:创建一个服务器端的套接字

3:创建一个RMIClientSocketFactory

4:创建一个RMIServerSocketFactory

5:创建一个继承了UnicastRemoteObjec的远程对象,从而使用新的factories

根据这一大致的想法,我们来看每一步如何具体的实现。

步骤1: 创建ZipSocket

由于要进行Zip压缩,我们重新创建这样的套接字

import java.io.InputStream;
import java.io.OutputStream;
import java.util.zip.ZipInputStream;
import java.util.zip.ZipOutputStream;
import java.net.Socket;

public class ZipSocket extends Socket {
	private InputStream in;
	private OutputStream out;

	public ZipSocket() {
		super();
	}

	public ZipSocket(String host, int port) throws IOException {
		super(host, port);
	}

	public InputStream getInputStream() throws IOException {
		if (in == null) {
			in = new ZipInputStream(super.getInputStream());
		}
		return in;
	}

	public OutputStream getOutputStream() throws IOException {
		if (out == null) {
			out = new ZipOutputStream(super.getOutputStream());
		}
		return out;
	}

	public synchronized void close() throws IOException {
		OutputStream o = getOutputStream();
		o.flush();
		super.close();
	}
}

 步骤2: 创建ZipServerSocket

import java.net.ServerSocket;
import java.net.Socket;
import java.io.IOException
public class ZipServerSocket extends ServerSocket{
	public ZipServerSocket(int port) throws IOException {
		super(port);
	}
	
	public Socket accept() throws IOException {
		Socket socket = new ZipSocket();
		implAccept(socket);
		return socket;
	}
}

 

步骤3:创建ZipClientSocketFactory

客户端的factory的创建必须遵循以下的形式:

import java.io.IOException;
import java.io.Serializable;
import java.net.Socket;
import java.rmi.server.RMIClientSocketFactory;
public class ZipClientSocketFactory implements RMIClientSocketFactory, Serializable {
	public Socket createSocket(String host, int port) throws IOException {
		ZipSocket socket = new ZipSocket(host, port);
		return socket;
	}
}

 步骤4:创建ZipServerSocketFactory

import java.io.IOException;
import java.io.Serializable;
import java.net.ServerSocket;
import java.rmi.server.RMIServerSocketFactory;
public class ZipServerSocketFactory implements RMIServerSocketFactory, Serializable {
	public ServerSocket createServerSocket(int port) throws IOException {
		ZipServerSocket server = new ZipServerSocket(port);
		return server;
	}
}

 步骤5: 创建一个继承了UnicastRemoteObjec的远程对象,从而使用新的factories.

public class YourRMIObject extends UnicastRemoteObject {
	public YourRemoteObject( int port ) {
		super( port, new ZipClientSocketFactory(), new ZipServerSocketFactory() );
	}
	// 剩下的是你自己的程序实现
}

 

现在你的通信数据得到了压缩.

分享到:
评论

相关推荐

    java实现视频压缩

    总之,Java实现视频压缩涉及到多媒体处理、图像编码、数据封装等多个技术环节,虽然Java不是首选的视频处理语言,但借助适当的库和接口,仍然能够构建功能强大的视频压缩系统。对于想要深入这一领域的开发者来说,...

    java数据压缩传输

    在Java编程环境中,数据压缩和传输是常见的任务,特别是在大数据处理、网络通信和文件存储等领域。Java提供了多种库和API来实现数据的压缩与解压缩,以提高存储效率和网络传输速度。本篇文章将深入探讨Java中的数据...

    lz4压缩算法java实现-LZ4-极快的压缩算法,排序算法数据结构 最快的排序算法

    *数据压缩:LZ4java实现可以用于数据压缩,提高存储和传输效率 *高速存储:LZ4java实现可以用于高速存储系统,提高数据的存储和读取速度 *云存储:LZ4java实现可以用于云存储系统,提高数据的存储和传输效率

    Java压缩数据文件并实现传输功能.rar

    结合上述知识点,我们可以推断出,压缩包中的`codesc.net`可能是实现上述功能的Java源代码文件,包含了一个或多个类,这些类定义了网络连接、数据压缩和传输的逻辑。通过阅读和理解这段代码,开发者可以学习如何在...

    Java数据压缩与传输实例

    在Java编程环境中,数据压缩与传输是常见的任务,特别是在处理大量数据或进行网络通信时。本文将深入探讨Java中如何实现这两个关键功能,并提供相关的源码示例。 首先,我们来了解一下Java中的数据压缩。Java标准库...

    java 数据压缩的实现示例

    在Java中,我们可以使用标准库如`java.util.zip`来实现数据压缩,例如GZIP、Deflater和Inflater类提供了gzip和DEFLATE压缩算法的实现。 哈夫曼编码是一种可变长度的前缀编码方法,基于频率进行编码。构建哈夫曼树的...

    G.721语音压缩算法的java实现

    这种压缩方法在保持语音质量的同时,显著减少了数据传输量,对于有限带宽的通信系统来说尤为重要。 在Java编程语言中实现G.721算法,通常会涉及以下几个关键步骤: 1. **采样与量化**:首先,原始的模拟语音信号...

    Java数据压缩与传输实例.rar

    在Java编程语言中,数据压缩和传输是两个关键的领域,尤其在大数据处理、网络通信以及文件存储等场景中显得尤为重要。本实例将探讨如何利用Java实现数据的压缩和传输,帮助开发者提升程序效率和资源利用率。 首先,...

    Java数据压缩与传输实例Java源码.

    在Java编程语言中,数据压缩和传输是两个关键的概念,特别是在大数据处理、网络通信和存储优化的场景下。本实例提供了Java源码,用于演示如何实现这些功能。 首先,我们来了解一下数据压缩。数据压缩的主要目的是...

    Java实现压缩与解压缩功能源码

    在Java编程语言中,压缩和解压缩文件是常见的任务,特别是在处理大量数据或者需要在网络上传输数据时。这里我们将深入探讨如何使用Java实现这一功能,主要关注ZIP文件格式的压缩和解压缩。 首先,Java标准库提供了...

    java实现压缩与解压缩

    - **压缩**:`GZIPOutputStream`用于将数据压缩成GZIP格式。你需要创建一个`GZIPOutputStream`,然后通过`write`方法写入要压缩的数据。 - **解压缩**:`GZIPInputStream`用于读取GZIP格式的文件。你可以创建一个`...

    DICOM医学图像数据接口的Java实现

    总的来说,DICOM医学图像数据接口的Java实现涉及了医学图像数据的解析、处理、存储和传输,需要对DICOM标准、Java编程以及可能的图像处理库有深入的理解。通过合理的编程和库的使用,可以构建功能丰富的医学图像应用...

    哈夫曼编码实现压缩解压缩java

    由于高频字符的编码短,低频字符的编码长,所以整体上可以减少编码长度,实现数据压缩。 2. **哈夫曼树构建**: - 首先,将每个字符视为一个带有频率的节点,形成一个“单节点”集合。 - 然后,选择频率最小的两...

    根据哈夫曼编码写的数据压缩解压软件(java实现)

    在Java中实现哈夫曼编码的数据压缩和解压软件,需要理解以下几个关键步骤和技术: 1. **构建哈夫曼树**:首先,需要统计输入文本中每个字符的出现频率。然后,基于这些频率构建一个哈夫曼树(也称为最优二叉树)。...

    数据压缩与传输_java_throwc4v_

    本实例聚焦于Java语言实现数据压缩与传输的实践,涉及了多个关键概念和方法。 首先,"Java数据压缩与传输"涉及到Java的I/O流和压缩库。在Java中,我们通常使用`java.util.zip`包来处理压缩和解压缩任务,如`...

    java实现rar压缩与解压缩

    在Java编程语言中,实现RAR压缩与解压缩是一项常见的任务,尤其在处理大量数据或打包文件以便于传输时。本文将深入探讨如何使用Java来实现这个功能,主要关注`FileUtil.java`文件中的代码实现。 首先,Java本身并不...

    使用Java向服务器上传文件压缩包并实现解压缩

    在这个场景中,我们关注的是如何使用Java来实现文件压缩包的上传以及在服务器上的解压缩。Java作为一种强大的编程语言,提供了丰富的库来支持这样的操作,特别是在涉及到SFTP(Secure File Transfer Protocol)时,...

    利用JAVA实现局域网的跨平台实时视频传输_吴良斌1

    视频媒体数据量巨大必须将编码后的视频媒体数据进行高效的压缩,然后将压缩后的数据在网络上传输。其相应的解压模块负责将数据还原成为原来的流媒体格式。 二、基于JMF架构实现RTP/RTCP传输模型 JMF...

    java源码:Java数据压缩与传输实例.zip

    在Java编程语言中,数据压缩和传输是两个关键的领域,尤其在大数据处理、网络通信以及文件存储中扮演着重要角色。本实例聚焦于如何利用Java实现数据的压缩和解压,以及如何进行数据传输。这里我们将深入探讨相关知识...

Global site tag (gtag.js) - Google Analytics