补丁
扫雷游戏啊下补丁
在扫雷游戏中,点关闭弹出一个确认框,确认之后再关闭,取消就不关闭
data:image/s3,"s3://crabby-images/649af/649af670979c496b27c9a22f47ea1242f093834b" alt="img"
- 首先第一步就是确认关闭按钮响应的位置,一般都是 WM_CLOSE 的消息 ,消息响应一般都在过程函数,所以就是要定位到过程函数,我们知道 MC 项目中 ,如果是重叠类的窗口,注册窗口类的时候会用到过程函数, 如果是对话框的 那就是调 DialogBox
- 先假设扫雷是一个 重叠类窗口 那我们就要知道程序中那个地方调用了 RegisterClass (注册窗口类)
-
最笨的方法就是一步步跟,但比较耗时间
- 使用OD自带的功能,帮助我们定位在哪些地方,调用了哪些导入函数,只显示当前加载的
data:image/s3,"s3://crabby-images/397e3/397e318b9d6044fb5033f7d2b1b19b0f7f608f85" alt="img"
data:image/s3,"s3://crabby-images/3f21b/3f21b5197cfb377adac9b1e5d9a18442432c8ce6" alt="img"
data:image/s3,"s3://crabby-images/34d29/34d29cdeec408810a27b8b24b7ad4a332c36eb96" alt="img"
data:image/s3,"s3://crabby-images/825f8/825f86838dbbf857c81179960a070080cbbd091b" alt="img"
data:image/s3,"s3://crabby-images/27d7b/27d7bc7753030e85e7d38bd690c8bccf6ca06141" alt="img"
data:image/s3,"s3://crabby-images/e32a0/e32a0b6ecf2f9c4b9633fa4f796ee945f28fa678" alt="img"
data:image/s3,"s3://crabby-images/fb99a/fb99a0b219feb05643c0f3cab97552f86e643dc3" alt="img"
在所有调用地方设置断点
data:image/s3,"s3://crabby-images/1ddb0/1ddb050d0212a8875eab8456c57f56f3afc3ef98" alt="img"
- 下好断点后开始调试, F9 运行到断点处
注册窗口类第一个参数是窗口类的地址,
data:image/s3,"s3://crabby-images/765ea/765ea372a4bf88c560b0d73f949cbbfe95ce6a1c" alt="img"
窗口类第二个参数是函数地址,第一个是风格
data:image/s3,"s3://crabby-images/3b7d1/3b7d115d9831bf8569ba31d9119441508e590ed4" alt="img"
data:image/s3,"s3://crabby-images/44f2a/44f2a12e298dd1a36e7ff9a5e448e19ba647be26" alt="img"
data:image/s3,"s3://crabby-images/8ec19/8ec193daed44ab643166e7586b529abf5be5a31d" alt="img"
- 寻找 WM_CLOSE 消息,可以通过条件断点寻找
data:image/s3,"s3://crabby-images/9bfe5/9bfe538ee4e52453c557eec7821c1245b9e3fedf" alt="img"
分析可知 , 参数入栈顺序是 最后一个参数,倒数第二个参数........,第一个参数,返回地址,二消息id是通过 第三个参数 WPARAM 所以参数位置在 esp + 8 处
data:image/s3,"s3://crabby-images/a17dd/a17ddee2dd3fda138048afcb12869789b0998a2b" alt="img"
data:image/s3,"s3://crabby-images/c27df/c27df3a11ff1dae87dd8ca1c974061c7e4425ebf" alt="img"
- 在关闭游戏,这样就可以触发 WM_CLOSE 消息,从而触发断点,在 F8 单步运行,看到哪部跳走
可以看出它调用了 默认过程函数,并没有自己处理关闭消息,所以我们只能 自己来 判断是不是WM_CLOSE 消息,然后我们自己来处理 ,如果是 WM_CLOSE ,那么就需要我们去弹窗,不是的话就交给过程函数去处理
- 我们要处理 WM_CLOSE 消息,那么就需要去写代码,但是又不能覆盖他原本的代码,因此他们有代码地方我们都不能用,只能找空白的地方写
data:image/s3,"s3://crabby-images/fdacd/fdacd265dd5d19075170fd16cc3f7366e3fe8af2" alt="img"
记录一下我们们写代码的地方
我们汇编代码开始位置
01004A60 00 db 00
data:image/s3,"s3://crabby-images/a2574/a257474aeb3d5e251f4bf5582032f79cca157c9f" alt="img"
通过之前我们跟代码,可以知道,程序是从该处跳转到 默认过程函数的,因此我们可以将此处改成 跳转到我们的代码处,然后再由我们跳转回来
原来的跳转地址
01001C16 |. /0F85 8D050000 jnz 010021A9
函数退出位置
010021BB |> \5F pop edi
通过空格单击, ,修改汇编代码,来修改跳转位置
data:image/s3,"s3://crabby-images/44b6b/44b6b0ebf7ba49b2a50dfe461e23fc8dc5b2bc0d" alt="img"
选中修改后的地址,跳转过去开始写我们的汇编代码
data:image/s3,"s3://crabby-images/f3f06/f3f0601d8a65a8bf8c72b525bd6f593200d64134" alt="img"
data:image/s3,"s3://crabby-images/5a388/5a3888c20073d0e506df909aa037aa4a376e11b6" alt="img"
接下来相等就要弹窗 ,首先要有提示语,需要保存到文本
data:image/s3,"s3://crabby-images/14e90/14e9060ad9cd0cdb39d539bfd664844b7360f62a" alt="img"
data:image/s3,"s3://crabby-images/35938/3593807c12ce253377ddc1b8af5a1172462cfadb" alt="img"
data:image/s3,"s3://crabby-images/b4599/b4599e61a41e88614f0c36551ac5ff2492e5a880" alt="img"
- 调用弹窗函数
data:image/s3,"s3://crabby-images/2b9e3/2b9e321ae47d06db1e33d05f519081d07c13dd3a" alt="img"
标题,文本入栈
data:image/s3,"s3://crabby-images/2cf71/2cf71cd858f42dc31a85b8aec87bc705a6cf9f8f" alt="img"
data:image/s3,"s3://crabby-images/71ca9/71ca93a62db2e67dc0e43394d1d523e821904b8a" alt="img"
窗口句柄入栈
data:image/s3,"s3://crabby-images/7e1b5/7e1b55ca3f47169f7564cf1c9d8803656fef8151" alt="img"
调用函数
data:image/s3,"s3://crabby-images/2ef70/2ef706e328036778ba1c06843c4bd16233a4e42e" alt="img"
判断点击按钮
data:image/s3,"s3://crabby-images/03a8a/03a8a53a97be4b5739a8914de4326cb47162b5df" alt="img"
判断,是确定就挑转到 默认过程处理函数,否则退出函数
data:image/s3,"s3://crabby-images/910dc/910dcc8e5b1e1355ed612bcf62a7724ff8f909ee" alt="img"
data:image/s3,"s3://crabby-images/4d0e5/4d0e536d4c40893d208816026a75a05b95b4a882" alt="img"
data:image/s3,"s3://crabby-images/0b81d/0b81d93af50ea553db26e45e8f7722de999dae35" alt="img"
但是这个时候我们写的代码还只是在内存里面,程序一旦重启 就都没了,因此我们要保存到可执行文件
data:image/s3,"s3://crabby-images/974df/974df5c18088857b2713fc91bdc5faaf123d688f" alt="img"
data:image/s3,"s3://crabby-images/ceafa/ceafaae662a59a3d8c210fddc48aaefbe26716fd" alt="img"
data:image/s3,"s3://crabby-images/368d6/368d66c1de868daa8a0d53377ea002d004c8c874" alt="img"
- 保存文件运行
这是点击退出,发现出现了弹窗提示
data:image/s3,"s3://crabby-images/cc5a5/cc5a59ba43ce756bcfd37b0213c8a82a46921df9" alt="img"
data:image/s3,"s3://crabby-images/fec56/fec562897bcf40720b0de6ccd431b5ca9e251c33" alt="img"
注意: 找空白位置不要到最后,不然按可能报错,位置有规律,但是要学pe
data:image/s3,"s3://crabby-images/2b36d/2b36d234b69f3f41ddfba1bd43a48e7446ae4247" alt="img"
通过OD 下断点/取消断点 alt +b
data:image/s3,"s3://crabby-images/43ef8/43ef8bb95686ecca24ede4364978588c6a83aeed" alt="img"
如果有断点 ,选中 del
程序 F9 运行后
data:image/s3,"s3://crabby-images/20a86/20a86da32ff00db56e1b2d63337e542b6d20ebb3" alt="img"
data:image/s3,"s3://crabby-images/68337/683377b70948b69b3eca493cc6f6adaafc52b4ef" alt="img"
data:image/s3,"s3://crabby-images/60766/6076668fd4648de618e19062275c4adbfd6e94a3" alt="img"
data:image/s3,"s3://crabby-images/04f95/04f95b5b5418ba5d2d9c7f975c7205126a74a2bb" alt="img"
data:image/s3,"s3://crabby-images/b71ab/b71abd9ec1d164d6fa16c121685d537b39fd3f25" alt="img"
在Crack Me 下补丁
使其提示成功
Brad Soblesky.1.zip(4 KB)
data:image/s3,"s3://crabby-images/f337f/f337f35d53fc076b8860e01d3aaa99c7df786d65" alt="image.png"
方法1: 定位 command 消息
data:image/s3,"s3://crabby-images/edc98/edc983cd0955f7e22eeca48b1930895bb31f0aff" alt="image.png"
data:image/s3,"s3://crabby-images/8c738/8c73840204e646908eb3bf73b9b850ebbed0b0dc" alt="image.png"
或者
data:image/s3,"s3://crabby-images/dc648/dc648f4cd88e0d842fbf5a7c5f1fe1812b56e51d" alt="image.png"
data:image/s3,"s3://crabby-images/27ac2/27ac2d36e61c39249723fdacc67237102136d648" alt="image.png"
f9 运行 到断点 ,在 f8 单步运行
data:image/s3,"s3://crabby-images/fb7bb/fb7bbdc6fcb4d570907495d8a321288d3dc5065f" alt="image.png"
可以看到,运行到系统的 dll 中,所以这不是一个 重叠类窗口,所以过程函数不是自己的,无法用上面方法,所以要换个f方法
因为 他失败成功都会弹出一个对话框,里面有字符串,因此我们可以通过 OD 的字符串查找功能
data:image/s3,"s3://crabby-images/86a20/86a2008a3f3dacb0cf672912e1d65a3294f70fa1" alt="image.png"
data:image/s3,"s3://crabby-images/f4012/f4012a0e84560680d3f3b5ba15baaf4a708b0363" alt="image.png"
data:image/s3,"s3://crabby-images/325aa/325aa459c792145c0c328730bcc6aea2df93f9c8" alt="image.png"
data:image/s3,"s3://crabby-images/44e02/44e0232db9cce6227bc11fea8566a770f63bc10c" alt="image.png"
查看上面的代码
data:image/s3,"s3://crabby-images/ec38d/ec38d3f262ed057a994a299e7595a2e4434ad5b1" alt="image.png"
在此处下点,就可以看到比较的字符串,即正确的字符串
data:image/s3,"s3://crabby-images/ea0b8/ea0b88d2b60dfcab422dbea8a1d78608d5b69f62" alt="image.png"
或者直接去掉比较,那么不管输出字符串是啥,都可以成功
data:image/s3,"s3://crabby-images/283b0/283b0ae4761ccd989e506e12380c80e3058cacf9" alt="image.png"
data:image/s3,"s3://crabby-images/3235e/3235e28b6c4f793a562490322d1639e06b520ab2" alt="image.png"
将文件保存
data:image/s3,"s3://crabby-images/cd22b/cd22b30d25f7eefdecab6b241e265318886ee906" alt="image.png"
运行我们保存的文件,发下不管输入什么字符串都可以通过了,即破解成功了
注册机
当遇到非明码比较时,上面的方法就行不通,因为密码是通过 加密解密得到的
data:image/s3,"s3://crabby-images/da913/da913d237839e3fb10250b7d2505026e44aeb2cb" alt="image.png"
输入2行字符串,验证通过
Brad Soblesky.2.zip(4 KB)
首先定位到字符串,下断点
data:image/s3,"s3://crabby-images/63f26/63f26daf67072c68ba37b9a8392a877831505be3" alt="image.png"
往上找代码,在函数入口出下断点
data:image/s3,"s3://crabby-images/cade8/cade81d0bdc6b91f4c48278248ca17370ada3237" alt="image.png"
跟一下大体流程,通过跟代码,我们可以知道
data:image/s3,"s3://crabby-images/5cb9a/5cb9aa7be9248ad3f48672e4940879e5fb2607d9" alt="image.png"
data:image/s3,"s3://crabby-images/1534e/1534e06210bc6cf6b6017ff69f4821762fde3f1e" alt="image.png"
data:image/s3,"s3://crabby-images/90428/90428b0ccd6bb1c626349dcbbc779d569285916f" alt="image.png"
F4 运行到光标处,运行完循环 ,继续运行
data:image/s3,"s3://crabby-images/b019b/b019b4482feff9428fc21ffd9462c3522a9a5f6a" alt="image.png"
data:image/s3,"s3://crabby-images/a381b/a381bd1c465a885a2c7efabc06e83bfe3f92b6ca" alt="image.png"
断点继续跟
data:image/s3,"s3://crabby-images/f0c78/f0c784b47a33d0d4d8fa190d4be4e7ce6cd48b78" alt="image.png"
data:image/s3,"s3://crabby-images/3724c/3724caa24a7644ed79c7fef8d6ab8bd1a0f8c80b" alt="image.png"
data:image/s3,"s3://crabby-images/1aa4c/1aa4caa0e31c6cd7a5051172a0773e772fa766e2" alt="image.png"
加注释于0040163B
data:image/s3,"s3://crabby-images/1182e/1182e17d5ef570aecaf4326ae18ca39f7dd57a7d" alt="image.png"
因此可以分析出,程序是那我们输入的字符串做一系列运算,再把结果格式化后去跟第二个字符串 作比较,我们把上面格式化后的字符串拿去测试,可以发现通过了,所以猜想是正确的
data:image/s3,"s3://crabby-images/8fb21/8fb21592350d4d0721ec3192b027934a1ceb8bea" alt="image.png"
上面软件已经提供了加密算法,因此写该软件的注册机可以直接把他的代码复制出来来就可以了
data:image/s3,"s3://crabby-images/72ef4/72ef43fe18ccb6a2d12f97a067356310021e9de1" alt="image.png"
L000:
mov edx, dword ptr [ebp-20]
add edx, 1
mov dword ptr [ebp-20], edx
mov eax, dword ptr [ebp-20]
cmp eax, dword ptr [ebp-1C]
jge short 0040161A
mov ecx, dword ptr [ebp-20]
push ecx
lea ecx, dword ptr [ebp-14]
call 00401900
movsx edx, al
mov eax, dword ptr [ebp-10]
add eax, edx
mov dword ptr [ebp-10], eax
mov ecx, dword ptr [ebp-20]
shl ecx, 8
mov edx, dword ptr [ebp-10]
xor edx, ecx
mov dword ptr [ebp-10], edx
mov eax, dword ptr [ebp-20]
add eax, 1
mov ecx, dword ptr [ebp-1C]
imul ecx, dword ptr [ebp-20]
not ecx
imul eax, ecx
mov edx, dword ptr [ebp-10]
imul edx, eax
mov dword ptr [ebp-10], edx
jmp L000
上面还有很多参数,必须我们去分析
data:image/s3,"s3://crabby-images/adaeb/adaeb0fd0e4e8313bbaa3bb0e905cec44948d535" alt="image.png"
新建工程
data:image/s3,"s3://crabby-images/afdbd/afdbd1ac18257807d3bece6dea636973f8a61788" alt="image.png"
模板,根据自己需要选择
剩下的不用动,一直下一步完成就行
data:image/s3,"s3://crabby-images/31004/31004ad624e640f0378b1165ba09d9e57a749754" alt="image.png"
GIST\REGIST.ASM
data:image/s3,"s3://crabby-images/0b448/0b448107e2fd052b47bfb2248b9501ad450e0951" alt="image.png"
S\ADMINISTRATOR\DESKTOP\03 补丁\REGIST\REGIST.ASM]
data:image/s3,"s3://crabby-images/7ccf0/7ccf0f107d5f44b770bcff062ec37c8ede229027" alt="image.png"
编译和链接,链接之前记得编译资源脚本,或者直接构建
添加资源
data:image/s3,"s3://crabby-images/1207a/1207a02c10729513a4bf34ec50b923cf6a0c7979" alt="image.png"
如果给控件添加名字需要自己手动加到头文件
data:image/s3,"s3://crabby-images/b60a0/b60a04a385e45fc2b54faa61019f80e19c9e5bf3" alt="image.png"
data:image/s3,"s3://crabby-images/046d1/046d1a1a0af887bcab8a5193579b8e425f7ed986" alt="image.png"
下面就开始写注册机了
L000:
mov edx, dword ptr [ebp-20]
add edx, 1
mov dword ptr [ebp-20], edx
mov eax, dword ptr [ebp-20]
cmp eax, dword ptr [ebp-1C]
jge short 0040161A
mov ecx, dword ptr [ebp-20]
push ecx
lea ecx, dword ptr [ebp-14]
call 00401900
movsx edx, al
mov eax, dword ptr [ebp-10]
add eax, edx
mov dword ptr [ebp-10], eax
mov ecx, dword ptr [ebp-20]
shl ecx, 8
mov edx, dword ptr [ebp-10]
xor edx, ecx
mov dword ptr [ebp-10], edx
mov eax, dword ptr [ebp-20]
add eax, 1
mov ecx, dword ptr [ebp-1C]
imul ecx, dword ptr [ebp-20]
not ecx
imul eax, ecx
mov edx, dword ptr [ebp-10]
imul edx, eax
mov dword ptr [ebp-10], edx
jmp L000
首选要对函数进行分析
通过跟代码发现 ebp-20 是一个局部变量,作用是计数器
ebp-1c 是输入字符长度
data:image/s3,"s3://crabby-images/ba7c7/ba7c74f3aa8152f73520c157d13d29fe1c97894b" alt="img"
这里是去字符串读取 所以可以用 lodsb 替换
几位下来就剩 ebp-10 ,ebp-1c .找到最开始出现的地方,来观察数据变化
data:image/s3,"s3://crabby-images/434d4/434d46737e625a265fc72ff6d591e96f82094a95" alt="img"
通过几次不同测试,发现值 是固定的
data:image/s3,"s3://crabby-images/ddd5b/ddd5bb5d620a2d1a77cab0cb99eedd7e6805ada1" alt="img"
data:image/s3,"s3://crabby-images/e4ce2/e4ce265defc337540da4b8320f86dde5a303eba9" alt="img"
注册机源码
.386
.model flat, stdcall ;32 bit memory model
option casemap :none ;case sensitive
include Regist.inc
.data
g_szUserName db 50 dup(0) ;用户名
g_szSerial db 50 dup(0) ;注册码
g_szFmt db "%lu" ,0 ;格式化字符串
.code
start:
invoke GetModuleHandle,NULL
mov hInstance,eax
invoke InitCommonControls
invoke DialogBoxParam,hInstance,IDD_DIALOG1,NULL,addr DlgProc,NULL
invoke ExitProcess,0
;########################################################################
Make proc hWin:HWND ;加密
LOCAL @dwIdx:DWORD
LOCAL @dwCnt:DWORD
LOCAL @dwEdp_10:DWORD
LOCAL @dwEdp_14:DWORD
;回去文本输入的值
invoke GetDlgItemText,hWin,EDT_USERNAME,offset g_szUserName,size g_szUserName ;获取用户名内容
mov @dwCnt,eax
mov @dwIdx,0
mov esi ,offset g_szUserName
mov @dwEdp_10,81276345H
jmp LSATART
;对用户名加密解密
L000:
mov edx, @dwIdx
add edx, 1
mov @dwIdx, edx
LSATART:
mov eax, @dwIdx
cmp eax, @dwCnt
jge LEND
;mov ecx, @dwIdx
;push ecx
;lea ecx, dword ptr [ebp-14]
;call 00401900
lodsb ;上面四行作用
movsx edx, al
mov eax, @dwEdp_10
add eax, edx
mov @dwEdp_10, eax
mov ecx, @dwIdx
shl ecx, 8
mov edx, @dwEdp_10
xor edx, ecx
mov @dwEdp_10, edx
mov eax, @dwIdx
add eax, 1
mov ecx, dword ptr @dwCnt
imul ecx, @dwIdx
not ecx
imul eax, ecx
mov edx, @dwEdp_10
imul edx, eax
mov @dwEdp_10,edx
jmp L000
LEND:
;格式化字符串
invoke wsprintf,offset g_szSerial,offset g_szFmt,@dwEdp_10
;显示到界面
invoke SetDlgItemText,hWin,EDT_SERUNMBER,offset g_szSerial
Make endp
DlgProc proc hWin:HWND,uMsg:UINT,wParam:WPARAM,lParam:LPARAM
mov eax,uMsg
.if eax==WM_INITDIALOG
.elseif eax==WM_COMMAND
mov eax,wParam
.if eax == BTN_MAKE
invoke Make,hWin
.endif
.elseif eax==WM_CLOSE
invoke EndDialog,hWin,0
.else
mov eax,FALSE
ret
.endif
mov eax,TRUE
ret
DlgProc endp
end start
作业
📎作业文件.zip
1. 修改机器码指令对照表.exe的字体
思路:
\1. sendmessage给callwindow发消息 然后绘制界面,sendmessage的第一个消息就是设置字体的
\2. 调用 CreateFontA 它有个设置字体的那块 设置完毕后会发个消息 找消息循环上面的发消息那块 就能看见有个函数,在获取系统字体 然后把这个函数换掉,换成跳转到自己的代码处 改完再跳回来
HFONT CreateFontA(
[in] int cHeight,
[in] int cWidth,
[in] int cEscapement,
[in] int cOrientation,
[in] int cWeight,
[in] DWORD bItalic,
[in] DWORD bUnderline,
[in] DWORD bStrikeOut,
[in] DWORD iCharSet,
[in] DWORD iOutPrecision,
[in] DWORD iClipPrecision,
[in] DWORD iQuality,
[in] DWORD iPitchAndFamily,
[in] LPCSTR pszFaceName
);
data:image/s3,"s3://crabby-images/f7dfb/f7dfb2ec450d15ef9f426a0078aa9ec62f1818cc" alt="image.png"
data:image/s3,"s3://crabby-images/ddb9d/ddb9dbeb7c4302f2bcff5d8130122a6eba91264a" alt="image.png"
- COM Explorer_Setup 注册机,汇编实现。
详情见 day05 补课
思路: 根据弹窗标题搜字符串,往上找到分支跳,定位到关键函数,找到算法代码,(算法代码使用四则运算和位运算比较多),然后把代码抽出来去分析,失败分支那里肯定有校验的算法
data:image/s3,"s3://crabby-images/08654/0865467a64e10d778bee445dd126b676c2c43366" alt="image.png"
data:image/s3,"s3://crabby-images/57312/573124336fab343597afee6b7ab512eb5b3c745f" alt="image.png"
找到成功或失败分支
data:image/s3,"s3://crabby-images/61ace/61ace860ee51674dae8010571dd2f00bfda27b0b" alt="image.png"
L000:
mov ebp, dword ptr [463E48]
or ecx, FFFFFFFF
mov edi, ebp
xor eax, eax
repne scas byte ptr es:[edi]
not ecx
dec ecx
mov eax, esi
xor edx, edx
mov edi, ebp
div ecx
mov ecx, dword ptr [esp+14]
mov eax, esi
movsx ebx, byte ptr [edx+ebp]
xor edx, edx
div ecx
movsx eax, byte ptr [edx+469968]
lea edx, dword ptr [eax+eax*2]
lea eax, dword ptr [eax+edx*4]
mov edx, esi
imul edx, esi
imul edx, esi
imul edx, ecx
add ebx, eax
or ecx, FFFFFFFF
xor eax, eax
add ebx, edx
repne scas byte ptr es:[edi]
not ecx
dec ecx
mov eax, ebx
xor edx, edx
div ecx
lea ecx, dword ptr [esp+10]
mov al, byte ptr [edx+ebp]
push eax
call 0042F29A
test esi, esi
je L048
mov eax, esi
xor edx, edx
mov ecx, 3
div ecx
test edx, edx
jnz L048
push 004640F8
lea ecx, dword ptr [esp+14]
call 0042F273
L048:
inc esi
cmp esi, 9
jb L000
data:image/s3,"s3://crabby-images/b24a8/b24a8b23325aa4aab26a2ad0129b32fda12844f2" alt="img"
data:image/s3,"s3://crabby-images/ba23d/ba23d36bfc83acf26f50b7748fca769defc9fd11" alt="img"
data:image/s3,"s3://crabby-images/493e2/493e2ec7eea83d2025fe1bb789c6092821b8d988" alt="img"