[笔记] 编译bit7z踩坑记录

简介: [笔记] 编译bit7z踩坑记录

前言

最近在使用解压各种格式文件,做进一步内容检测,发现docx是zip格式,doc是ole格式,zip格式可以用zlib库解压,ole却不行,发现7z可以解压,于是便有了一系列的操作。

步骤

bit7z 是一个开源项目,在7z的基础上做了一层封装,依赖7z的库,所以编译使用过程需要加入7z的DLL,和头文件等。

简单编译bit7z描述整个过程:

  1. 拉去bit7z代码
  2. 下载7z sdk
  3. 7z sdk解压放到到bit7z项目的third_part目录7-Zip
  4. 7z sdk解压再放到bit7z项目的include目录
  5. 下载7z sdk extra补充包 解压其中7za.dll 或者 7z.dll(根据自己的需求确认)
  6. 按照官网文档使用cmake构建和编译:
cd <bit7z folder>
mkdir build && cd build
cmake ../ -DCMAKE_BUILD_TYPE=Release
cmake --build . -j --config Release

注意:

7za.dll 只支持7z格式的解压和压缩

7z.dll 支持大多数格式的解压和压缩。

解压测试

注意:BitFormat::Auto 选项需要编译bit7z时,添加 BIT7Z_AUTO_FORMAT

// This is an open source non-commercial project. Dear PVS-Studio, please check it.
// PVS-Studio Static Code Analyzer for C, C++ and C#: http://www.viva64.com
/*
 * bit7z - A C++ static library to interface with the 7-zip shared libraries.
 * Copyright (c) 2014-2022 Riccardo Ostani - All Rights Reserved.
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at https://mozilla.org/MPL/2.0/.
 */
 //#define BIT7Z_USE_NATIVE_STRING
#define BIT7Z_AUTO_FORMAT
#include <bitexception.hpp>
//#include <bitarchiveinfo.hpp>
#include <bit7zlibrary.hpp>
#include <bitarchivereader.hpp>
#include <bitfileextractor.hpp>
#include <iostream>
//#pragma comment(lib, "D:\\workspace\\github\\bit7z\\lib\\x64\\Release\\bit7z64.lib")
using namespace std;
using namespace bit7z;
int main(int argc, char* argv[]) {
    try { // bit7z classes can throw BitException objects
        using namespace bit7z;
        Bit7zLibrary lib{ "D:\\workspace\\github\\bit7z\\bin\\x64\\Debug\\7z.dll" };
        BitFileExtractor extractor{ lib, BitFormat::Auto };
        // Extracting a simple archive
        extractor.extract("D:\\test_office.doc", "D:\\test_office\\");
        // Extracting a specific file
        //extractor.extractMatching("path/to/archive.7z", "file.pdf", "out/dir/");
        // Extracting the first file of an archive to a buffer
        //std::vector< byte_t > buffer;
        //extractor.extract("path/to/archive.7z", buffer);
        // Extracting an encrypted archive
        //extractor.setPassword("password");
        //extractor.extract("path/to/another/archive.7z", "out/dir/");
    }
    catch (const bit7z::BitException& ex) {
        printf(ex.what());
    }
    return 0;
}

总结

主要参考这个文章的:!!!C++ 7z解压缩编译及使用!!!

参考:

7z源码的编译与使用_markdown 格式

7z文件格式及其源码的分析(二)

笔记:7-zip在Visual Studio 2019下的编译

c++配置并使用bit7z加密压缩或解压7z文件


相关文章
|
存储 编解码 安全
冥王峡谷安装steamos踩坑记录
记录冥王峡谷安装第三方steamos-holoiso时遇到的一些问题,其它玩家可参考
2320 0
|
5月前
|
存储 机器学习/深度学习 芯片
8086 汇编笔记(十二):int 指令 & 端口 & 直接定址表
8086 汇编笔记(十二):int 指令 & 端口 & 直接定址表
|
7月前
|
Go
Golang随笔之自动类型推导[:=]踩坑
Golang随笔之自动类型推导[:=]踩坑
37 0
|
数据库 C++
《C++避坑神器·十七》找到程序崩溃Bug的一个实用方法:dump调试
《C++避坑神器·十七》找到程序崩溃Bug的一个实用方法:dump调试
144 0
|
算法 编译器 C语言
算法小白的心得笔记:分清楚执行程序和动态链接库的编译方式。
-fPIC 选项:这个选项告诉编译器生成位置无关代码(Position Independent Code)。这种代码同样可以在内存的任何位置执行,因为它使用的是相对地址而不是绝对地址。这对于动态库是必要的,因为动态库在被加载时,其在内存中的位置是不确定的。
44 0
|
数据采集 JavaScript API
猿人学对抗赛踩坑记录
猿人学对抗赛踩坑记录
159 0
猿人学对抗赛踩坑记录
|
Java 应用服务中间件 Android开发
开发踩坑记录之四:Tomcat内存溢出问题分析
系统平台运行一段时间后,平台出现无法访问的问题,重启对应的服务后平台恢复正常。查看日志发现在凌晨两点零四分之后没有对应的日志输出,直到重启服务后才有日志的正常输出。同时发现在Tomcat的目录下存在hprof文件,即java进程的内存镜像文件。初步猜测Tomcat发生了内存溢出导致服务出现假死现象,即在任务管理器中虽然为运行状态,但是实际已不能正常对外提供服务。   对于hprof文件的分析需要借助于内存分析工具Eclipse Memory Analyzer,通过它寻找到平台发生内存泄露的根源,再根据发生内存泄露的地方以及相关的日志信息定位什么样的业务场景下导致该异常情况的发生。
开发踩坑记录之四:Tomcat内存溢出问题分析
|
Java 区块链 Maven
Spring源码下载与编译,Debug学习才有效率
Spring源码下载与编译,Debug学习才有效率
533 0
|
设计模式 缓存 Java
面试题 | 怎么写一个又好又快的日志库?(一)(下)
面试题 | 怎么写一个又好又快的日志库?(一)
132 0
ROS noetic 安装编译Cartographer踩坑记录
ROS noetic 安装编译Cartographer踩坑记录
740 0
ROS noetic 安装编译Cartographer踩坑记录