CVE-2020-25291:金山WPSOffice远程堆溢出漏洞分析

0x01 漏洞描述

网站建设哪家好,找创新互联!专注于网页设计、网站建设、微信开发、微信平台小程序开发、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了尼开远免费建站欢迎大家使用!

WPS Office是适用于Microsoft Windows,macOS,Linux,iOS和Android的办公软件,由总部位于珠海的中国软件开发商金山软件公司开发。WPS Office由三个主要组件组成:WPS Writer,WPS Presentation和WPS Spreadsheet。个人基本版本可以免费使用,WPS Office软件中存在一个远程执行代码漏洞,是当Office软件在分析特制Office文件时不正确地处理内存中的对象时引起的。成功利用此漏洞的攻击者可以在当前用户的上下文中运行任意代码。漏洞可能会导致拒绝服务,易受攻击的产品WPS Office,影响版本11.2.0.9453。

0x02 漏洞分析

在WPS Office中用于图像格式解析的Qt模块中发现存在堆溢出。嵌入WPS office的特制图像文件可能会触发此漏洞。打开特制的文档文件时,触发访问冲突。EDX指向数组的指针,而EAX是指向数组的索引。

 
 
 
  1. 0:000> g
  2. (c50.b4): Access violation - code c0000005 (first chance)
  3. First chance exceptions are reported before any exception handling.
  4. This exception may be expected and handled.
  5. eax=000000c0 ebx=006f1c48 ecx=cd2aefbc edx=cd2c6f80 esi=2ed7ae18 edi=0000001c
  6. eip=6ba13321 esp=006f1b44 ebp=006f1b44 iopl=0 nv up ei pl nz na po ;nc ;
  7. cs=0023 ss=002b ds=002b es=002b fs=0053 gs=002b efl=00210202
  8. QtCore4!QMatrix::dy+0x48a8:
  9. 6ba13321 8b448210 mov eax,dword ptr [edx+eax*4+10h] ds:002b:cd2c7290=????????

