Welcome To Savi Savi Nenapu

Naveen Chinthakaaya

Thursday, June 1, 2023

DSniff


"dsniff is a collection of tools for network auditing and penetration testing. dsniff, filesnarf, mailsnarf, msgsnarf, urlsnarf, and webspy passively monitor a network for interesting data (passwords, e-mail, files, etc.). arpspoof, dnsspoof, and macof facilitate the interception of network traffic normally unavailable to an attacker (e.g, due to layer-2 switching). sshmitm and webmitm implement active monkey-in-the-middle attacks against redirected SSH and HTTPS sessions by exploiting weak bindings in ad-hoc PKI." read more...

Website: http://www.monkey.org/~dugsong/dsniff/

Related word

  1. Pentest Tools For Windows
  2. Pentest Tools For Ubuntu
  3. Underground Hacker Sites
  4. Wifi Hacker Tools For Windows
  5. Hacking Tools For Mac
  6. Pentest Tools Review
  7. Hak5 Tools
  8. Hacking Tools For Pc
  9. Hacking Tools Download
  10. Hacking Tools Software
  11. Tools 4 Hack
  12. Pentest Tools Framework
  13. Hack Tools Github
  14. Hak5 Tools
  15. Pentest Tools Online
  16. New Hack Tools
  17. Wifi Hacker Tools For Windows
  18. Free Pentest Tools For Windows
  19. Black Hat Hacker Tools
  20. Hack Tools Download
  21. World No 1 Hacker Software
  22. Growth Hacker Tools
  23. Hacking Tools Software
  24. Hacking App
  25. Beginner Hacker Tools
  26. Pentest Tools Github
  27. Hacking Tools For Pc
  28. Pentest Tools Website
  29. Pentest Tools Tcp Port Scanner
  30. Hacking Tools Online
  31. Hack Tools For Mac
  32. How To Hack
  33. Hacking Tools For Beginners
  34. Physical Pentest Tools
  35. Hack Tools For Pc
  36. Hack App
  37. Top Pentest Tools
  38. Blackhat Hacker Tools
  39. Hack Tools
  40. Hacking Tools For Windows Free Download
  41. Hack Tools For Windows
  42. Hack Website Online Tool
  43. Pentest Tools For Ubuntu
  44. Best Hacking Tools 2019
  45. Hacker Security Tools
  46. Hacking Tools Hardware
  47. How To Make Hacking Tools
  48. Computer Hacker
  49. Hacker Tools Apk
  50. Hacking Tools Mac
  51. Tools 4 Hack
  52. Hacking Tools Free Download
  53. Hack Tools For Windows
  54. Pentest Tools Nmap
  55. Growth Hacker Tools
  56. Hacker Tools
  57. Best Hacking Tools 2020
  58. Pentest Tools Find Subdomains
  59. Pentest Tools Kali Linux
  60. Hacker Tools Software
  61. Hack Tools
  62. Hacking Tools Windows 10
  63. Hacking Tools For Windows
  64. Pentest Tools Subdomain
  65. Game Hacking
  66. Hacker Tools Online
  67. Hacker Tools For Windows
  68. Hacker Tools Windows
  69. Best Hacking Tools 2020
  70. Hackrf Tools
  71. Hacker Tools
  72. Hacker Tools Online
  73. Blackhat Hacker Tools
  74. What Is Hacking Tools
  75. Hack Tools For Pc
  76. Hacker Tools Apk Download
  77. Hacking Tools For Games
  78. Hacking Tools For Windows
  79. Kik Hack Tools
  80. World No 1 Hacker Software
  81. Pentest Reporting Tools
  82. Hack App
  83. New Hack Tools
  84. Pentest Tools Github
  85. Hacking App
  86. Hacking Tools Online
  87. Hack Tools For Pc
  88. Hacker Tools 2020
  89. Pentest Tools Find Subdomains
  90. Hacker Tools Hardware
  91. Pentest Tools Url Fuzzer
  92. Pentest Tools For Ubuntu
  93. Hack Tools Pc
  94. Hack Website Online Tool
  95. Hacking Tools Free Download
  96. Free Pentest Tools For Windows
  97. How To Install Pentest Tools In Ubuntu
  98. Pentest Automation Tools
  99. Hack Rom Tools
  100. Best Hacking Tools 2019
  101. Hacking Tools Pc
  102. Pentest Tools For Windows
  103. Hacking Tools Free Download
  104. Hacker
  105. Easy Hack Tools
  106. Bluetooth Hacking Tools Kali
  107. Pentest Tools Review
  108. Hacker
  109. Hack Tools Mac
  110. Hacking Tools Hardware
  111. Android Hack Tools Github
  112. Pentest Tools Kali Linux
  113. Wifi Hacker Tools For Windows
  114. Hacking Tools Name
  115. Hack Tools Download
  116. Underground Hacker Sites
  117. Hack Apps
  118. Hacker Tools Software
  119. Nsa Hack Tools Download
  120. Hack Rom Tools
  121. Wifi Hacker Tools For Windows
  122. How To Hack
  123. Hacker Tools Linux
  124. Hack Tool Apk
  125. Hacker Tools Linux
  126. Hacking Tools Software
  127. Best Pentesting Tools 2018
  128. Free Pentest Tools For Windows
  129. Pentest Tools Free
  130. Best Hacking Tools 2020
  131. Hacking Tools
  132. Hacker Tools Github
  133. Pentest Tools Framework
  134. Pentest Tools Open Source
  135. Hacker Tools Software
  136. Hacker Tools Apk Download
  137. World No 1 Hacker Software
  138. Hacking Tools
  139. Install Pentest Tools Ubuntu
  140. Hacker Tools Software
  141. Hacks And Tools
  142. Hacking Tools 2019
  143. Pentest Tools Website Vulnerability
  144. Pentest Box Tools Download
  145. What Is Hacking Tools
  146. Hack Tools For Windows
  147. Pentest Tools Github
  148. Hack Tools 2019
  149. Pentest Box Tools Download
  150. Hacker Tools For Mac
  151. Hacker Tools Linux
  152. Hack Tools For Pc
  153. Hacker Tools
  154. Hack Tool Apk
  155. Hack Tool Apk
  156. Pentest Recon Tools
  157. Hackrf Tools
  158. Hack Rom Tools
  159. Hacking Tools For Kali Linux
  160. Computer Hacker
  161. Hacker Tools Github
  162. Pentest Tools Port Scanner
  163. Pentest Automation Tools
  164. Bluetooth Hacking Tools Kali
  165. Free Pentest Tools For Windows
  166. Hacking Tools Online
  167. Hacker Tools Apk
  168. Hacker Tools For Mac
  169. How To Make Hacking Tools
  170. Hacker Tools
  171. Hackrf Tools
  172. Pentest Tools Download
  173. Install Pentest Tools Ubuntu
  174. Hack Tool Apk No Root
  175. Pentest Tools For Android

