During a security audit, a web application using an outdated version of the Symfony framework was identified. The analysis revealed the presence of the Symfony Profiler tool, which is commonly used for debugging applications during development.
The Profiler provides detailed information about the application's operation, which is useful for developers. However, in a production environment, its availability can lead to the disclosure of sensitive information and, in some cases, remote code execution on the server.
Access to the Symfony Profiler ToolAccessing the Symfony Profiler is possible by navigating to the /app_dev.php endpoint on the server. Upon accessing the page, a toolbar appears, providing access to various diagnostic features, as shown in the screenshot below:
Sensitive Information Accessible in the Profiler The Profiler can expose a wide range of information about the application, including:
• PHP configuration details through the phpinfo() function:
data:image/s3,"s3://crabby-images/c9fa0/c9fa0d6368135587a1677ab41647179d85bfaf81" alt=""
• Error details generated during HTTP requests:
data:image/s3,"s3://crabby-images/c9fa0/c9fa0d6368135587a1677ab41647179d85bfaf81" alt=""
• Contents of configuration files, including files containing access credentials or secret tokens:
Remote Code Execution In critical cases, the availability of the Symfony Profiler can allow an attacker to extract a secret token from the configuration files. This token can then be used to exploit another Symfony feature – the /_fragment endpoint. By leveraging this mechanism, an attacker can achieve remote code execution (RCE) on the server.
An exploit demonstrating this attack is publicly available in the following repository: https://github.com/ambionics/symfony-exploits.
After successful exploitation, remote code execution can be confirmed by a result displayed in the browser:
Audit Findings in Other Applications During the audit, other web applications with the Symfony Profiler enabled were also identified. However, in these cases, the attack described above could not be successfully executed. Despite the inability to escalate the issue to full RCE, the presence of the Profiler in a production environment still poses a significant security risk.
Recommendations To secure web applications against this attack vector, the following steps are recommended:
1. Disable access to the Symfony Profiler in production environments.
2. Upgrade the Symfony framework to the latest stable version.
3. Ensure unique "secret" tokens are used for each application instance.
4. Perform regular security audits to identify potential configuration issues.
Implementing these recommendations can significantly reduce the risk of sensitive data exposure and potential attacks leading to remote code execution on production servers.
#Cybersecurity #WebSecurity #SessionFixation #PenTesting #SecureApplications