How to add a black hole attack in AODV protocol in ns2.
https://www.nsnam.com
You can download the source code here:
https://drive.google.com/open?id=1LFRrmJM3YXiQT3X1HMSFyS9T9d8oWlIx
https://drive.google.com/open?id=1LFRrmJM3YXiQT3X1HMSFyS9T9d8oWlIx
Black hole is the basic attack in a network, here we are going mitigate this attack in ns2.
Trust value, based on the trust value, if the value is less, then we can make it as an attacker node.
High trust, medium trust and low trust (integer)
Trusted or not (boolean)
To make a node attacker node (preferanly a black hole attack, how to do that?)
AODV protocol as it is easy to implement in ns2.
Step 1: Declare the attacker variable
We will two files aodv.h and aodv.cc files
in aodv.h file,
create a variable name as given below in the protected scope
bool attacker;
Step 2: initialise the attacker variable as false.
In aodv.cc file, initialise the attacker to be false inside the constructor.
Step 3: if a node is a blackhole, what happens to attacker value
in the command() function of aodv.cc file inside the block
if(argc==2), include the following lines
if(strncasecmp(argv[1], "blackhole") == 0) {
attacker=true;
return TCL_OK;
}
Step 4: If the node is an attacker node, what it will do?
if(attacker==true)
{
printf("Packets dropped by node number %d is %d \n",index,t_count++);
drop(p,DROP_RTR_ROUTE_LOOP);
}
Open the terminal and go to ~ns-2.35/ and execute the command
$] make
If no errors, in the above logic your compilation is successful.
Step 5: Run the TCL file with AODV protocol, with Attacker code and without attacker code and compare both the results.
$] ns AODV.tcl
You can compare the node with attacker and without attacker
Here is the comparison for an attacker node (node number 5)
When node 5 was an Attacker node, these are the results
Number of generated packets: 4
Number of sent packets: 2
Number of forwarded packets: 2
Number of received packets: 22
Number of dropped packets: 16
Number of lost packets: 0
Number of sent bytes: 204
Number of forwarded bytes: 88
Number of received bytes: 1000
Number of dropped bytes: 472
Minimal packet size: 40
Maximal packet size: 102
Average packet size: 49.6923
When node 5 was a good node, here is the result
Number of generated packets: 446
Number of sent packets: 446
Number of forwarded packets: 443
Number of received packets: 465
Number of dropped packets: 0
Number of lost packets: 0
Number of sent bytes: 373736
Number of forwarded bytes: 347724
Number of received bytes: 348764
Number of dropped bytes: 0
Minimal packet size: 32
Maximal packet size: 1598
Average packet size: 790.4165
You can watch for my forthcoming video (preferably tomorrow) on Tracegraph. Which is used in this tutorial.
Thanks for watching...
Subscribe to my channel and share it to your friends
Spread the knowledge..
Youtube.com/tspradeepkumar
https://www.nsnam.com
Stay Tuned...
T S Pradeep Kumar
I did see the source code for blackhole attack??? where is it Please????
ReplyDelete
Deletehttps://drive.google.com/open?id=1LFRrmJM3YXiQT3X1HMSFyS9T9d8oWlIx
Hello sir, Thank you so much for this video.
ReplyDeletecan i download the source codes please?
if yes , Then how?
please sir give the download the source codes link
code please
Deletehttps://drive.google.com/open?id=1LFRrmJM3YXiQT3X1HMSFyS9T9d8oWlIx
DeleteI am facing difficulties trying to download the codes. any help??
ReplyDeletePlease help me
ReplyDeletens: _o40 blackhole:
(_o40 cmd line 1)
invoked from within
"_o40 cmd blackhole"
invoked from within
"catch "$self cmd $args" ret"
invoked from within
"if [catch "$self cmd $args" ret] {
set cls [$self info class]
ns: _o40 blackhole :
ReplyDelete(_o40 cmd line 1)
invoked from within
"_o40 cmd blackhole"
invoked from within
"catch "$self cmd $args" ret"
invoked from within
"if [catch "$self cmd $args" ret] {
set cls [$self info class]
global errorInfo
set savedInfo $errorInfo
error "error when calling class $cls: $args" $..."
(procedure "_o40" line 2)
(SplitObject unknown line 2)
invoked from within
"_o40 blackhole "
i am getting this error while implementing black hole attack kidnly help me
Respected sir i've followed the above procedure but getting this error.
ReplyDeleteKindly help me out of this error, I shall be very thankful to you.
saifullah@saifullah-Inspiron-3542:~$ ns AODV.tcl
num_nodes is set 17
INITIALIZE THE LIST xListHead
ns: _o63 blackhole:
(_o63 cmd line 1)
invoked from within
"_o63 cmd blackhole"
invoked from within
"catch "$self cmd $args" ret"
invoked from within
"if [catch "$self cmd $args" ret] {
set cls [$self info class]
global errorInfo
set savedInfo $errorInfo
error "error when calling class $cls: $args" $..."
(procedure "_o63" line 2)
(SplitObject unknown line 2)
invoked from within
"_o63 blackhole"
wormhole code please
ReplyDeleteSir, respectfully, I hope you could at least reply comments because some of us actually followed the exact same thing as you did, but the output wasn't the same.
ReplyDeleteSir, Can i apply the same method to simulate Blackhole attack in Proactive routing protocols like DSDV and FSR.
ReplyDeleteHow would i apply blackhole attack in proactive routing protocol ?
ReplyDeletesir please, how i can simulate blackhole attack in leach protocol
ReplyDeleteGetting same error sir, please help
ReplyDelete_o40 blackhole :
(_o40 cmd line 1)
invoked from within
"_o40 cmd blackhole"
invoked from within
"catch "$self cmd $args" ret"
invoked from within
"if [catch "$self cmd $args" ret] {
set cls [$self info class]
global errorInfo
set savedInfo $errorInfo
error "error when calling class $cls: $args" $..."
(procedure "_o40" line 2)
(SplitObject unknown line 2)
invoked from within
"_o40 blackhole "
num_nodes is set 17
ReplyDeleteINITIALIZE THE LIST xListHead
ns: _o132 malicious:
(_o132 cmd line 1)
invoked from within
"_o132 cmd malicious"
invoked from within
"catch "$self cmd $args" ret"
invoked from within
"if [catch "$self cmd $args" ret] {
set cls [$self info class]
global errorInfo
set savedInfo $errorInfo
error "error when calling class $cls: $args" $..."
(procedure "_o132" line 2)
(SplitObject unknown line 2)
invoked from within
"_o132 malicious"
how can I resolve this please
num_nodes is set 17
ReplyDeleteINITIALIZE THE LIST xListHead
ns: _o132 malicious:
(_o132 cmd line 1)
invoked from within
"_o132 cmd malicious"
invoked from within
"catch "$self cmd $args" ret"
invoked from within
"if [catch "$self cmd $args" ret] {
set cls [$self info class]
global errorInfo
set savedInfo $errorInfo
error "error when calling class $cls: $args" $..."
(procedure "_o132" line 2)
(SplitObject unknown line 2)
invoked from within
"_o132 malicious"
please help me solve this problem
Hello sir,
ReplyDeletecan you provide the code for better understanding. In the drive basic code is there. Thank you
hi sir, where have malicious coding in tcl. please check your coding. I cant able to see in malcious.tcl
ReplyDeleteIts there in the Google Drive given....
DeleteThere is not AODV.tcl in youre Google Drive
Deletehttps://drive.google.com/drive/folders/1B4HN87qBg8Pc5LpfWq6ldOSe33ZYtv-6
Deleterespected sir, sir your drive link is not opening.it is showing "The requested URL was not found on this server. That’s all we know." when we click the link . Sir please provide us the correct drive link
ReplyDeleteIs any one have source codes
ReplyDeleteDear sir, follow all the steps you put here to add the malicious node (black-hole node). but while I run the blackhole.tcl file it gives an error message. when I add the malicious node ($ns at 0.0 "[$n(3) set ragent_] malicious). If I delete this malicious line it runs correctly. how do I correct it? please!! The error message is below:
ReplyDeletenum_nodes is set 7
INITIALIZE THE LIST xListHead
ns: _o127 malicious:
(_o127 cmd line 1)
invoked from within
"_o127 cmd malicious"
invoked from within
"catch "$self cmd $args" ret"
invoked from within
"if [catch "$self cmd $args" ret] {
set cls [$self info class]
global errorInfo
set savedInfo $errorInfo
error "error when calling class $cls: $args" $..."
(procedure "_o127" line 2)
(SplitObject unknown line 2)
invoked from within
"_o127 malicious"