zoukankan
html css js c++ java
Net压缩文件流
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; using System.IO.Compression; using System.IO; namespace gzipfile { public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void button1_Click(object sender, EventArgs e) { //文件流 FileStream reader; reader = File.Open("D:\\ddd.txt", FileMode.Open); FileStream writer; writer = File.Create("D:\\ddd.gz"); //压缩相关的流 MemoryStream ms = new MemoryStream(); GZipStream zipStream = new GZipStream(ms, CompressionMode.Compress, true); //往压缩流中写数据 byte[] sourceBuffer = new byte[reader.Length]; reader.Read(sourceBuffer, 0, sourceBuffer.Length); zipStream.Write(sourceBuffer, 0, sourceBuffer.Length); //一定要在内存流读取之前关闭压缩流 zipStream.Close(); zipStream.Dispose(); //从内存流中读数据 ms.Position = 0; //注意,不要遗漏此句 byte[] destBuffer = new byte[ms.Length]; //ms.Read(destBuffer, 0, destBuffer.Length); byte[] header = new byte [10]; ms.Read(header, 0, 10); header[3] = 8; //表示包含文件名信息 byte[] fielContent = new byte[ms.Length -10] ; ms.Read(fielContent, 0, fielContent.Length); string strfilename = "widebright的文件.txt"; //指定初始文件名 //byte [] filename=System.Text.Encoding.Convert(System.Text.Encoding.Default, // // System.Text.Encoding.GetEncoding("ISO-8859-1"), // System.Text.Encoding.Default, // System.Text.Encoding.Default.GetBytes(strfilename)); byte[] filename = System.Text.Encoding.Default.GetBytes(strfilename); writer.Write(header, 0, header.Length); writer.Write(filename, 0, filename.Length); writer.WriteByte(0); //文件名以0 字节结束 writer.Write(fielContent, 0, fielContent.Length); //关闭并释放内存流 ms.Close(); ms.Dispose(); //关闭并释放文件流 writer.Close(); writer.Dispose(); reader.Close(); reader.Dispose(); } } }
查看全文
相关阅读:
Splashtop :符合 HIPAA 标准的远程桌面软件
学生如何在家中访问学校许可的软件
Splashtop用于远程实验室的功能得到增强
docker环境安装,镜像和容器常用命令
vue-cli入门
webpack快速入门
Vue路由vue-router
Vue组件化
Vue指令
Vue实例
原文地址:https://www.cnblogs.com/javawebsoa/p/2458115.html
最新文章
JS---案例:表格隔行变色(鼠标划过背景色恢复)
JavaScript的array方法
JSON
GitHub项目简介
自制正则表达式测试工具
JSONP Hijackin攻击详解
react-父子子孙组件嵌套-context
jQuery---手风琴案例+stop的使用(解决动画队列的问题)
jQuery---城市选择案例
ng-项目结构
热门文章
ffmpeg 命令行总结
异步禁止! map函数结合Promise同步写法
通过ArrayBuffer创建image
ActiveMQ集群方案(2)(热备方案)
ActiveMQ系列—ActiveMQ集群方案(1)
LVS简介
Nginx、HAProxy、LVS三者的优缺点
python多线程与多进程及其区别
Component legend.scroll not exists. Load it first.
react使用ant design RangePicker 报错invalid hook call
Copyright © 2011-2022 走看看