Pointers Part 1: The Basics



So you're eager to learn about pointers but unfortunately you got stuck because they seemed to you terrible in nature? That's not true I know, but many of the people get confused when they arrive at the topic of pointers. Well pointers are the most important tools in C programming and are the one that can make you fly (unless you don't know how to ride over them). In this article we're going to learn basics of pointers.
Pointers are the varaibles that store addresses of other variables. Easy ain't it?
So lets start with the decleration of a pointer, pointer is decreleared as:
data_type *var_name;
e,g
int *pt;
well the astrisk(*) before the variable name is the thing that makes variable a pointer. So far so good now what?
Now lets say we want to store address of a variable in our pointer variable that seems pretty complex..!
Let's do it:
int number = 100;
int *pt = #
Is it really complex..?
what we are doing here is that we are first declaring and initializing a integer variable (number) with value of 100 and then we declare and initialize a pointer variable (pt) with the address of number variable. Now pt (pointer variable) contains the address of number (integer varaible). So what? Now we can use this pointer variable to change the value of number variable. Is this some kind of Magic? Maybe. Lets' do it:
*pt = 200;
what we have done here is that we De-referencing the pt variable with the asterisk (*) and then assigned it the value of 200 now the number variable contains 200. Isn't it a magic? De-referencing is used for accessing the value of the variable towards which our pointer is pointing simple. So lets write a full program of what we have learned so far.
/*Pointer Basics: Creating and Using Pointers*/
#include<stdio.h>
int main(void){
  int number = 100;
  int *pt = &number;
  printf("Value of 'number' is: %d", number);
  printf("Address of 'number' is: %p", pt);
  *pt = 200;
  printf("New value of 'number' is: %d", number);
  return 0;
}
What this whole program did was it created a integer variable and a pointer to integer variable and then printed out the value and address of the 'number' variable and after that we De-referenced the pointer variable so that we can access the value to which our pointer variable is pointing and changed the old 100 value with new 200 value and at last we printed that out. Easy isn't it?
But do you know that you can get the address of a variable even by using ampersand (&) operator? Lemme show you how. I'll declare and initialize a variable 'var' and then print it to screen using ampersand (&) operator:
int var = 10;
printf("Address of 'var' is %p\n", &var);
the last statement here will print out the address of 'var' not value so that means it is equal to this statement:
int *pt = &var;
printf("Address of 'var' is %p\n", pt);
here we first assigned the address of 'var' to pointer variable 'pt' and then printed out the address of 'var' using the pointer variable (pt).
So lets write another program that will wrap up this part of 'Pointer Basics':
/*Pointer Basics Part 1: Program 2*/
#include<stdio.h>
int main(void){
   int var = 10;
   int *pt = &var;
   printf("The Value of 'var' is: %d\n", var);
   printf("De-referencing: *pt = %d\n", *pt);
   printf("Ampersand: The Address of 'var' is %p\n",  &var);
   printf("pt = %p\n", pt);
   return 0;
}
So that's the end of first part watch out for the next part in which we'll tighten our grip on pointers and get ready for some Advanced '*po(inter)-fo'.
Related posts

Attacking Financial Malware Botnet Panels - SpyEye

This is the second blog post in the "Attacking financial malware botnet panels" series. After playing with Zeus, my attention turned to another old (and dead) botnet, SpyEye. From an ITSEC perspective, SpyEye shares a lot of vulnerabilities with Zeus. 

The following report is based on SpyEye 1.3.45, which is old, and if we are lucky, the whole SpyEye branch will be dead soon. 

Google dorks to find SpyEye C&C server panel related stuff:

  • if the img directory gets indexed, it is rather easy, search for e.g. inurl:b-ftpbackconnect.png
  • if the install directory gets indexed, again, easy, search for e.g. inurl:spylogo.png
  • also, if you find a login screen, check the css file (style.css), and you see #frm_viewlogs, #frm_stat, #frm_botsmon_country, #frm_botstat, #frm_gtaskloader and stuff like that, you can be sure you found it
  • otherwise, it is the best not to Google for it, but get a SpyEye sample and analyze it
And this is how the control panel login looks like, nothing sophisticated:


The best part is that you don't have to guess the admin's username ;)