崩溃是如何触发的?让我们看一下PNG标头格式。

 
 
 
  1. 00029E30 FF 89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 ÿ‰PNG........IHD
  2. 00029E40 52 00 00 02 80 00 00 01 C6 04 03 00 00 00 16 0A R...€...Æ.......
  3. 00029E50 27 FC 00 00 00 04 67 41 4D 41 00 00 B1 88 95 98 'ü....gAMA..±ˆ•˜
  4. 00029E60 F4 A6 00 00 00 30 50 4C 54 45 00 00 00 80 00 00 ô¦...0PLTE...€..
  5. 00029E70 00 80 00 80 80 00 00 00 80 80 00 80 00 80 80 80 .€.€€...€€.€.€€€
  6. 00029E80 80 80 C0 C0 C0 FF 00 00 00 FF 00 FF FF 00 00 00 €€ÀÀÀÿ...ÿ.ÿÿ...
  7. 00029E90 FF FF 00 FF 00 FF FF FF FF FF 7B 1F B1 C4 00 00 ÿÿ.ÿ.ÿÿÿÿÿ{.±Ä..

从偏移量0x29E31开始-0x29E34是PNG文件格式的签名标头。PNG头文件的结构:

 
 
 
  1. PNG signature --> IHDR --> gAMA --> PLTE --> pHYs --> IDAT --> IEND

在这种情况下,当WPS Office Suite中使用的QtCore库解析PLTE结构并触发堆溢出时,该漏洞位于Word文档中的嵌入式PNG文件中。在偏移量0x29E82到0x29E85处,调色板的解析失败,从而触发了堆中的内存损坏。崩溃触发之前的堆栈跟踪:

 
 
 
  1. 00 00ee1790 6b8143ef QtCore4!path_gradient_span_gen::path_gradient_span_gen+0x6a71
  2. 01 00ee17f0 6b814259 QtCore4!QBrush::setMatrix+0x234
  3. 02 00ee58d4 6b8249a4 QtCore4!QBrush::setMatrix+0x9e
  4. 03 00ee58ec 6b80cc84 QtCore4!QImage::rect+0x22b
  5. 04 00ee5908 6b857ccc QtCore4!QTransform::inverted+0xec8
  6. 05 00ee629c 6b81c55b QtCore4!QSvgFillStyle::setFillOpacity+0x1b59
  7. 06 00ee6480 6b896844 QtCore4!QPainter::drawPixmap+0x1c98
  8. 07 00ee6574 6d1e0fbd QtCore4!QPainter::drawImage+0x325
  9. 08 00ee6594 6d0dd155 kso!GdiDrawHoriLineIAlt+0x11a1a

在QtCore4解析嵌入式图像之前,我们可以看到来自KSO模块的最后一次调用,试图处理图像kso!GdiDrawHoriLineIAlt。使用IDA Pro分解应用程序来分析发生异常的函数。最后的崩溃路径如下(WinDBG结果):

 
 
 
  1. QtCore4!QMatrix::dy+0x48a8:
  2. 6ba13321 8b448210 mov eax,dword ptr [edx+eax*4+10h] ds:002b:cd2c7290=????????

在IDA Pro中打开时,我们可以按以下方式反汇编该函数:

 
 
 
  1. .text:67353315 push ebp
  2. .text:67353316 mov ebp, esp
  3. .text:67353318 movzx eax, byte ptr [ecx+edx] ; crash here
  4. .text:6735331C mov ecx, [ebp+arg_0]
  5. .text:6735331F mov edx, [ecx]
  6. .text:67353321 mov eax, [edx+eax*4+10h]
  7. .text:67353325 mov ecx, eax

使用crashs转储中的信息,我们知道应用程序在0x67353321(mov eax,[edx + eax * 4 + 10h])处触发了访问冲突。我们可以看到EAX寄存器由0xc0值控制。因此,从这里我们可以根据导致异常的指令对寄存器的状态进行一些假设。需要注意的重要一点是,在发生异常之前,我们可以看到ECX(0xc0)中包含的值被写入到以下指令所定义的任意位置:

 
 
 
  1. mov ecx, [ebp+arg_0]

此外,我们注意到,在我们的故障指令之外,EBP的偏移量存储在ECX寄存器中。我们在前面提到的指令(偏移量为0x6ba1331c)上设置了一个断点,以观察内存。断点触发后,我们可以看到第一个值c45adfbc指向另一个指针,该指针应该是指向数组的指针。

 
 
 
  1. Breakpoint 0 hit
  2. eax=0000000f ebx=004f1b40 ecx=d3544100 edx=0000001c esi=d1200e18 edi=0000001c
  3. eip=6ba1331c esp=004f1a34 ebp=004f1a34 iopl=0 nv up ei pl nz na po ;nc ;
  4. cs=0023 ss=002b ds=002b es=002b fs=0053 gs=002b efl=00200202
  5. QtCore4!QMatrix::dy+0x48a3:
  6. 6ba1331c 8b4d08 mov ecx,dword ptr [ebp+8] ss:002b:004f1a3c=c45adfbc
  7. 0:000> dc ebp+8
  8. 004f1a3c c45adfbc 00000048 00000000 6f13830f ..Z.H..........o
  9. 004f1a4c 004f5cc8 00000000 00000000 00000000 .\O.............
  10. 004f1a5c 00000000 004f65a0 004f662c 00000000 .....eO.,fO.....
  11. 004f1a6c 779eae8e 00000000 00000001 3f800000 ...w...........?
  12. 004f1a7c 3f800000 3f31e4f8 3f800000 3f800000 ...?..1?...?...?
  13. 004f1a8c 3f800000 3f31e4f8 3f800000 3de38800 ...?..1?...?...=
  14. 004f1a9c 3de38800 3d9e1c8a 3c834080 004f3c00 ...=...=.@.<.
  15. 004f1aac 4101c71c 6ba13315 3f800000 4081c71c ...A.3.k...?...@

从c45adfbc观察内存引用,发现另一个指针。第一个值ab69cf80始终表示为指向它所引用的任何地方的指针。指针ab69cf80基本上是我们指针的索引数组。

 
 
 
  1. 0:000> dc c45adfbc
  2. c45adfbc ab69cf80 d3544100 00000003 00000280 ..i..AT.........
  3. c45adfcc 0000055a 00000012 c0c0c0c0 1c3870e2 Z............p8.
  4. c45adfdc 40ad870e 1c3870e2 40ad870e 00000000 ...@.p8....@....
  5. c45adfec 00000000 c0c0c0c1 6c1d12c0 00000000 ...........l....
  6. c45adffc c0c0c0c0 ???????? ???????? ???????? ....????????????
  7. c45ae00c ???????? ???????? ???????? ???????? ????????????????
  8. c45ae01c ???????? ???????? ???????? ???????? ????????????????
  9. c45ae02c ???????? ???????? ???????? ???????? ????????????????
  10. 0:000> dc ab69cf80
  11. ab69cf80 00000001 0000001c 00000010 00000001 ................ // 0000001c is overwritten in the register EDX and EDI before we trigger crash
  12. ab69cf90 ff000000 ff800000 ff008000 ff808000 ................
  13. ab69cfa0 ff000080 ff800080 ff008080 ff808080 ................
  14. ab69cfb0 ffc0c0c0 ffff0000 ff00ff00 ffffff00 ................ // ffc0c0c0 where it will be stored in EAX after crash, at the moment it only takes 0xf value in EAX
  15. ab69cfc0 ff0000ff ffff00ff ff00ffff ffffffff ................
  16. ab69cfd0 c0c0c0c0 c0c0c0c0 c0c0c0c0 c0c0c0c0 ................
  17. ab69cfe0 c0c0c0c0 c0c0c0c0 c0c0c0c0 c0c0c0c0 ................
  18. ab69cff0 c0c0c0c0 c0c0c0c0 c0c0c0c0 c0c0c0c0 ................

因为我们知道崩溃的路径,所以可以使用下面的命令简单地设置一个断点。该命令将获得指针值“ edx + eax * 4 + 10”,并检查其是否满足0xc0。

 
 
 
  1. bp 6ba13321 ".if (poi(edx+eax*4+10) == 0xc0) {} .else {gc}"
  2. 0:000> g
  3. eax=000000c0 ebx=004f1b40 ecx=c45adfbc edx=ab69cf80 esi=d1200e18 edi=0000001c
  4. eip=6ba13321 esp=004f1a34 ebp=004f1a34 iopl=0 nv up ei pl nz na po ;nc ;
  5. cs=0023 ss=002b ds=002b es=002b fs=0053 gs=002b efl=00200202
  6. QtCore4!QMatrix::dy+0x48a8:
  7. 6ba13321 8b448210 mov eax,dword ptr [edx+eax*4+10h] ds:002b:ab69d290=????????

观察堆栈,可以看到以下执行:

 
 
 
  1. 004f1a38 6ba3cb98 QtCore4!path_gradient_span_gen::path_gradient_span_gen+0x6a74
  2. 004f1a3c c45adfbc
  3. 004f1a40 00000048
  4. 004f1a44 00000000
  5. 004f1a48 6f13830f verifier!DphCommitMemoryForPageHeap+0x16f
  6. 004f1a4c 004f5cc8
  7. 004f1a50 00000000
  8. 004f1a54 00000000
  9. 004f1a58 00000000
  10. 004f1a5c 00000000
  11. 004f1a60 004f65a0
  12. 004f1a64 004f662c
  13. 004f1a68 00000000
  14. 004f1a6c 779eae8e ntdll!RtlAllocateHeap+0x3e

如果我们反汇编6ba3cb98,则可以看到以下反汇编代码,真正的漏洞根本原因在于此代码。

 
 
 
  1. 6ba3cb89 8b96b4000000 mov edx,dword ptr [esi+0B4h]
  2. 6ba3cb8f 8b4df4 mov ecx,dword ptr [ebp-0Ch]
  3. 6ba3cb92 52 push edx
  4. 6ba3cb93 8bd7 mov edx,edi
  5. 6ba3cb95 ff5580 call dword ptr [ebp-80h]
  6. 6ba3cb98 8b4e7c mov ecx,dword ptr [esi+7Ch]
  7. C pseudo code
  8. grad = *(&ptr_grad);
  9. if ( grad > 0.0099999998 )
  10. {
  11. input_value = grad_size(check, size, input);
  12. ptr_grad = *(input);
  13. ... cut here ...

我们在6ba3cb89地址上设置断点并观察ESI + 0xB4,我们可以看到一个指针指向另一个位置:

 
 
 
  1. 0:000> r
  2. eax=00000000 ebx=00791878 ecx=00000005 edx=00793938 esi=cb07de18 edi=0000001c
  3. eip=6ba3cb89 esp=00791780 ebp=00791870 iopl=0 nv up ei pl nz na po ;nc ;
  4. cs=0023 ss=002b ds=002b es=002b fs=0053 gs=002b efl=00200202
  5. QtCore4!path_gradient_span_gen::path_gradient_span_gen+0x6a65:
  6. 6ba3cb89 8b96b4000000 mov edx,dword ptr [esi+0B4h] ds:002b:cb07decc=cf69afbc
  7. 0:000> dc esi+0B4h
  8. cb07decc cf69afbc c0c0c000 00000000 00000100 ..i.............
  9. cb07dedc c0c0c0c0 00000000 00000000 00000000 ................
  10. cb07deec 00000000 00000000 00000000 00000000 ................
  11. cb07defc 00000000 cf030fd0 00000000 00000000 ................
  12. cb07df0c 00000000 00000000 00000000 00000000 ................
  13. cb07df1c c0c0c0c0 00000000 3ff00000 00000000 ...........?....
  14. cb07df2c 00000000 00000000 00000000 00000000 ................
  15. cb07df3c 00000000 00000000 3ff00000 00000000 ...........?....
  16. 0:000> dc cf69afbc
  17. cf69afbc c88baf80 d1326100 00000003 00000280 .....a2.........
  18. cf69afcc 0000055f 00000012 c0c0c0c0 1c3870e2 _............p8.
  19. cf69afdc 40ad870e 1c3870e2 40ad870e 00000000 ...@.p8....@....
  20. cf69afec 00000000 c0c0c0c1 6c1d12c0 00000000 ...........l....
  21. cf69affc c0c0c0c0 ???????? ???????? ???????? ....????????????
  22. cf69b00c ???????? ???????? ???????? ???????? ????????????????
  23. cf69b01c ???????? ???????? ???????? ???????? ????????????????
  24. cf69b02c ???????? ???????? ???????? ???????? ????????????????
  25. 0:000> dc c88baf80
  26. c88baf80 00000001 0000001c 00000010 00000001 ................
  27. c88baf90 ff000000 ff800000 ff008000 ff808000 ................
  28. c88bafa0 ff000080 ff800080 ff008080 ff808080 ................
  29. c88bafb0 ffc0c0c0 ffff0000 ff00ff00 ffffff00 ................
  30. c88bafc0 ff0000ff ffff00ff ff00ffff ffffffff ................
  31. c88bafd0 c0c0c0c0 c0c0c0c0 c0c0c0c0 c0c0c0c0 ................
  32. c88bafe0 c0c0c0c0 c0c0c0c0 c0c0c0c0 c0c0c0c0 ................
  33. c88baff0 c0c0c0c0 c0c0c0c0 c0c0c0c0 c0c0c0c0 ................

从这里我们可以知道代码实际上没有从指针释放任何东西。一旦移至EDX,EDX将保留指向索引数组的指针:

 
 
 
  1. eax=00000000 ebx=00791878 ecx=00000005 edx=cf69afbc esi=cb07de18 edi=0000001c
  2. eip=6ba3cb8f esp=00791780 ebp=00791870 iopl=0 nv up ei pl nz na po ;nc ;
  3. cs=0023 ss=002b ds=002b es=002b fs=0053 gs=002b efl=00200202
  4. QtCore4!path_gradient_span_gen::path_gradient_span_gen+0x6a6b:
  5. 6ba3cb8f 8b4df4 mov ecx,dword ptr [ebp-0Ch] ss:002b:00791864=d1326100
  6. 0:000> dc cf69afbc
  7. cf69afbc c88baf80 d1326100 00000003 00000280 .....a2.........
  8. cf69afcc 0000055f 00000012 c0c0c0c0 1c3870e2 _............p8.
  9. cf69afdc 40ad870e 1c3870e2 40ad870e 00000000 ...@.p8....@....
  10. cf69afec 00000000 c0c0c0c1 6c1d12c0 00000000 ...........l....
  11. cf69affc c0c0c0c0 ???????? ???????? ???????? ....????????????
  12. cf69b00c ???????? ???????? ???????? ???????? ????????????????
  13. cf69b01c ???????? ???????? ???????? ???????? ????????????????
  14. cf69b02c ???????? ???????? ???????? ???????? ????????????????
  15. 0:000> dc c88baf80
  16. c88baf80 00000001 0000001c 00000010 00000001 ................
  17. c88baf90 ff000000 ff800000 ff008000 ff808000 ................
  18. c88bafa0 ff000080 ff800080 ff008080 ff808080 ................
  19. c88bafb0 ffc0c0c0 ffff0000 ff00ff00 ffffff00 ................
  20. c88bafc0 ff0000ff ffff00ff ff00ffff ffffffff ................
  21. c88bafd0 c0c0c0c0 c0c0c0c0 c0c0c0c0 c0c0c0c0 ................
  22. c88bafe0 c0c0c0c0 c0c0c0c0 c0c0c0c0 c0c0c0c0 ................
  23. c88baff0 c0c0c0c0 c0c0c0c0 c0c0c0c0 c0c0c0c0 ................

崩溃后的堆栈跟踪:

 
 
 
  1. 0:000> kvL
  2. # ChildEBP RetAddr Args to Child
  3. 00 012f18d4 6ba3cb98 cc53afbc 00000048 00000000 QtCore4!QMatrix::dy+0x48a8
  4. 01 012f19d0 6b8143ef 00000000 012f1b78 012f1a5c QtCore4!path_gradient_span_gen::path_gradient_span_gen+0x6a74
  5. 02 012f1a30 6b814259 0000002e 012f5bd0 00000000 QtCore4!QBrush::setMatrix+0x234
  6. 03 012f5b14 6b8249a4 0000003b 012f5b68 cc780e18 QtCore4!QBrush::setMatrix+0x9e
  7. 04 012f5b2c 6b80cc84 0000003b 012f5b68 cc780e18 QtCore4!QImage::rect+0x22b
  8. 05 012f5b48 6b857ccc 0000003b 012f5b68 cc780e18 QtCore4!QTransform::inverted+0xec8
  9. 06 012f64dc 6b81c55b 00000000 003c0000 00000000 QtCore4!QSvgFillStyle::setFillOpacity+0x1b59
  10. 07 012f66c0 6b896844 012f6724 cc818ff0 0000001c QtCore4!QPainter::drawPixmap+0x1c98
  11. 08 012f67b4 6d1e0fbd 012f69ec 012f66d4 012f6864 QtCore4!QPainter::drawImage+0x325
  12. 09 012f67d4 6d0dd155 012f6a54 012f69ec 012f6864 kso!GdiDrawHoriLineIAlt+0x11a1a
  13. 0a 012f67ec 6d0c8d88 012f69ec 012f68e0 012f6864 kso!kpt::PainterExt::drawBitmap+0x23

堆分析:

 
 
 
  1. 0:000> !heap -p -a cc53afbc
  2. address cc53afbc found in
  3. _DPH_HEAP_ROOT @ 6731000
  4. in busy allocation ( DPH_HEAP_BLOCK: UserAddr UserSize - VirtAddr VirtSize)
  5. cc36323c: cc53afa8 58 - cc53a000 2000
  6. 6f13ab70 verifier!AVrfDebugPageHeapAllocate+0x00000240
  7. 77a9909b ntdll!RtlDebugAllocateHeap+0x00000039
  8. 779ebbad ntdll!RtlpAllocateHeap+0x000000ed
  9. 779eb0cf ntdll!RtlpAllocateHeapInternal+0x0000022f
  10. 779eae8e ntdll!RtlAllocateHeap+0x0000003e
  11. 6f080269 MSVCR100!malloc+0x0000004b
  12. 6f08233b MSVCR100!operator new+0x0000001f
  13. 6b726c67 QtCore4!QImageData::create+0x000000fa
  14. 6b726b54 QtCore4!QImage::QImage+0x0000004e
  15. 6b7a0e21 QtCore4!png_get_text+0x00000436
  16. 6b79d7a8 QtCore4!QImageIOHandler::setFormat+0x000000de
  17. 6b79d457 QtCore4!QPixmapData::fromFile+0x000002bf
  18. 6b725eb4 QtCore4!QImageReader::read+0x000001e2
  19. 6d0ca585 kso!kpt::VariantImage::forceUpdateCacheImage+0x0000254e
  20. 6d0c5964 kso!kpt::Direct2DPaintEngineHelper::operator=+0x00000693
  21. 6d0c70d0 kso!kpt::RelativeRect::unclipped+0x00001146
  22. 6d0c8d0c kso!kpt::VariantImage::forceUpdateCacheImage+0x00000cd5
  23. 6d451d5c kso!BlipCacheMgr::BrushCache+0x0000049a
  24. 6d451e85 kso!BlipCacheMgr::GenerateBitmap+0x0000001d
  25. 6d453227 kso!BlipCacheMgr::GenCachedBitmap+0x00000083
  26. 6d29bb92 kso!drawing::PictureRenderLayer::render+0x000009b6
  27. 6d450fb1 kso!drawing::RenderTargetImpl::paint+0x00000090
  28. 6d29b528 kso!drawing::PictureRenderLayer::render+0x0000034c
  29. 6d2a2d83 kso!drawing::VisualRenderer::render+0x00000060
  30. 6d2b8970 kso!drawing::SingleVisualRenderer::drawNormal+0x000002b5
  31. 6d2b86a7 kso!drawing::SingleVisualRenderer::draw+0x000001e1
  32. 6d2b945e kso!drawing::SingleVisualRenderer::draw+0x00000046
  33. 6d3d0142 kso!drawing::ShapeVisual::paintEvent+0x0000044a
  34. 680a2b5c wpsmain!WpsShapeTreeVisual::getHittestSubVisuals+0x000068f1
  35. 6d0e36df kso!AbstractVisual::visualEvent+0x00000051
  36. 6d3cbe97 kso!drawing::ShapeVisual::visualEvent+0x0000018f
  37. 6d0eba90 kso!VisualPaintEvent::arriveVisual+0x0000004e
  38. 0:000> dt _DPH_BLOCK_INFORMATION cc780e18-0x20
  39. verifier!_DPH_BLOCK_INFORMATION
  40. +0x000 StartStamp : 0xc0c0c0c0
  41. +0x004 Heap : 0xc0c0c0c0 Void
  42. +0x008 RequestedSize : 0xc0c0c0c0
  43. +0x00c ActualSize : 0xc0c0c0c0
  44. +0x010 Internal : _DPH_BLOCK_INTERNAL_INFORMATION
  45. +0x018 StackTrace : 0xc0c0c0c0 Void
  46. +0x01c EndStamp : 0xc0c0c0c0

段中的最后一个堆条目通常是一个空闲块。堆块的状态指示为空闲块,堆块声明前一个块的大小为00108,而当前块的大小为00a30。前一块报告其自身大小为0x20字节,不匹配。位置为05f61000的堆块的使用似乎是该堆块的使用导致以下块的元数据损坏的可能性。堆块如下:

 
 
 
  1. 0:000> !heap -a 05f60000
  2. Index Address Name Debugging options enabled
  3. 1: 05f60000
  4. Segment at 05f60000 to 0605f000 (00001000 bytes committed)
  5. Flags: 00000002
  6. ForceFlags: 00000000
  7. Granularity: 8 bytes
  8. Segment Reserve: 00100000
  9. Segment Commit: 00002000
  10. DeCommit Block Thres: 00000200
  11. DeCommit Total Thres: 00002000
  12. Total Free Size: 00000146
  13. Max. Allocation Size: fffdefff
  14. Lock Variable at: 05f60258
  15. Next TagIndex: 0000
  16. Maximum TagIndex: 0000
  17. Tag Entries: 00000000
  18. PsuedoTag Entries: 00000000
  19. Virtual Alloc List: 05f6009c
  20. Uncommitted ranges: 05f6008c
  21. 05f61000: 000fe000 (1040384 bytes)
  22. FreeList[ 00 ] at 05f600c0: 05f605b8 . 05f605b8
  23. 05f605b0: 00108 . 00a30 [100] - free
  24. Segment00 at 05f60000:
  25. Flags: 00000000
  26. Base: 05f60000
  27. First Entry: 05f604a8
  28. Last Entry: 0605f000
  29. Total Pages: 000000ff
  30. Total UnCommit: 000000fe
  31. Largest UnCommit:00000000
  32. UnCommitted Ranges: (1)
  33. Heap entries for Segment00 in Heap 05f60000
  34. address: psize . size flags state (requested size)
  35. 05f60000: 00000 . 004a8 [101] - busy (4a7)
  36. 05f604a8: 004a8 . 00108 [101] - busy (107) Internal
  37. 05f605b0: 00108 . 00a30 [100]
  38. 05f60fe0: 00a30 . 00020 [111] - busy (1d)
  39. 05f61000: 000fe000 - uncommitted bytes.
  40. 0:000> dd 05f60fe0
  41. 05f60fe0 a9b3c836 03007087 05f6008c 05f6008c
  42. 05f60ff0 05f60038 05f60038 05f61000 000fe000
  43. 05f61000 ???????? ???????? ???????? ????????
  44. 05f61010 ???????? ???????? ???????? ????????
  45. 05f61020 ???????? ???????? ???????? ????????
  46. 05f61030 ???????? ???????? ???????? ????????
  47. 05f61040 ???????? ???????? ???????? ????????
  48. 05f61050 ???????? ???????? ???????? ????????

0x03 披露时间表

该漏洞于2020年8月报告,披露时间表:

  •  2020-08-04-将电子邮件发送到公开提供的WPS的各种邮件列表(销售和支持)。
  •  2020-08-10-WPS团队回应该报告可以转发给他们。
  •  2020-08-11-要求进一步的信息,例如向适当的渠道披露等。
  •  2020-08-17-根据先前的要求与WPS团队进行跟进。
  • 2020-08-18-通过电子邮件提供技术报告和概念验证(未加密)。
  •  2020-08-25-WPS跟进报告进度。
  •  2020-08-26-WPS更新说此问题已转发给开发团队。
  • 2020-08-28-WPS发送了一封电子邮件,指出该问题已在最新的下载版本11.2.0.9403中得到解决。
  •  2020-08-28-针对提供的PoC测试了新版本,并确认问题已解决。
  •  2020-08-28-向WPS团队寻求咨询或更改日志更新。
  •  2020-09-03-申请漏洞CVE。
  •  2020-09-14-已分配CVE编号:CVE-2020-25291。

 本文翻译自:http://zeifan.my/security/rce/heap/2020/09/03/wps-rce-heap.html如若转载,请注明原文地址。

网站题目:CVE-2020-25291:金山WPSOffice远程堆溢出漏洞分析
文章分享:http://www.mswzjz.cn/qtweb/news24/72124.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能