ISevenZipCompressor.cs 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. using Masuit.Tools.Systems;
  2. using SharpCompress.Common;
  3. using System.Collections.Generic;
  4. using System.IO;
  5. namespace Masuit.Tools.Files;
  6. /// <summary>
  7. /// 7z压缩
  8. /// </summary>
  9. public interface ISevenZipCompressor
  10. {
  11. /// <summary>
  12. /// 解压文件,自动检测压缩包类型
  13. /// </summary>
  14. /// <param name="compressedFile">rar文件</param>
  15. /// <param name="dir">解压到...</param>
  16. /// <param name="ignoreEmptyDir">忽略空文件夹</param>
  17. void Decompress(string compressedFile, string dir = "", bool ignoreEmptyDir = true);
  18. /// <summary>
  19. /// 压缩多个文件
  20. /// </summary>
  21. /// <param name="files">多个文件路径,文件或文件夹</param>
  22. /// <param name="zipFile">压缩到...</param>
  23. /// <param name="rootdir">压缩包内部根文件夹</param>
  24. /// <param name="archiveType"></param>
  25. void Zip(IEnumerable<string> files, string zipFile, string rootdir = "", ArchiveType archiveType = ArchiveType.Zip);
  26. /// <summary>
  27. /// 压缩多个文件
  28. /// </summary>
  29. /// <param name="streams">多个文件流</param>
  30. /// <param name="zipFile">压缩到...</param>
  31. /// <param name="archiveType"></param>
  32. /// <param name="disposeAllStreams">是否需要释放所有流</param>
  33. void Zip(DisposableDictionary<string, Stream> streams, string zipFile, ArchiveType archiveType = ArchiveType.Zip, bool disposeAllStreams = false);
  34. /// <summary>
  35. /// 压缩文件夹
  36. /// </summary>
  37. /// <param name="dir">文件夹</param>
  38. /// <param name="zipFile">压缩到...</param>
  39. /// <param name="rootdir">压缩包内部根文件夹</param>
  40. /// <param name="archiveType"></param>
  41. public void Zip(string dir, string zipFile, string rootdir = "", ArchiveType archiveType = ArchiveType.Zip);
  42. /// <summary>
  43. /// 将多个文件压缩到一个文件流中,可保存为zip文件,方便于web方式下载
  44. /// </summary>
  45. /// <param name="files">多个文件路径,文件或文件夹,或网络路径http/https</param>
  46. /// <param name="rootdir"></param>
  47. /// <param name="archiveType"></param>
  48. /// <returns>文件流</returns>
  49. PooledMemoryStream ZipStream(IEnumerable<string> files, string rootdir = "", ArchiveType archiveType = ArchiveType.Zip);
  50. /// <summary>
  51. /// 将多个文件压缩到一个文件流中,可保存为zip文件,方便于web方式下载
  52. /// </summary>
  53. /// <param name="streams">多个文件流</param>
  54. /// <param name="archiveType"></param>
  55. /// <param name="disposeAllStreams">是否需要释放所有流</param>
  56. /// <returns>文件流</returns>
  57. PooledMemoryStream ZipStream(DisposableDictionary<string, Stream> streams, ArchiveType archiveType = ArchiveType.Zip, bool disposeAllStreams = false);
  58. /// <summary>
  59. /// 将文件夹压缩到一个文件流中,可保存为zip文件,方便于web方式下载
  60. /// </summary>
  61. /// <param name="dir">文件夹</param>
  62. /// <param name="rootdir"></param>
  63. /// <param name="archiveType"></param>
  64. /// <returns>文件流</returns>
  65. public PooledMemoryStream ZipStream(string dir, string rootdir = "", ArchiveType archiveType = ArchiveType.Zip);
  66. }