草庐IT

preg_replace_all

全部标签

c++ - 注册由 Microsoft 的 All-In-One 框架(CppShellExtContextMenuHandler 项目)提供的 Windows 上下文菜单处理程序

我一直在使用Microsoft的一体化框架中的CppShellExtContextMenuHandler示例项目将自定义菜单项+图标添加到Windows的上下文菜单中。但是,我似乎无法在除我以外的其他计算机上注册此示例提供的DLL。该DLL是在Windows7x86机器上从未经修改的代码编译而来的,无法在以下平台上运行:另一个Windows7x86在VirtualBox上安装全新的WindowsXPSP3x86我得到:LoadLibrary(CppShellExtContextMenuHandler.dll)Failedtofindspecifiedprocedure(翻译)在XP机器

c++ - 在 Visual Studio 2010 中的 "break all"之后,一些线程的调用堆栈在我的 C++ 程序中几乎缺失

我的跨平台C++应用程序(使用Juce)的最新版本在Windows中可能存在死锁或可以想象的无限循环,但在Mac中没有,不幸的是我们目前没有Windows开发人员,所以这取决于我.我可以在VisualStudio2010下运行该程序但出现问题,然后当我遇到“active丢失”时:-D我使用了“全部中断”命令,这似乎暂停了我的所有线程。很好,而且大多数堆栈都非常合理。不幸的是,有几个线程(包括我怀疑处于死锁状态的两个线程)没有可用的调用堆栈。我非常清楚我的堆栈的“顶部”不会在那里,因为我没有调试信息,例如ntdll.dll。但我似乎只是从堆栈的中间得到了一点点。我包括了一个不好的堆栈和一

c - 微型筛选器驱动程序 : how to replace file content on open?

我有一个顶层微过滤器驱动和一个用户模式服务,类似于ScannerMSDNexample.我希望我的用户模式服务在记事本中打开时替换A.txt文件内容。因此,在IRP_MJ_CREATE操作后回调中,我向服务发送通知并等待它向文件写入新数据。但是服务无法打开A.txt,因为它已经被记事本锁定了。如何让我的服务在不使用内核的情况下写入数据FltWriteFile?这样做的最佳方法是什么?也许取消文件打开,让服务写入数据并用相同的参数重新打开它而不离开操作后回调?也许我应该在预操作中覆盖所需的访问权限?---任何信息将不胜感激。如果您认为这个问题缺乏细节,请告诉我。

c++ - std::regex_replace 给了我意想不到的结果

我在C++Windows项目(VisualStudio2010)中使用std::regex_replace。代码如下所示:std::stringstr("http://www.wikipedia.org/");std::regexfromRegex("http://([^@:/]+\\.)?wik(ipedia|imedia)\\.org/",std::regex_constants::icase);std::stringfmt("https://$1wik$2.org/");std::stringresult=std::regex_replace(str,fromRegex,fmt)

c++ - 如何在Windows上构建Botan合并文件botan_all.cpp和.h

正如标题所建议的那样,我尝试制作botan_all文件以将botan直接集成到我的项目中。我在我的Windows上安装了python并在控制台中运行以下命令:C:\Temp\Botan-1.11.16>configure.py--cc=msvc--single-amalgamation-file这导致以下输出:INFO:Platform:OS="Windows"machine="AMD64"proc="Intel64Family6Model58Stepping9,GenuineIntel"INFO:GuessingtargetOSiswindows(use--ostoset)INFO:

c++ - 用于控制对 "All Users\Application Data"中文件的访问的 Windows 服务

这是我的情况:我有一个使用配置文件的应用程序。配置文件适用于系统的所有用户,所有用户都可以更改配置。我决定将配置文件放在“AllUsers\ApplicationData”文件夹中。问题是该文件只能由创建它的用户写入。这是我的临时解决方案:创建文件时,应用程序会设置其安全选项,以便系统的所有用户都可以写入。然而,Ithinkthisisahack我想我必须创建一个服务来管理对文件的访问。我的应用程序是用C++(MFC)编写的,我不是所有.Net方面的专家。所以我的第一个想法是编写一个带有COM接口(interface)的WindowsC++服务,该服务将由应用程序调用。我的问题:我的想

c++ - AdjustTokenPrivileges 错误 ERROR_NOT_ALL_ASSIGNED

请告知下面代码中指出的错误,为什么会这样?我是C++的新手。我查看了StackO和MSDN(例如link),但它们对我没有帮助,因为我不知道自己做错了什么。HANDLEhToken;if(!OpenProcessToken(GetCurrentProcess(),TOKEN_ADJUST_PRIVILEGES|TOKEN_QUERY,&hToken)){returnFALSE;}{SetPrivilege(hToken,L"SeBackupPrivilege",1);BOOLSetPrivilege(HANDLEhToken,//accesstokenhandleLPCTSTRlpsz

windows - 使用 -replace 从 csv 中的单元格中删除带有特殊字符的字符串

我有一个CSV文件,例如:"localpath""C:\Users\calabresel""C:\Users\goslinep""C:\Users\deangelisr""C:\Users\bannont""C:\Users\goodwind"我正在寻找一种方法来将用户名与每个字段隔离开来。然后我将查询AD以确定每个用户是禁用还是启用。不过,我一直无法弄清楚如何获得最后一block。我的想法是使用-replace将相同的字符串替换为null,如下所示:$txt=import-csvpaths1.csv|%{$_.localpath=$_.localpath-replace"C:\Use

c# - ICorProfilerCallback2 : CLR profiler does not log all Leave calls

我正在尝试编写一个记录进程中所有.Net方法调用的分析器。目标是使其具有高性能,并在内存中保留最后5-10分钟(固定缓冲区,循环覆盖旧信息),直到用户触发将该信息写入磁盘。预期用途是追踪很少重现的性能问题。我从https://github.com/appneta/SimpleCLRProfiler的SimpleCLRProfiler项目开始.分析器使用.Net分析的ICorProfilerCallback2回调接口(interface)。我让它在我的环境中编译和工作(Win8.1、.Net4.5、VS2012)。但是,我注意到有时记录了Enter调用的Leave调用会丢失。Consol

c++ - Windows 驱动内核 : How enumerate all subdirectories and files?

我在一个小型的antirootkit中工作,我需要添加一个功能:删除rootkit目录和您可能的子目录中的所有文件。那么,首先有必要知道所有这些目录和文件,对吧?为此,我下面的代码已经完成了这项任务的一半。他枚举了特定目录的所有目录和文件,但不“查看”子目录(文件和文件夹)。例如:输出:代码:#includetypedefunsignedintUINT;NTSTATUSEnumFilesInDir(){HANDLEhFile=NULL;UNICODE_STRINGszFileName={0};OBJECT_ATTRIBUTESOa={0};NTSTATUSntStatus=0;IO_S