Note from the Editor: This blog is the 2nd installment of an 8-part blog series entitled, The Complete Web Application Penetration Test Guide. To read the series from the beginning, please go to the blog, What is a Web Application Penetration Test?
A web application penetration test takes a look at the security of external or internal application for your organization. This type of testing goes above and beyond standard network-level penetration testing.
It focuses on the both the unauthenticated and authenticated portions of a website.
But why do web application penetration testing? What threats are you addressing? What questions will it answer?
This article will help clarify what information we get through web application penetration testing and why this type of cybersecurity testing is important to your institution.
1. Can an unauthorized individual break into my application?
This may seem obvious, but it’s also one of the highest risks to any application that’s available on the Internet. The second part of this question which helps put the risk in context is, if they do get in, what information can they gain access to/exfiltrate?
2. Is any sensitive information stored in the application being disclosed publicly to unauthenticated users?
Many web application penetration tests have revealed misconfigurations that resulted in databases or folders being shared openly. Too often, these shares contain sensitive information such as health information (ePHI), personally identifiable information (PII), user credentials, credit card data (PCI), etc.
It doesn’t have to be a sophisticated attack that compromises your application. An impartial set of eyes helps reliably uncover these types of issues.
3. In a multi-tenant application, can one organizational user access the information of another organization?
Web application penetration testing will cover information disclosure/bleed between tenants in a shared application space. For SaaS providers specifically, this can be the worst-case scenario where one authenticated user to your application can see the data of another user or organization within the application.
4. Can a low-level user escalate their privileges to that of an application administrator?
A web application penetration test can answer this situation, also referred to as “vertical movement.”
Can a user become an administrator or take administrative actions within the app?
This can lead to confidentiality, integrity, and availability issues. These vulnerabilities can also increase the severity of other vulnerabilities discovered.
For example, it is bad if an unauthorized individual can gain access to the application as a low level user. It’s worse if that user can then escalate their privileges and become an administrator.
5. Can one user view/modify the information of another user?
Web application penetration testing can answer this question, also referred to as “horizontal movement.”
Can one user become another user or take actions on their behalf?
If you were a user of a banking website and some other user could transfer money out of your account, that’d be pretty scary right?
6. Can a user trick the website into giving them free services/products?
For e-commerce websites, this is a significant concern.
Can a user change the pricing information of products?
Web application penetration testing will identify logic errors and other issues that could allow a user to bypass certain protections or controls.
Is a user able to break out of sequential process (e.g. choose a car -> pass a credit check -> pay for car -> receive car) or modify certain web requests to only pay $1 for a $500 item?
7. Can an external attacker or user gain access to the underlying web server?
Could this application be used as an entry point to your organization’s internal network?
Many application-layer vulnerabilities can quickly turn your web application into foothold on the internal network for an external attacker. Injection style attacks, server-side template injection, command execution, etc. can all provide access to the underlying host.
8. Can weaknesses in my web application be used as a weapon against my institution?
Some misconfigurations with your web application could be used as part of a social engineering attack. Username enumeration on your application could allow an attacker to build a list of your users that they can then use for password attacks on your other externally exposed services.
9. Can an attacker deface the site in any way that would potentially harm my institution’s brand image?
For many higher education institutions this can be an incredibly important question. If an attacker is able to compromise your website, even if that can’t gain access to any sensitive data, public defacement could cause immediate negative effects to brand image, shareholder confidence, etc.
If you had the choice of using Amazon or Microsoft for web hosting services, and one of them suddenly had unsavory images and content all over their main website, it would probably affect your decision.
10. Is the web server configured according to security best practice?
Knowing this is important not just for overall security posture, but also for compliance. Host server and web server configurations can provide defense in depth for your applications.
Furthermore, they are also important for a lot of organizations to maintain compliance with required standards, such as HIPAA or PCI.
If you’d to know more about how web application penetration testing can help your institution, please schedule a call today.
About the Author:
JR Johnson is the Director of Penetration Testing at SIG. He holds a BS in Computer Science Engineering from the University of Florida and a MS in Information Assurance and Cybersecurity from the Florida Institute of Technology. JR is an avid collector of security-related certifications, including OSCP, OSWE, GWAPT, CISSP, C|EH, CISA, and PCI QSA. You can find him on Twitter @InfoSecJR.