This is how an average control panel looks like:


Hack the Planet! :)

Boring vulns found (warning, an almost exact copy from the Zeus blog post)


  • Clear text HTTP login - you can sniff the login password via MiTM, or steal the session cookies
  • No password policy - admins can set up really weak passwords
  • No anti brute-force - you can try to guess the admin's password. There is no default username, as there is no username handling!
  • Password autocomplete enabled - boring
  • Missing HttpOnly flag on session cookie - interesting when combining with XSS
  • No CSRF protection - e.g. you can upload new exe, bin files, turn plugins on/off :-( boring. Also the file extension check can be bypassed, but the files are stored in the database, so no PHP shell this time. If you check the following code, you can see that even the file extension and type is checked, and an error is shown, but the upload process continues. And even if the error would stop the upload process, the check can be fooled by setting an invalid $uptype. Well done ...
        if ($_FILES['file']['tmp_name'] && ($_FILES['file']['size'] > 0))         {                 $outstr = "<br>";                 set_time_limit(0);                 $filename = str_replace(" ","_",$_FILES['file']['name']);                 $ext = substr($filename, strrpos($filename, '.')+1);                 if( $ext==='bin' && $uptype!=='config' ) $outstr .= "<font class='error'>Bad CONFIG extension!</font><br>";                 if( $ext==='exe' && $uptype!=='body' && $uptype!=='exe' ) $outstr .= "<font class='error'>Bad extension!</font><br>";                  switch( $uptype )                 {                 case 'body': $ext = 'b'; break;                 case 'config': $ext = 'c'; break;                 case 'exe': $ext = 'e'; break;                 default: $ext = 'e';                 }                 $_SESSION['file_ext'] = $ext;                 if( isset($_POST['bots']) && trim($_POST['bots']) !== '')                 {                         $bots = explode(' ', trim($_POST['bots']));                         //writelog("debug.log", trim($_POST['bots']));                         $filename .= "_".(LastFileId()+1);                 }                 if( FileExist($filename) ) $filename .= LastFileId();                 $tmpName  = $_FILES['file']['tmp_name'];                 $fileSize = $_FILES['file']['size'];                 $fileType = $_FILES['file']['type'];                 ## reading all file for calculating hash                 $fp = fopen($tmpName, 'r'); 
  • Clear text password storage - the MySQL passwords are stored in php files, in clear text. Also, the login password to the form panel is stored in clear text.
  • MD5 password - the passwords stored in MySQL are MD5 passwords. No PBKDF2, bcrypt, scrypt, salt, whatever. MD5. Just look at the pure simplicity of the login check, great work!
$query = "SELECT * FROM users_t WHERE uPswd='".md5($pswd)."'";
  • ClickJacking - really boring stuff

SQL injection


SpyEye has a fancy history of SQL injections. See details here, here, here, video here and video here.

It is important to highlight the fact that most of the vulnerable functions are reachable without any authentication, because these PHP files lack user authentication at the beginning of the files.

But if a C&C server owner gets pwned through this vuln, it is not a good idea to complain to the developer, because after careful reading of the install guide, one can see:

"For searching info in the collector database there is a PHP interface as formgrabber admin panel. The admin panel is not intended to be found on the server. This is a client application."

And there are plenty of reasons not to install the formgrabber admin panel on any internet reachable server. But this fact leads to another possible vulnerability. The user for this control panel is allowed to remotely login to the MySQL database, and the install guide has pretty good passwords to be reused. I mean it looks pretty secure, there is no reason not to use that.

CREATE USER 'frmcpviewer' IDENTIFIED BY 'SgFGSADGFJSDGKFy2763272qffffHDSJ'; 

Next time you find a SpyEye panel, and you can connect to the MySQL database, it is worth a shot to try this password.

Unfortunately the default permissions for this user is not enough to write files (select into outfile):

Access denied for user 'frmcpviewer' (using password: YES)

I also made a little experiment with this SQL injection vulnerability. I did set up a live SpyEye botnet panel, created the malware install binaries (droppers), and sent the droppers to the AV companies. And after more and more sandboxes connected to my box, someone started to exploit the SQL injection vulnerability on my server!

63.217.168.90 - - [16/Jun/2014:04:43:00 -0500] "GET /form/frm_boa-grabber_sub.php?bot_guid=&lm=3&dt=%20where%201=2%20union%20select%20@a:=1%20from%20rep1%20where%20@a%20is%20null%20union%20select%20@a:=%20@a%20%2b1%20union%20select%20concat(id,char(1,3,3,7),bot_guid,char(1,3,3,7),process_name,char(1,3,3,7),hooked_func,char(1,3,3,7),url,char(1,3,3,7),func_data)%20from%20rep2_20140610%20where%20@a=3%23 HTTP/1.1" 200 508 "-" "Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; .NET CLR 1.1.4322; .NET CLR 2.0.50727; .NET CLR 3.0.4506.2152; .NET CLR 3.5.30729; .NET4.0C; .NET4.0E)"

Although the query did not return any meaningful data to the attacker (only data collected from sandboxes), it raises some legal questions.

Which company/organization has the right to attack my server? 
  • police (having a warrant)
  • military (if we are at war)
  • spy agencies (always/never, choose your favorite answer)
  • CERT organisations?

But, does an AV company or security research company has the legal right to attack my server? I don't think so... The most problematic part is when they hack a server (without authorization), and sell the stolen information in the name of "intelligence service". What is it, the wild wild west?

The SQLi clearly targets the content of the stolen login credentials. If this is not an AV company, but an attacker, how did they got the SpyEye dropper? If this is an AV company, why are they stealing the stolen credentials? Will they notify the internet banking owners about the stolen credentials for free? Or will they do this for money?

And don't get me wrong, I don't want to protect the criminals, but this is clearly a grey area in the law. From an ethical point of view, I agree with hacking the criminal's servers. As you can see, the whole post is about disclosing vulns in these botnet panels. But from a legal point of view, this is something tricky ... I'm really interested in the opinion of others, so comments are warmly welcome.

On a side note, I was interested how did the "attackers" found the SpyEye form directory? Easy, they brute-forced it, with a wordlist having ~43.000 entries.

(Useless) Cross site scripting


Although parts of the SpyEye panel are vulnerable to XSS, it is unlikely that you will to find these components on the server, as these codes are part of the install process, and the installer fails to run if a valid install is found. And in this case, you also need the DB password to trigger the vuln...



Session handling


This is a fun part. The logout button invalidates the session only on the server side, but not on the client side. But if you take into consideration that the login process never regenerates the session cookies (a.k.a session fixation), you can see that no matter how many times the admin logs into the application, the session cookie remains the same (until the admin does not close the browser). So if you find a session cookie which was valid in the past, but is not working at the moment, it is possible that this cookie will be valid in the future ...

Binary server


Some parts of the SpyEye server involve running a binary server component on the server, to collect the form data. It would be interesting to fuzz this component (called sec) for vulns.

Log files revealed


If the form panel mentioned in the SQLi part is installed on the server, it is worth visiting the <form_dir>/logs/error.log file, you might see the path of the webroot folder, IP addresses of the admins, etc.

Reading the code


Sometimes reading the code you can find code snippets, which is hard to understand with a clear mind:

$content = fread($fp, filesize($tmpName)); if ( $uptype === 'config' )     $md5 = GetCRC32($content); else $md5 = md5($content); .... <script> if (navigator.userAgent.indexOf("Mozilla/4.0") != -1) {         alert("Your browser is not support yet. Please, use another (FireFox, Opera, Safari)");         document.getElementById("div_main").innerHTML = "<font class=\'error\'>ChAnGE YOuR BRoWsEr! Dont use BUGGED Microsoft products!</font>"; } </script> 

Decrypting SpyEye communication

It turned out that the communication between the malware and C&C server is not very sophisticated (Zeus does a better job at it, because the RC4 key stream is generated from the botnet password).

function DeCode($content) {         $res = '';         for($i = 0; $i < strlen($content); $i++)         {                 $num = ord($content[$i]);                 if( $num != 219) $res .= chr($num^219);         }         return $res; } 
Fixed XOR key, again, well done ...
This means that it is easy to create a script, which can communicate with the SpyEye server. For example this can be used to fill in the SpyEye database with crap data.


import binascii import requests import httplib, urllib  def xor_str(a, b):     i = 0     xorred = ''     for i in range(len(a)):         xorred += chr(ord(a[i])^b)     return xorred              b64_data= "vK6yv+bt9er17O3r6vqPnoiPjZb2i5j6muvo6+rjmJ/9rb6p5urr6O/j/bK+5uP16/Xs7evq9ers7urv/bSo5u316vXs7evq/a6v5pq/trK1/bi4qbjm453j6uPv7Or9tr/u5um+uuvpve3p7eq/4+vsveLi7Lnqvrjr6ujs7rjt7rns/au3vOa5sre3srW8s7q2tr6p4Lm3tLiw4LmuvKm+q7Spr+C4uPu8qbq5ub6p4Li4vKm6ubm+qeC4qb6/sq+8qbq54LiuqK+0tri0tbW+uK+0qeC/v7So4L+1qLqrsuC+trqyt7ypurm5vqngvb24vqmvvKm6ubm+qeC9/aivuq/mtLW3srW+" payload =xor_str (binascii.a2b_base64(b64_data), 219)  print ("the decrypted payload is: " + payload) params = (binascii.b2a_base64(xor_str(payload,219))) payload = {'data': params} r = requests.post("http://spyeye.localhost/spyeye/_cg/gate.php", data=payload) 

Morale of the story?


Criminals produce the same shitty code as the rest of the world, and thanks to this, some of the malware operators get caught and are behind bars now. And the law is behind the reality, as always.

More info