Skip to content

hmlyn/SunnyNet-wpf

Repository files navigation

SunnyNet WPF

SunnyNet WPF 是基于 SunnyNet Go 核心的 Windows 抓包分析工具。项目使用 C# + WPF 重绘桌面界面,核心抓包、代理、脚本、证书与协议处理仍由 Go 后端提供,并以 c-shared DLL 方式供 WPF 直接调用。

仓库地址:https://github.com/hmlyn/SunnyNet-wpf

作者:hmlyn

仓库描述:

SunnyNet WPF 是基于 SunnyNet Go 核心的 Windows 抓包分析工具,使用 C# + WPF 重绘界面,支持 HTTP/HTTPS、WebSocket、TCP/UDP、断点拦截、重放、请求规则、请求构造器、MCP 与常用调试工具。

功能概览

  • Windows x64 桌面应用,界面层使用 WPF,运行产物为 SunnyNet.exe
  • Go 后端编译为 backend/SunnyNetBridge.dll,WPF 通过 P/Invoke 直接调用 SunnyNet 核心能力。
  • 仓库已随项目分发 SunnyNet 核心兼容源码,后端通过本地 replace 引用,不再依赖额外手动准备核心源码。
  • 支持 HTTP/HTTPS、WebSocket、TCP、UDP 会话捕获、筛选、查看和分析。
  • 支持进程筛选、域名筛选、会话收藏、备注、标记颜色、列宽记忆和窗口布局记忆。
  • 支持会话比较视图,可拖入两条会话对比请求/响应差异,并显示哈希摘要。
  • 支持请求/响应 XML 视图,内容匹配 XML 时自动显示,避免无关视图占用空间。
  • 支持 TLS 指纹视图,可查看 JA3、JA3N、JA4、JA4-R、Akamai 等指纹信息。
  • 支持断点拦截、普通重发、运行到结束、断开连接,以及请求/响应内容修改。
  • 支持请求规则中心,包括请求断点、HTTP/WebSocket/TCP/UDP 屏蔽、请求重写、请求映射。
  • 支持请求构造器,可自行构造 GET/POST 等请求,支持协议头/Body 多视图编辑、从会话列表回填重放和历史记录缓存。
  • 支持会话右键复制请求代码,包含 C#、Java、Go、Python、JavaScript、易语言、火山等模板。
  • 支持全局查找、查找替换、请求/响应文本高亮,查找窗口命中后可联动右侧详情视图。
  • 支持 WebSocket 消息流、主动发送、消息重放、HEX/原文/JSON/Protobuf 视图。
  • 支持 TCP/UDP 专用数据视图,避免复用 HTTP/WebSocket 视图造成信息冗余。
  • 支持脚本扩展,可在脚本中处理、解密或转换数据,并写入显示层明文,不破坏原始请求/响应数据。
  • 内置文本工具、JSON 结构编辑器、加密/解密工具、开源协议与赞赏页面。
  • 文本工具支持 Base64/Base64URL、URL、UCS2、常用压缩解压、文本差异、文本去重、大小写转换、时间戳转换等。
  • 加密/解密工具支持 AES/DES/RSA、常用哈希、HMAC,并支持文本/Base64/HEX/Base64URL 输入输出。
  • 支持 GitHub Release 检查更新,可自动检测新版本并打开发布页。
  • 支持 SunnyNet MCP,可让 AI 会话读取、搜索、标记、收藏、备注、查看 TLS 指纹和分析抓包会话。

最新版本

当前发布版本:v0.1.6

发布包命名:

SunnyNet-wpf-v0.1.6-win-x64.zip

Release 包含 Windows x64 可运行程序、WPF 主程序、Go 后端 DLL、随程序运行所需资源,以及可选 MCP 桥接程序。

本次核心更新

  • 请求规则入口重构:主界面顶部“请求规则”现在直接进入规则中心,不再使用下拉菜单。
  • 规则中心按方案 B 重绘:左侧分类导航、顶部统一工具条、右侧表格工作区,减少卡片堆叠和空间浪费。
  • 原“拦截规则”迁移为规则中心内的“请求断点”,支持添加、编辑、删除、启用、备注保存与重复规则校验。
  • 请求断点编辑窗口改为轻量表单,只保留方向、匹配范围、匹配方式、匹配值、备注等必要字段。
  • 请求屏蔽保留 HTTP、WebSocket、TCP、UDP 二级分类,规则数量和当前页统计会同步显示。
  • 规则中心新增当前页搜索过滤,方便在大量断点、屏蔽、重写、映射规则中快速定位。
  • MCP 和后端配置同步补齐请求断点备注字段,AI 读取或管理断点规则时能保留备注信息。

目录结构

  • backend/:Go 后端桥接层,编译为 backend/SunnyNetBridge.dll
  • third_party/SunnyNet/:随仓库分发的 SunnyNet Go 核心兼容源码。
  • src/SunnyNet.Wpf/:WPF 桌面程序源码。
  • docs/:项目文档,例如 MCP 工具清单。
  • sunnymcptool/:可选的上游 MCP 工具源码目录,默认不随仓库提交,需自行克隆。
  • _toolchain/:可选本地工具链目录,例如 Zig。
  • build-debug.bat:Debug 构建脚本,输出到 artifacts/Debug/
  • build-release.bat:Release 构建脚本,输出到 artifacts/Release/,并移除 pdb。

