Skip to content

Implementation of some scenarios of man-in-the-middle attack & pharming attack.

Notifications You must be signed in to change notification settings

hy-qqqqq/mitm_pharm_attack

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MITM & Pharming Attacks in Wi-Fi Networks

Project in Computer Security Capstone.

Concepts

  • Redirect victim's traffic to attacker
    • MITM - ARP spoofing - requires IP, MAC.
  • Encrypted sessions - sslsplit
    • MITM - sslsplit - do ARP spoofing first.
    • PHARM - redirect HTTP requests to a phishing web page.

Scenario

Attack scenario

Implementation

Collect default gateway and host information

HOST_IP = get_if_addr(conf.iface)  # default interface
HOST_MAC = get_if_hwaddr(conf.iface) # default interface
GW_IP = conf.route.route("0.0.0.0")[2] # gateway
SUBNET = GW_IP + '/24'

Man-in-the-middle attack

  1. Scan interfaces
    • scapy or netifaces
    • Send ARP request packets to subnet, get MAC from the answered responses.
  2. ARP spoofing (consider both uplink and downlink)
    • Send ARP reply packets to all possible victims. (modify the below fields)
      • Source MAC: Attacker MAC
      • Souce IP: AP IP
    • Send ARP reply packets to AP. (modify the below fields)
      • Source MAC: Attacker MAC
      • Source IP: Victim IP
  3. Split SSL/TLS session
    • Generate RSA key and certificate by openssl
    • Enable IP forwarding
      • sysctl -w net.ipv4.ip_forward=1
    • Set NAT rules to redirect connections to ports: 8080, 8443
    • sslsplit command
  4. Intercept username and password
    • parse HTTP content (input box)

Pharming attack

  1. Scan interfaces
  2. ARP spoofing
    • In order to do DNS spoofing, we need to become the middle man first, so that we can intercept the packet and then forward it.
  3. DNS spoofing
    • Since we have the ability to intercept and forward packets, we can modify the values in the packet when capturing it, and then forward it.
    • scapy + netfilterqueue
      • Add a rule in iptables, so that whenever a packet is forwarded, redirect it to the netfilter queue with number 0.
      • iptables -I FORWARD -j NFQUEUE --queue-num 0
    • DNS format
      • Check if the packet is in IP + UDP + DNS + DNSRR structure
      • Keep the original IP + UDP layers
      • Replace the original DNS layer with self created DNS layer with only one qd + one an

Usage

Build mitm_attack & pharm_attack & generate key, certificate

make

Clean

make clean

Run programs

./mitm_attack
./pharm_attack

About

Implementation of some scenarios of man-in-the-middle attack & pharming attack.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published