What is Penetration Testing?
Penetration testing is a type of security testing used to test the insecure areas of the system or application. The goal of this testing is to find all security vulnerabilities that are present in the system being tested. Vulnerability is the risk that an attacker can disrupt or gain authorized access to the system or any data contained within it. It is also called pen testing or pen test.
Vulnerabilities are usually introduced by accident during software development and implementation phase. Common vulnerabilities include design errors, configuration errors, software bugs etc.
Why Penetration testing?
Penetration is essential in an enterprise because -
- Financial sectors like Banks, Investment Banking, Stock Trading Exchanges want their data to be secured, and penetration testing is essential to ensure security
- In case if the software system is already hacked and organization wants to determine whether any threats are still present in the system to avoid future hacks.
- Proactive Penetration Testing is the best safeguard against hackers
Types of Penetration testing:
The type of penetration test selected usually depends on the scope and whether the organization wants to simulate an attack by an employee, Network Admin (Internal Sources) or by External Sources. There are three types of Penetration testing and they are
- Black Box Testing
- White Box Penetration testing
- Grey Box Penetration Testing
In black box penetration testing, tester has no knowledge about the systems to be tested. He is responsible to collect information about the target network or system.
In a white-box penetration testing, the tester is usually provided with a complete information about the network or systems to be tested including the IP address schema, source code, OS details, etc. This can be considered as a simulation of an attack by any Internal sources (Employees of an Organization).
In a grey box penetration testing, tester is provided with partial knowledge of the system. It can be considered as an attack by an external hacker who had gained illegitimate access to an organization's network infrastructure documents.
Penetration Testing Process:
Following are activities needs to be performed to execute Penetration Test -
- Planning phase
- Scope & Strategy of the assignment is determined
- Existing security policies, standards are used for defining the scope
- Discovery phase
- Collect as much information as possible about the system including data in the system, user names and even passwords. This is also called as FINGERPRINTING
- Scan and Probe into the ports
- Check for vulnerabilities of the system
- Attack Phase
- Find exploits for various vulnerabilities You need necessary security Privileges to exploit the system
- Reporting Phase
- Report must contain detailed findings
- Risks of vulnerabilities found and their Impact on business
- Recommendations and solutions, if any
The prime task in penetration testing is to gather system information. There are two ways to gather information -
- 'One to one' or 'one to many' model with respect to host: A tester performs techniques in a linear way against either one target host or a logical grouping of target hosts (e.g. a subnet).
- 'Many to one' or 'many to many' model: The tester utilizes multiple hosts to execute information gathering techniques in a random, rate-limited, and in non-linear.
Tools of Penetration testing:
There is a wide variety of tools that are used in penetration testing and the important tools are:
- NMap- This tool is used to do port scanning, OS identification, Trace the route and for Vulnerability scanning.
- Nessus- This is traditional network based vulnerabilities tool.
- Pass-The-Hash - This tool is mainly used for password cracking.
- Cain and Abel- This tool mainly used for Password recovery, Network sniffing, Wireless scanning and VoIP.
Role and Responsibilities of Penetration Testers:
Penetration Testers job is to:
- Testers should collect required information from the Organization to enable penetration tests
- Find flaws that could allow hackers to attack a target machine
- Pen Testers should think & act like real hackers albeit ethically.
- Work done by Penetration testers should be reproducible so that it will be easy for developers to fix it
- Start date and End date of test execution should be defined in advance.
- Tester should be responsible for any loss in the system or information during the testing
- Tester should keep data and information confidential
Manual Penetration vs. automated penetration testing:
|Manual Penetration Testing||Automated Penetration Testing|
|Manual testing requires expert professionals to run the tests||Automated test tools provide clear reports with less experienced professionals|
|Manual Testing requires Excel and other tools to track it||Automation Testing has centralized and standard tools|
|In Manual testing, results vary from test to test||In the case of Automated Tests results do not vary from test to test|
|Memory Cleaning up should be remembered by users||Automated Testing will have comprehensive clean ups.|
Limitations of Penetration testing:
Penetration Testing cannot find all vulnerabilities in the system. There are limitations of time, budget, scope, skills of Penetration Testers
Following will be side effects when we are doing penetration testing:
- Data Loss and Corruption
- Down Time
- Increase costs
Testers should act like a real hacker and test the application or system and needs to check whether code is securely written. A penetration test will be effective if there is a well-implemented security policy. Penetration testing policy and methodology should be a place to make penetration testing more effective.