printspoofer的RPC调用接口的简单代码

🧠 问题背景:为什么不能"啥都不导库"就直接调用 RPC 接口?

因为:

  • 你想调用的是 RPC 接口函数 ,比如 RpcRemoteFindFirstPrinterChangeNotificationEx

  • 它不是像 MessageBox() 那样的普通 API,而是 运行在远程服务(如 Print Spooler)里的接口

  • 你要调用它,需要知道:

    • 它的接口 ID(UUID)

    • 函数编号(OpNum)

    • 参数格式(结构体、顺序等)


✅ 做法一:使用 Windows 自带的封装 API(推荐新手)

Windows 提供了一个封装好的 API:

复制代码
BOOL FindFirstPrinterChangeNotificationEx(
    HANDLE hPrinter,
    DWORD fdwFlags,
    DWORD fdwOptions,
    LPCWSTR pszLocalMachine,
    DWORD Count,
    LPVOID pPrinterNotifyOptions,
    LPVOID pPrinterNotifyInfo
);

这个函数内部会自动构造 RPC 调用,你只需要引入头文件和库即可:

复制代码
#include <windows.h>
#include <winspool.h>

int main() {
    HANDLE hPrinter;
    OpenPrinter(L"PrinterName", &hPrinter, NULL); // 一般用 NULL 也行

    FindFirstPrinterChangeNotificationEx(
        hPrinter,
        PRINTER_CHANGE_ADD_JOB, // 监听什么事件
        0,
        L"\\\\127.0.0.1\\pipe\\legitname", // 诱导 spooler 去连接此路径
        0,
        NULL,
        NULL
    );

    ClosePrinter(hPrinter);
    return 0;
}

这里的L"\\\\127.0.0.1\\pipe\\legitname", // 诱导 spooler 去连接此路径

其实是错的

正常就是传个ip

L"127.0.0.1"

看起来像 IP 地址,但 Windows 会自动把它当作 UNC 路径处理:

它最终会被解析成 \\127.0.0.1\pipe\spoolss

这个函数在 winspool.drv 里,编译时需要链接:

复制代码
#pragma comment(lib, "winspool.lib")

✅ 做法二:你手写 RPC 调用(适合深入研究漏洞)

这个就麻烦多了,你要手动:

  1. 使用 .idl 文件描述 spoolss 接口;

  2. 编译 .idl.h + .c(MIDL 工具);

  3. 注册并绑定 RPC 接口;

  4. 自己调用其中函数;

👨‍💻 举个最简单例子:你拿到 spoolss 接口的 IDL 后会看到:

复制代码
[
  uuid(12345678-1234-abcd-ef00-0123456789ab),
  version(1.0)
]
interface spoolss {
    void RpcRemoteFindFirstPrinterChangeNotificationEx(
        [in] handle_t hPrinter,
        ...
    );
}

你用 rpcview 等工具就能导出这样的接口,然后用 MIDL 编译,生成对应 .h/.c 文件。


🛠 工具推荐:

  • 📦 RpcView.exe(开源):查看系统暴露的 RPC 接口、UUID、OpNum 等。

  • 🧰 MIDL.exe:微软官方的 IDL 编译器(把接口定义文件编译成 .h + .c


✅ 总结给你:

方法 优点 缺点
使用 FindFirstPrinterChangeNotificationEx 简单、直接、系统封装好了 不够底层
自己写 RPC 接口代码(手撸) 灵活、深入理解提权机制 麻烦、需要 RPC 基础

相关推荐
IT学习资源每日免费分享38 分钟前
网络安全系列课程合集,含病毒分析、红队安全、攻防安全等教程汇总
网络·网络协议·计算机网络·系统安全
czy87874751 小时前
在 LwIP 中,select() 函数返回值小于等于 0 通常表示发生了错误或超时
网络协议
czy87874752 小时前
深入理解 TCP 协议中三次握手建立连接和四次挥手关闭连接的核心逻辑
网络·网络协议·tcp/ip
这儿有一堆花3 小时前
实战:FastAPI与WebSocket的高并发足球数据API开发指南
websocket·网络协议·fastapi
数通工程师3 小时前
实操教程:华为防火墙HRP主备模式完整配置步骤
运维·服务器·网络·网络协议·tcp/ip·华为
2301_803554523 小时前
Qt中connect()实现信号与槽连接这一核心机制
java·数据库·qt
Frank学习路上3 小时前
【Qt】问题记录ld: framework ‘AGL‘ not found on MacOS 26
开发语言·qt·macos
青果全球http3 小时前
2026年动态代理IP实测分享:跨境与数据采集的高性价比方案
网络·网络协议·tcp/ip
Selenium-Wang4 小时前
静态IP是什么意思?一文解析原理、用途与优势
网络·网络协议·tcp/ip
YYYing.4 小时前
【计算机网络 | 第十一篇】计网之应用层(二)—— 万字解析 + 图解DNS、DHCP、HTTP2.0/3.0
网络·网络协议·计算机网络·http