Skip to content

Latest commit

 

History

History
31 lines (27 loc) · 2.37 KB

README.md

File metadata and controls

31 lines (27 loc) · 2.37 KB

SDN-FlowControl

Description

This is a Malicious Data Flow Control System within Software Defined Networks, developed by myself during my bachelor's degree in Feb 2023. In this project, I:

  • Designed and implemented a malicious data flow control system using the Floodlight controller framework to enhance security.
  • Developed and integrated link flow detection and data flow decision-making modules for real-time threat mitigation.
  • Analyzed switch edge port data to monitor traffic patterns, adjusting system states to optimize performance.
  • Managed IP address pairs and processed incoming data packets, improving threat detection and response times.

How to run

To run this code, you have to install JDK 1.8 on your physical machine. This project use a Mininet platform in a Ubuntu virtual machine to simulate a simple SDN topology, and run a Floodlight Controller on the physical machine to send commands, thus control the traffic in the vm's network.

N.B. This project cannot be used independently. It has to be executed based on Java source code of Floodlight Controller. Due to the limitation of file size, I cannot upload it here.

The topology is as below:

Snipaste_2024-10-30_00-50-42

Sadly, I lost the script to set up a virtual network after reinstalling my OS.

Source file functions

  • entity/Bucket.java -> Bucket in group table entry
  • entity/FlowEntry.java -> defines the necessary fields in flow table entry, as well as methods for setting and getting fields
  • entity/GroupEntry.java -> defines the necessary fields in group table entry, as well as methods for setting and getting fields
  • sdn/Add.java -> creates flow table entry and adds flow table to switch
  • sdn/Delete.java -> deletes flow table entry
  • sdn/GroupAdd.java -> adds group table entry and adds group table to switch
  • sdn/List.java -> displays flow table entry
  • tools/Constant.java -> defines constants used in the experiment
  • tools/FlowTableTool.java -> defines operations for adding flow table entry to the specified switch and clearing flow table entry
  • tools/HttpRequest.java -> defines GET and POST methods used to send HTTP requests to the specified URL of the controller

Demo Video (Recorded In Chinese)

Watch the video