编译环境

必须环境:

  • Windows 10/11 x64
  • .NET SDK 8.0+
  • Go 1.24.x
  • Zig 0.15.2 或兼容版本,用于让 Go 生成 Windows 可加载的 c-shared DLL
  • Git

推荐环境:

  • Visual Studio 2022,用于打开、调试 WPF 项目。
  • PowerShell 7 或 Windows PowerShell,用于运行构建脚本和 MCP 构建脚本。

可选环境:

  • sunnymcptool,用于打包 MCP 桥接程序。

SunnyNet 核心分发说明

项目已随仓库分发 SunnyNet Go 核心兼容源码:

third_party/SunnyNet

当前 backend/go.mod 使用本地 replace:

replace github.com/qtgolang/SunnyNet => ../third_party/SunnyNet

这样首次拉取仓库后即可直接编译后端,也方便项目维护必要的核心层补丁。后续如果 SunnyNet 核心需要增强或修复,建议在 third_party/SunnyNet 内维护兼容补丁,并同步验证 WPF 调用链。

获取源码

git clone https://github.com/hmlyn/SunnyNet-wpf.git
cd SunnyNet-wpf

仓库当前不依赖 Git submodule,third_party/SunnyNet 已在仓库内分发。

Zig 准备

两种方式任选一种。

方式一:安装 zig 并加入 PATH

zig version

方式二:将 Zig 解压到项目本地路径:

_toolchain/zig-x86_64-windows-0.15.2/zig.exe

项目会优先使用本地 _toolchain,如果不存在则使用 PATH 中的 zig

MCP 准备

MCP 是可选项。若需要把 MCP 桥接程序一起打包,请在项目根目录旁准备上游 sunnymcptool

git clone https://github.com/a121400/sunnymcptool.git
cd sunnymcptool
.\scripts\build.ps1 -Target mcp

编译后应存在:

sunnymcptool/build/bin/sunnynet-mcp.exe

WPF 构建时会自动复制到运行目录:

mcp/sunnynet-mcp.exe

如果没有该文件,主程序仍可编译运行,只是 MCP 功能不可用。

编译方式

Debug:

build-debug.bat

Release:

build-release.bat

也可以直接使用:

dotnet build .\SunnyNet.sln -c Debug
dotnet build .\SunnyNet.sln -c Release

建议发布包使用 build-release.bat,因为该脚本会输出到固定目录,并删除 pdb 文件。

输出位置

使用脚本构建后:

artifacts/Debug/SunnyNet.exe
artifacts/Release/SunnyNet.exe

使用 dotnet build 默认构建后:

src/SunnyNet.Wpf/bin/Debug/net8.0-windows/SunnyNet.exe
src/SunnyNet.Wpf/bin/Release/net8.0-windows/SunnyNet.exe

运行时主程序会加载同目录下的 Go 后端 DLL:

backend/SunnyNetBridge.dll

如果启用了 MCP,还会加载:

mcp/sunnynet-mcp.exe

发布打包

推荐流程:

build-release.bat

然后将下面目录压缩为 zip:

artifacts/Release/

推荐命名:

SunnyNet-wpf-v0.1.6-win-x64.zip

常见问题

如果提示找不到 Zig:

  • 确认 zig version 可以在 PowerShell 中正常执行。
  • 或确认本地路径 _toolchain/zig-x86_64-windows-0.15.2/zig.exe 存在。

如果 Go 后端 DLL 没有生成:

  • 确认已经安装 Go 1.24.x。
  • 确认 Zig 可用。
  • 确认 third_party/SunnyNet 目录存在。
  • 重新运行 build-debug.batbuild-release.bat

如果 MCP 文件没有出现在编译产物里:

  • 先编译 sunnymcptool 的 MCP 目标。
  • 确认 sunnymcptool/build/bin/sunnynet-mcp.exe 存在。
  • 重新运行 build-debug.batbuild-release.bat

文档

  • docs/MCP工具清单.md:当前 WPF 版支持的 MCP 工具、参数与返回字段说明。

开源协议

SunnyNet WPF 版采用 MIT 协议开源。你可以自由使用、复制、修改、合并、发布、分发或二次开发本项目,但需要保留原始版权声明和协议声明。

本项目仅用于合法的网络调试、接口分析、测试与技术研究场景。请勿将本工具用于未授权抓包、绕过访问控制、攻击或其它违法用途。

About

SunnyNet WPF 是基于 SunnyNet Go 核心的 Windows 抓包分析工具,使用 C# + WPF 重绘界面,支持 HTTP/HTTPS、WebSocket、TCP/UDP、断点拦截、重放、请求规则、请求构造器、MCP、检查更新与常用调试工具。

Topics

Resources

Stars

Watchers

Forks

Packages

 
 
 

Contributors