| 库 | 作用 |
|---|---|
| zlib | 通用压缩库,libpng 的底层依赖 |
| libpng | PNG 编码/解码,负责将量化后的调色板写入 PNG 文件 |
| libimagequant | 核心量化算法,将 RGBA 图像减色为 256 色调色板(与 tinypng 同类算法) |
mingw1310_64)确保 MinGW 在 PATH 中,在 cmd 执行:
set PATH=C:\Qt\Tools\mingw1310_64\bin;%PATH%⚠️ 重要:后续所有编译步骤必须在无空格路径下进行。
如果你的用户目录包含空格(如C:\Users\Marco Nie),请在C:\根目录下建立工作目录。
mkdir C:\build_libs
cd C:\build_libscd C:\build_libs
git clone https://github.com/madler/zlib.git --branch v1.3.1 --depth 1
cd zlib
cmake -B build -G "MinGW Makefiles" ^
-DCMAKE_BUILD_TYPE=Release ^
-DBUILD_SHARED_LIBS=OFF ^
-DCMAKE_INSTALL_PREFIX=C:/build_libs/third_party/zlib
cmake --build build
cmake --install build
cd ..安装结果:
C:\build_libs\third_party\zlib\
include\ ← zlib.h, zconf.h
lib\ ← libzlibstatic.acd C:\build_libs
git clone https://github.com/pnggroup/libpng.git --branch v1.6.43 --depth 1
cd libpng
cmake -B build -G "MinGW Makefiles" ^
-DCMAKE_BUILD_TYPE=Release ^
-DPNG_SHARED=OFF ^
-DPNG_STATIC=ON ^
-DPNG_TESTS=OFF ^
-DZLIB_ROOT=C:/build_libs/third_party/zlib ^
-DCMAKE_INSTALL_PREFIX=C:/build_libs/third_party/libpng
cmake --build build
cmake --install build
cd ..安装结果:
C:\build_libs\third_party\libpng\
include\ ← png.h, pngconf.h, pnglibconf.h
lib\ ← libpng16.alibimagequant 2.17+ 已用 Rust 重写,MinGW 下需使用最后一个纯 C 版本 2.12.6,
该版本没有 CMakeLists.txt,直接用 gcc 手动编译。
cd C:\build_libs
git clone https://github.com/ImageOptim/libimagequant.git ^
--branch 2.12.6 --depth 1 libimagequant_c
cd libimagequant_c
:: 编译所有源文件
gcc -c -O3 -std=c99 -ffast-math ^
libimagequant.c blur.c kmeans.c mediancut.c mempool.c nearest.c pam.c
:: 打包静态库
ar rcs libimagequant.a ^
libimagequant.o blur.o kmeans.o mediancut.o mempool.o nearest.o pam.o
:: 手动安装
mkdir C:\build_libs\third_party\libimagequant\include
mkdir C:\build_libs\third_party\libimagequant\lib
copy libimagequant.h C:\build_libs\third_party\libimagequant\include\
copy libimagequant.a C:\build_libs\third_party\libimagequant\lib\
cd ..安装结果:
C:\build_libs\third_party\libimagequant\
include\ ← libimagequant.h
lib\ ← libimagequant.a将编译好的库复制到你指定的目录,例如 C:\Users\Marco Nie\Library\imageprocess:
xcopy /E /I C:\build_libs\third_party\zlib ^
"C:\Users\Marco Nie\Library\imageprocess\zlib"
xcopy /E /I C:\build_libs\third_party\libpng ^
"C:\Users\Marco Nie\Library\imageprocess\libpng"
xcopy /E /I C:\build_libs\third_party\libimagequant ^
"C:\Users\Marco Nie\Library\imageprocess\libimagequant"最终目录结构:
C:\Users\Marco Nie\Library\imageprocess\
zlib\
include\
lib\
libpng\
include\
lib\
libimagequant\
include\
lib\win32 {
IMAGEPROCESS = "C:/Users/Marco Nie/Library/imageprocess"
INCLUDEPATH += \
$${IMAGEPROCESS}/libimagequant/include \
$${IMAGEPROCESS}/libpng/include \
$${IMAGEPROCESS}/zlib/include
LIBS += \
-L$${IMAGEPROCESS}/libimagequant/lib -limagequant \
-L$${IMAGEPROCESS}/libpng/lib -lpng16 \
-L$${IMAGEPROCESS}/zlib/lib -lzlibstatic
}brew install libpng zlib libimagequant安装路径(Apple Silicon 固定为 /opt/homebrew/opt/):
| 库 | 路径 |
|---|---|
| libpng | /opt/homebrew/opt/libpng |
| zlib | /opt/homebrew/opt/zlib |
| libimagequant | /opt/homebrew/opt/libimagequant |
Intel Mac 的 Homebrew 前缀为/usr/local/opt/,将下方路径中的/opt/homebrew替换为/usr/local即可。
macx {
INCLUDEPATH += \
/opt/homebrew/opt/libimagequant/include \
/opt/homebrew/opt/libpng/include \
/opt/homebrew/opt/zlib/include
LIBS += \
-L/opt/homebrew/opt/libimagequant/lib -limagequant \
-L/opt/homebrew/opt/libpng/lib -lpng \
-L/opt/homebrew/opt/zlib/lib -lz
}注意:macOS 下链接名与 Windows 不同:
- libpng 是
-lpng(不带版本号)- zlib 是
-lz(不是-lzlibstatic)
win32 {
IMAGEPROCESS = "C:/Users/Marco Nie/Library/imageprocess"
INCLUDEPATH += \
$${IMAGEPROCESS}/libimagequant/include \
$${IMAGEPROCESS}/libpng/include \
$${IMAGEPROCESS}/zlib/include
LIBS += \
-L$${IMAGEPROCESS}/libimagequant/lib -limagequant \
-L$${IMAGEPROCESS}/libpng/lib -lpng16 \
-L$${IMAGEPROCESS}/zlib/lib -lzlibstatic
}
macx {
INCLUDEPATH += \
/opt/homebrew/opt/libimagequant/include \
/opt/homebrew/opt/libpng/include \
/opt/homebrew/opt/zlib/include
LIBS += \
-L/opt/homebrew/opt/libimagequant/lib -limagequant \
-L/opt/homebrew/opt/libpng/lib -lpng \
-L/opt/homebrew/opt/zlib/lib -lz
}
HEADERS += src/image_compress.h
SOURCES += src/image_compress.cpp| 错误信息 | 原因 | 解决方法 |
|---|---|---|
cannot find -lpng16 | 库名不匹配 | 检查 lib\ 下实际文件名,改为对应的 -lpng 或 -lpng16 |
undefined reference to inflate | zlib 未链接 | 确认 -lzlibstatic 在 LIBS 中且在 -lpng16 之后 |
png.h: No such file or directory | INCLUDEPATH 路径错误 | 核对实际头文件路径与 .pro 中配置是否一致 |
Z_FILTERED undeclared | 缺少 zlib 头文件 | 在 image_compress.cpp 顶部添加 #include <zlib.h> |
| CMake 路径含空格报错 | MinGW windres 不支持空格路径 | 在无空格路径(如 C:\build_libs)下编译 |
| libimagequant clone 后无 .c 文件 | 拉取到了 Rust 重写版本 | 明确指定 --branch 2.12.6 |
start ms-cxh:localonly,即可直接创建本地账户,而且无需重启设备,无需先跳过联网步骤。
]]>dumpbin 位于 Visual Studio 工具链中,一般路径如下:
C:\Program Files (x86)\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\<version>\bin\Hostx64\x64\dumpbin.exe
要使用它,可以通过以下方式:
然后在命令行中直接输入:
dumpbin /?如果能看到帮助信息,说明环境已正确配置。
dumpbin /exports your.dll
输出说明:
Microsoft (R) COFF/PE Dumper Version 14.42.34433.0
Copyright (C) Microsoft Corporation. All rights reserved.
Dump of file C:\Users\Marco Nie\TEST.dll
File Type: DLL
Section contains the following exports for hasp_windows_x64_107043.dll
00000000 characteristics
68DB892A time date stamp Tue Sep 30 15:39:22 2025
0.00 version
1 ordinal base
79 number of functions
79 number of names
ordinal hint RVA name
1 0 00001000 MyFunctionA
2 1 00002000 MyFunctionB
Summary
A1000 .data
D000 .pdata
133000 .rdata
6000 .reloc
1000 .rsrc
483000 .textordinal:函数序号
name:导出函数名(重点)
RVA:函数在文件中的相对虚拟地址
用途:验证 DLL 是否正确导出了接口,比如你加密或封装的 DLL 是否暴露了预期的函数。
如果想要检测是否包含特定名称的函数可以过滤结果:
dumpbin /exports your.dll | findstr str111
以上指令会输出包含 str111 的行。
dumpbin /imports your.dll
这会列出该 DLL 引用的其他 DLL(比如 KERNEL32.dll, USER32.dll 等)。
dumpbin /headers your.dll | findstr machine
输出示例:
14C machine (x86)
8664 machine (x64)dumpbin /all your.dll > result.txt
这样可以把所有信息输出到文件中慢慢查看,包括节区、符号、导入表、导出表、资源等。
]]>参考之前的文章:https://blog.niekun.net/archives/413.html
确定您的 shell 类型。打开终端,运行以下命令:
echo $SHELL
这通常会返回 /bin/zsh 或 /bin/bash。
根据您的 shell 类型,编辑相应的配置文件:
对于 Zsh(最新的 macOS 默认使用):编辑 ~/.zshrc
对于 Bash:编辑 ~/.bash_profile 或 ~/.bashrc
使用文本编辑器打开相应的文件。例如,对于 zsh:
vim ~/.zshrc
在文件末尾添加以下行(替换为您的实际脚本目录路径):
export PATH="/path/script:$PATH"
保存并关闭文件。使更改生效,可以重新加载配置文件或重启终端。要重新加载,运行:
source ~/.zshrc # 如果使用 Zsh
source ~/.bash_profile # 如果使用 Bash
验证 PATH 更新:
echo $PATH
您应该能看到您的脚本目录已被添加。现在,您应该能够直接运行脚本,而不需要指定完整路径:
test.sh
注意事项:
chmod +x script_name.sh)。我的这一款是 6 大核 8 小核 20 线程设计。默认情况下启动虚拟机资源分配是交给 windows 主机自己协调的,很可能会分配给小核运行虚拟机导致运行卡顿,资源管理器可以看到 cpu 负载都在后面的小核上:
解决方法就是以管理员权限运行 vmware,这样 VMware 会自己调度资源使用,优先级大概是大核>小核>超线程。实际效果很明显,基本都运行在了大核上:
可以自己修改快捷方式的属性来建立一个以快捷方式所在地址为准的指向一个相对路径的文件。这样适用于需要同时移动原始文件与快捷方式的情况。
首先右键创建一个文件的快捷方式,然后右键选择快捷方式的属性,将目标位置地址改为:explorer.exe path/to/file.exe。注意 explorer.exe 后面的空格:
后面的路径就是相对于快捷方式地址的相对路径。
确认后默认快捷方式图标会变成资源管理器的图标,可以在属性里修改为其他图标。
]]>wsa 没有在官方的 store 中提供,这里使用开源的 WSA-Script 很方便的一键安装。
GitHub 主页:https://github.com/YT-Advanced/WSA-Script
在 release 页面下载最新打包的版本:https://github.com/YT-Advanced/WSA-Script/releases/latest
我需要使用 google play 框架及 root 权限,所以下载的是框出来的版本:
下载好解压到一个特定的目录,运行 Run.bat,期间会提示需要管理员权限以及提示收集信息的对话框,点击确认即可。
安装完成后会自动运行 Windows Subsystem For Android™ 应用。
如果需要使用 play 商店,就需要配置代理服务。如果本机有代理工具的话,可以让 wsa 直接调用本机代理。这里需要使用 adb 工具,下载链接:https://dl.google.com/android/repository/platform-tools-latest-windows.zip
解压压缩包,可以看到其中有一个 adb.exe,可以将目录添加到系统 path 以方便在 terminal 调用。
首先需要设置 wsa 打开开发者模式,进入设置打开选项:
默认 wsa 是运行在本地的 58526 端口的。
建立一个 powershell 脚本,如:wsaproxy.ps1,内容如下:
$WinNetIP=$(Get-NetIPAddress -InterfaceAlias 'vEthernet (WSLCore)' -AddressFamily IPV4) # get android network gateway addr
adb connect 127.0.0.1:58526 # android port
adb shell settings put global http_proxy "$($WinNetIP.IPAddress):1082" # local proxy port第一次执行会弹出对话框是否信任外部访问,点击允许即可。
以上脚本会获取到 wsa 所在网卡的网关地址,然后用 adb 连接到 wsa,最后配置代理,注意脚本里的本地代理端口修改为实际值即可。
运行脚本即可让 wsa 配置好代理服务。以后只需要执行这个脚本就可以自动设置代理。
如果需要取消代理运行下面命令即可:
adb shell settings put global http_proxy :0推荐直接在 play 商店安装应用程序,如果需要安装自己下载的第三方 apk,直接使用 adb 工具即可。
安装命令:
adb connect 127.0.0.1:58526
adb install xxx.apk可以配置一个 Windows 主机的路径作为同 wsa 共享目录,这样两边就可以互传文件了。
打开 Windows Subsystem For Android™ 进入 advanced settings - experimental feature,启用 share user folders 功能并选择一个本地目录作为共享目录:
通过 system - turnoff 关闭 wsa,然后点击 files 会重新运行 wsa:
可以看到有一个 windows 文件夹:
这个文件夹就是对应的 windows 共享目录。
默认情况下只有在第一次安装成功后会自动启动 Android 设置界面,并且找不到设置的启动图标在哪里,我们可以在浏览器里直接访问 android settings 地址的方式启动。
浏览器中输入以下地址并访问:wsa://com.android.settings,会提示是否需要跳转到设置,点击确认即可进入设置:
Windows Android 子系统 WSA 代理设置方法教程
WSA (Windows Subsystem for Android) 使用 Windows 上的代理
工具:
首先需要主板支持虚拟化 VT,需要在 bios 中打开对应选项。注意此项必须配置,否则安装会不成功。
VMware workstation 默认不支持安装 macos,需要使用第三方工具 unlocker 来开启支持,直接在上方提供的 github 主页下载最新版本即可,运行 windows 文件夹下的 unlock.exe 即可。
然后下载 macos iso 镜像文件,在我上面提供的网站中下载即可。
按照正常的新建虚拟机的方式新建,添加下载好的系统镜像用来安装,配置好确认后先不要启动虚拟机,先修改对应虚拟机文件夹下的 vmx 文件。
文本编辑器打开 vmx 文件后,在最后一行添加一句:
smc.version = 0
保存后即可启动虚拟机,进入 recovery 工具后,先格式化硬盘,然后安装系统,提示一步步安装即可。
How To Install macOS Monterey On Vmware On Windows Pc
Windows用VM虚拟机安装MacOS Ventura 13.6系统全流程教程
安装新密钥,会自动替换当前密钥:
slmgr /ipk xxxx-xxxx-xxxx-xxxx-xxxx
激活 Windows:
slmgr /ato
显示当前授权信息:
slmgr /dli
显示详细授权信息:
slmgr /dlv
显示授权剩余日期:
slmgr /xpr
密钥可用性在线检测:https://dbmer.com/checkkey/
]]>搜索 windows feature 打开功能开关配置界面:
开启如下 ftp 相关选项,确认后等待安装完成:
搜索 Administrative Tools:
双击 Internet Information Services (IIS) Manager:
sites 上右键点击 add ftp site:
设置名称及共享路径:
选择无 ssl:
选择 basic 验证以及指定可登录 FTP 的用户,设置读写权限:
可以单独建立一个用户用来登录 ftp,建立账户可以参考我的教程:https://blog.niekun.net/archives/2103.html#title-4
设置完成后,点击完成即可。
然后配置防火墙例外,搜索 allow an app through windows firewall:
在列表中找到 ftp server 并打勾即可:
以上就完成了 Windows 端 ftp 服务器的搭建,可以使用 ftp 客户端登录此 ftp 服务器了。
]]>