草庐IT

assisted-inject

全部标签

c++ - 防止从 Dll C++ 注入(inject) Dll

我对C++中的反dll注入(inject)有一些疑问。我有一个基于C++的游戏,我遇到了黑客注入(inject)dll的问题。然后我需要阻止它。我从那里找到通知Hook:MSDN-NotificationHooks但我不知道如何使用它。是否可以使用notifyhook来防止dll注入(inject)?这怎么可能?(有更好的例子)。可以来自dll吗?(有例子更好)。感谢您阅读该帖子。PS:对不起我的英语。 最佳答案 算了,除非你做非常复杂的事情,否则它是行不通的。我所说的复杂是指类似于Skype中使用的代码混淆、反调试技术。看看thi

c++ - 在注入(inject)的 DLL 中调用函数?

使用C++,我有一个创建远程进程并向其中注入(inject)DLL的应用程序。有没有办法让远程应用程序从创建它的应用程序执行从DLL导出的函数?是否可以向该函数发送参数?请注意,我试图避免在DllMain中做任何事情。 最佳答案 注意:要获得更好的答案,请seemyupdatepostedbelow!好的,这就是我如何做到这一点的:BOOLRemoteLibraryFunction(HANDLEhProcess,LPCSTRlpModuleName,LPCSTRlpProcName,LPVOIDlpParameters,SIZE_T

单元测试中的 C++ 和依赖注入(inject)

假设我有一个像这样的C++类:classA{public:A(){}voidSetNewB(constB&_b){m_B=_b;}private:Bm_B;}为了对这样的东西进行单元测试,我必须打破A对B的依赖。由于类A持有一个实际对象而不是一个指针,我将不得不重构此代码以获取一个指针。此外,我需要为B创建一个父接口(interface)类,这样我就可以在测试SetNewB时传入我自己的假B。在这种情况下,使用依赖注入(inject)进行单元测试不会使现有代码进一步复杂化吗?如果我将B设为指针,我现在将引入堆分配,并且现在有一段代码负责清理它(除非我使用引用计数指针)。此外,如果B是一

c++ - 在注入(inject)的 DLL 中调用函数

我想在我创建的注入(inject)DLL的远程进程中调用一个函数。我已经成功地将我的DLL注入(inject):CreateRemoteThread(pHandle,NULL,0,(LPTHREAD_START_ROUTINE)GetProcAddress(GetModuleHandle("kernel32"),"LoadLibraryA"),pLibRemote,0,NULL);DllMain被执行,DLL以待机模式运行。我想做的是以某种方式调用远程加载的DLL以完成一些工作。我试过像这样导出函数:extern"C"__declspec(dllexport)voidMyFunc(vo

c++ - Visual Assist 的免费替代品?

按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭10年前。有免费的VC++重构工具吗?

AI新工具(20240203) 文心一言APP数字分身;HuggingChat Assistants等

文心一言APP数字分身-一键生成专属数字分身文心一言数字分身是一项新功能,用户只需一张照片和录制三句语音,就能创建一个专属的数字分身。这个数字分身还支持个性化定义名称、声音、MBTI性格等,用户可以选择是否公开自己的数字分身。这个功能的上线大大缩短了创建数字分身的时间,极大地增加了用户的乐趣体验。未来,数字分身市场潜力巨大,文心一言率先上线数字分身功能,为用户提供了新型娱乐方式,也为数字分身在虚拟客服、在线教育等领域的应用开辟了可能性。HuggingChatAssistants-免费的可定制的AI聊天助手免费产品允许HuggingChat的用户轻松创建自己定制的AI聊天机器人,类似于OpenA

c++ - 对于测试非虚拟方法,模板或链接接缝依赖注入(inject)有哪些替代方案?

我正在尝试测试对无法更改且通常不使用虚拟方法的代码有很多依赖性的代码。这也是一个高性能场景,所以我可以想象在我们自己的代码中的某些地方我们不想使用虚拟方法。非虚拟方法对测试场景很重要,所以我想模拟它们。据我了解,主要有两种选择:模板依赖注入(inject):谷歌称之为hi-perfdependencyinjection.mock不再是依赖的派生类,取而代之的是模板类。它被实例化为用于生产的原始依赖类和用于测试的模拟类。Linkseams:将测试类命名为与生产类相同的名称,并在链接测试时使用链接器技巧将其替换为生产实现。我已经成功地使用了1.但它很快就会失去控制:我将模板化大部分代码库来

c++ - "method injection"的这种虚拟继承使用模式是已知范例吗?

昨天,我遇到了这个问题:forcingunqualifiednamestobedependentvalues最初,这似乎是一个与破坏VC++行为相关的非常具体的问题,但是在尝试解决它时,我偶然发现了一种我以前从未遇到过的虚拟继承的使用模式(我会在告诉你之后解释一下)我的问题)。我发现它很有趣,所以我在SO和google上寻找它,但我找不到任何东西。也许,我只是不知道它的正确名称(“方法注入(inject)”是我的猜测之一)而且它实际上广为人知。这也是我向社区提出的问题的一部分:这是一种常见的使用模式还是另一种已知范式的特例?您是否看到可以通过不同的解决方案避免的任何问题/陷阱?这个模式

c++ - Google Assistant SDK (C++) - 广播指令

我正在使用示例应用程序并使用--text_input选项向Google智能助理发送广播命令,一切正常。现在,在最新版本中,Google智能助理会回复:“出了点问题。出了点问题”,但我没有收到错误,即使打开了verbose。我需要做一些与以前不同的事情吗?其他命令,例如“几点了?”正常工作。这是广播请求的输出:$./run_assistant--text_input"BroadcastDinner"--credentials_file./credentials.jsonUsinglocaleen-USassistant_sdkrobots_pem:assistant_sdkCreateC

c++ - 依赖注入(inject)库的正确比喻是什么?

我是一个实现依赖注入(inject)的小型C++库的作者(我想有人会称它为“IoC容器”)。我一直认为为图书馆找到一个好的比喻可以在很多方面提供帮助:它简化了库的使用它帮助图书馆的作者找到正确的抽象它是检查设计合理性的指南这是一种为类找到有意义名称的方法等等...现在,在我的库中,我使用了设备/插头比喻:您的类是“设备”,它们的依赖项是“插头”,您可以将插头连接到另一个设备。这是一个代码示例:REGISTERED_CLASS(Foo),publicDevice{...private:Plugbar;...};...catalog.Create("myFoo","Foo");catalo