20 Jun 2012

Secure Coding Quiz

Thank you for taking the Secure Coding Quiz. For a better idea of application security, please download our free product ThreatModeler to learn more about threat modeling and building secure applications.

 



Secure Coding Quiz

Please wait while the activity loads.
If this activity does not load, try refreshing your browser. Also, this page requires javascript. Please visit using a browser with javascript enabled.
If loading fails, click here to try again

Congratulations – you have completed Secure Coding Quiz.

You scored %%SCORE%% out of %%TOTAL%%.

Your performance has been rated as %%RATING%%

Your answers are highlighted below.

Question 1
Best practice for secure coding against SQL Injection attacks?
A
Use of Stored Procedures
B
Use of Parameterized Queries.
C
Database hardening
D
Lowering application privileges
Question 2
For a web mail application that handles form input and displays them in the browser, what threat are you at risk of?
A
SQL Injection
B
Remote File Inclusion
C
CSRF
D
XSS
Question 3
The best way to implement input validation is by:
A
Server Side Blacklisting
B
Server Side Whitelisting
C
Client Side Input Validation
D
Encrypted communications
Question 4
Failure of handling of concurrent requests by a process dependent on a sequence or timing of events leads to:
A
SQL Injection
B
Race Condition
C
Brute Force Attack
D
Session Fixation
Question 5
What is the practice of encoding data to a common character set before validation formally known as?
A
Canonicalization
B
Encryption
C
Sanitization
D
Input Validation
Question 6
Why do you require to change the Session ID after Login?
A
To prevent XSS
B
To prevent Session Fixation
C
To Prevent Cross Site Request Forgery
D
To Prevent SQL Injection
Question 7
The use of a Canary value is a safeguard against what type of attack?
A
Heap Overflow
B
Denial of Service
C
Brute Force
D
Buffer Overflow by stack smashing
Question 8
How do you implement efficient error handling?
A
Redirect user to homepage
B
Give verbose error messages to help obtain necessary technical feedback.
C
Generic error messages without any information on the type of error or stack traces
Question 9
Consider the scenario where a developer uses a cookie to count failed login attempts to implement account lockout against a brute force attack. How can this measure be bypassed?
A
Attacker will attempt a session fixation attack
B
User can manipulate the cookie
C
Account Lockout will cause a denial of service thus helping the attacker
Question 10
For output data as input to another module of the application or to the underlying OS, what would be appropriate?
A
Implement application at least privilege
B
Validate all Input
C
Per-request session token
D
Transfer data using HTTP POST method
Question 11
Before embedding data into an HTTP response header, validating input for CR/LFs would help mitigate against:
A
Remote File Inclusion
B
Cross Site Request Forgery
C
HTTP Response Splitting
D
Brute Force Attack
Question 12
To harden your system against a Path Traversal attack, the following is considered a good practice
A
Generate a new session identifier to force change from HTTP to HTTPS and deactivate the old one.
B
Use a chrooted environment on the directory containing your application files
C
Transfer data in a POST request
D
Using Parameterized Queries
Question 13
For a centralized input validation component, what is the area at which you redirect input data for validation?
A
Client Side Form
B
At the database
C
Trust Boundary
D
At the communication medium
Question 14
Which of the following should be avoided as a security measure?
A
Blacklisting
B
Parameterized Queries
C
Encryption
D
Whitelisting
Question 15
For limited input type, what security measure is most viable as input validation?
A
Blacklist: Create a list of known bad values
B
Prepared Statements
C
Create a list of legitimate values that a user is allowed to specify
D
Output Encoding
Once you are finished, click the button below. Any items you have not completed will be marked incorrect.
Get Results


There are 15 questions to complete.
List

Return

Shaded items are complete.
1 2 3 4 5
6 7 8 9 10
11 12 13 14 15
End
Return


Leave a Reply