Hack Like a Pro: How to Hack Web Apps, Part 6 (Using OWASP ZAP to Find Vulnerabilities)

Jan 27, 2016 07:13 PM
Article cover image

Welcome back, my tenderfoot hackers!

Web apps are often the best vector to an organization's server/database, an entry point to their entire internal network. By definition, the web app is designed to take an input from the user and send that input back to the server or database. In this way, the attacker can send their malicious input back to the servers and network if the web app is not properly secured.

OWASP is the Open Web Application Security Project, a vendor-neutral, non-profit group of volunteers dedicated to making web apps more secure. As such, they publish their OWASP Top 10 to showcase the most critical vulnerabilities, and have designed WebGoat, a deliberately vulnerable web application for teaching and testing web app security. As part of this effort, they have also developed the OWASP Zed Attack Proxy (ZAP) tool.

OWASP ZAP is a Java-based tool for testing web app security. It has an intuitive GUI and powerful features to do such things as fuzzing, scripting, spidering, proxying and attacking web apps. It is also extensible through a number of plugins. In this way, it is an all-in-one web app testing tool. OWASP ZAP might even become your go-to web app testing tool once you get the hang of it.

In this tutorial, we will take a look at this powerful and versatile tool.

Fire Up Kali

Let's begin in the usual way—by firing up Kali. In this tutorial, I will be using Kali 2.0 as so many of you are now using it, although I still have my reservations. Earlier versions of Kali also have OWASP ZAP, so if you are using those, you can also follow this tutorial.

Start OWASP ZAP

If you want to start OWASP ZAP from the command line, you can simply type:

kali > owasp-zap

This should start the application as seen below. It's slow, so be patient.

635894894077035935.jpg

For those who prefer the GUI approach, go to Applications -> Web Application Analysis -> owasp-zap. Again, be patient, as it will take awhile to load the tool.

635894894161433026.jpg

The first thing you will see is the license. Go ahead and accept the terms if you feel comfortable with them. This is a standard Apache license.

635894894268472624.jpg

The OWASP ZAP Interface

When OWASP ZAP eventually opens, it should look like the screenshot below. This tool has many powerful features, but initially, we will only try out its "Attack" function in the large right-hand window. In this mode, OWASP ZAP aggressively goes to the website we designate and begins to look for vulnerabilities.

635894894375668401.jpg

Attacking a Website

In this first tutorial, let's test a website initially left vulnerable and safe to test, webscantest.com. Put the URL in the space next to "URL to attack" and then simply click on the "Attack" button below it.

635894894471300800.jpg

OWASP ZAP will now begin to spider and test the web application for numerous vulnerabilities.

Attack Results & Alerts

When it has completed its work (this can be considerable time for large websites), you should see a screen like that below.

635894894573965019.jpg

As you can see in the lower left window, OWASP ZAP has sent us 8 alerts. These alerts are categorized by the type of vulnerability. In this case, these are:

  • Cross Site Scripting
  • Remote OS Command Injection
  • Directory Browsing
  • X-Frame-Options Header Not Set
  • Cookie set without HttpOnly flag
  • Password Autocomplete in browser
  • Web Browser XSS Protection Not Enabled
  • X-Content-Type-Options Header Missing

Next to each category of alert is a number that represents the number of occurrences of that type of vulnerability. If you click on the arrow next to the alert, it will expand to show you each occurrence of the vulnerability.

635894894667722289.jpg

In the screenshot above, I first clicked on the alert "Cross Site Scripting" and it opened a window with information on it to the right reflecting the application's assessment of the risk (High) and confidence (Medium). Then, I expanded the alert to show each of the XSS vulnerabilities in this web app.

The next step, of course, is to test each of the reported vulnerabilities to see whether they are real.

Install the Proxy into Firefox

For ease of use, we can install the "Plug-n-Hack" extension in Firefox 24 or later browsers (Iceweasel, the default browser in Kali, is a fork of the Mozilla Firefox project). From the Quick Start menu, you can see the "Plug-n-Hack" button. Simply click on it to install the extension into your browser.

635894894758041938.jpg

Iceweasel will open with the following screen. Go ahead and select "Click to setup!"

635894894859468273.jpg

You will get a warning like that below; go ahead and click "Allow."

635893957141351193.jpg

Finally, go ahead and install the add-on to your browser.

635894894983926930.jpg

Now, you can just use your browser and whatever website you are visiting will be automatically available to the OWASP ZAP application.

In future tutorials, we will further explore the capabilities of this powerful web app testing application, so keep coming back my tenderfoot hackers!

Just updated your iPhone? You'll find new Apple Intelligence capabilities, sudoku puzzles, Camera Control enhancements, volume control limits, layered Voice Memo recordings, and other useful features. Find out what's new and changed on your iPhone with the iOS 18.2 update.

Related Articles

Comments

No Comments Exist

Be the first, drop a comment!