Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/aershov24/web-security-interview-questions

πŸ”΄ Web Security Interview Questions and Answered to prepare for your next Web Developer interview
https://github.com/aershov24/web-security-interview-questions

interview interview-practice interview-preparation interview-questions web-security web-security-research

Last synced: 3 days ago
JSON representation

πŸ”΄ Web Security Interview Questions and Answered to prepare for your next Web Developer interview

Awesome Lists containing this project

README

        

# Web Security Interview Questions and Answers from [FullStack.Cafe](https://www.fullstack.cafe)

> You could also find all the answers here πŸ‘‰ https://www.fullstack.cafe/Web%20Security.





## Q1: What is the difference between Authentication vs Authorization? ⭐

**Answer:**

* **Authentication** is the process of ascertaining that somebody really is who he claims to be.
* **Authorization** refers to rules that determine who is allowed to do what. E.g. Adam may be authorized to create and delete databases, while Usama is only authorised to read.

Or in short:
* **Authentication** = login + password (who you are)
* **Authorization** = permissions (what you are allowed to do)

Also:
* Authentication = **Verification**
* Authorization = **Permissions**

πŸ”— **Source:** [FullStack.Cafe](https://www.fullstack.cafe)

## Q2: What is SQL injection? ⭐

**Answer:**

Injection attacks stem from a lack of strict separation between program instructions (i.e., code) and user-provided (or external) input. This allows an attacker to inject malicious code into a data snippet.

*SQL injection* is one of the most common types of injection attack. To carry it out, an attacker provides malicious SQL statements through the application.

How to prevent:
* **Prepared statements with parameterized queries**
* **Stored procedures**
* **Input validation** - blacklist validation and whitelist validation
* **Principle of least privilege** - Application accounts shouldn’t assign DBA or admin type access onto the database server. This ensures that if an application is compromised, an attacker won’t have the rights to the database through the compromised application.

πŸ”— **Source:** [https://www.synopsys.com](https://www.synopsys.com/software-integrity/resources/knowledge-database/sql-injection.html)

## Q3: What is a DDOS attack? ⭐

**Answer:**

**A denial-of-service attack (DoS attack)** is an attempt to make a computer resource unavailable to its intended users.

Denial of service is typically accomplished by flooding the targeted machine or resource with superfluous requests in an attempt to overload systems and prevent some or all legitimate requests from being fulfilled.

In a **distributed denial-of-service attack (DDoS attack)**, the incoming traffic flooding the victim originates from many different sources. This effectively makes it impossible to stop the attack simply by blocking a single source.

πŸ”— **Source:** [en.wikipedia.org](https://en.wikipedia.org/wiki/Denial-of-service_attack)

## Q4: What is a botnet? ⭐

**Answer:**

A **botnet** is a number of Internet-connected devices, each of which is running one or more bots. Botnets can be used to perform distributed denial-of-service attack (DDoS attack), steal data, send spam, and allows the attacker to access the device and its connection.

πŸ”— **Source:** [en.wikipedia.org](https://en.wikipedia.org/wiki/Botnet)

## Q5: What is Security Testing? ⭐

**Answer:**

Security testing can be considered most important in all type of software testing. Its main objective is to find vulnerabilities in any software (web or networking) based application and protect their data from possible attacks or intruders.

As many applications contains confidential data and needs to be protected being leaked. Software testing needs to be done periodically on such applications to identify threats and to take immediate action on them.

πŸ”— **Source:** [softwaretestinghelp.com](https://www.softwaretestinghelp.com/interview-questions/security-testing-interview-questions-and-answers/)

## Q6: What is β€œVulnerability”? ⭐

**Answer:**

The **Vulnerability** can be defined as weakness of any system through which intruders or bugs can attack on the system.

If security testing has not been performed rigorously on the system then chances of vulnerabilities get increase. Time to time patches or fixes requires preventing a system from the vulnerabilities

πŸ”— **Source:** [softwaretestinghelp.com](https://www.softwaretestinghelp.com/interview-questions/security-testing-interview-questions-and-answers/)

## Q7: List the various methodologies in Security testing? ⭐

**Answer:**

Methodologies in Security testing are:
* **White Box** - All the information are provided to the testers.
* **Black Box** - No information is provided to the testers and they can test the system in real world scenario.
* **Grey Box** - Partial information is with the testers and rest they have to rest on their own.

πŸ”— **Source:** [softwaretestinghelp.com](https://www.softwaretestinghelp.com/interview-questions/security-testing-interview-questions-and-answers/)

## Q8: What is OWASP? ⭐

**Answer:**

**OWASP** stands for *Open Web Application Security Project*. It is an organization which supports secure software development.

πŸ”— **Source:** [career.guru99.com](https://career.guru99.com/top-14-owasp-interview-questions/)

## Q9: What is impersonation? ⭐⭐

**Answer:**

Impersonation is an act of pretending to be another person. For IT Systems impersonation means that some specific users (usually Admins) could get an access to other user's data.

πŸ”— **Source:** [FullStack.Cafe](https://www.fullstack.cafe)

## Q10: What is Cross-Site Scripting (XSS)? ⭐⭐

**Answer:**

Cross-Site Scripting (XSS) is an attack that occurs when an attacker uses a web application to send malicious code, generally in the form of a browser side script, to a different end user.

The page provided by the server when someone requests it is unaltered. Instead, an XSS attack exploits a weakness in a page that include a variable submitted in a request to show up in raw form in the response. The page is only reflecting back what was submitted in that request.

πŸ”— **Source:** [synopsys.com](https://www.synopsys.com/software-integrity/resources/knowledge-database/cross-site-scripting.html)

## Q11: What is Intrusion Detection System (IDS)? ⭐⭐

**Answer:**

An **intrusion detection system (IDS)** is a device or software application that monitors a network or systems for malicious activity or policy violations.

Intrusion detection check following:

* Possible attacks
* Any abnormal activity
* Auditing the system data
* Analysis of different collected data etc.

πŸ”— **Source:** [en.wikipedia.org](https://en.wikipedia.org/wiki/Intrusion_detection_system)

## Q12: What is Content Security Policy? ⭐⭐

**Answer:**

**Content Security Policy (CSP)** is an HTTP header that allows site operators fine-grained control over where resources on their site can be loaded from. The use of this header is the best method to prevent cross-site scripting (XSS) vulnerabilities. Due to the difficulty in retrofitting CSP into existing websites, CSP is mandatory for all new websites and is strongly recommended for all existing high-risk sites.

The primary benefit of CSP comes from disabling the use of unsafe inline JavaScript. Inline JavaScript – either reflected or stored – means that improperly escaped user-inputs can generate code that is interpreted by the web browser as JavaScript. By using CSP to disable inline JavaScript, you can effectively eliminate almost all XSS attacks against your site.

πŸ”— **Source:** [infosec.mozilla.org](https://infosec.mozilla.org/guidelines/web_security#https)

## Q13: What is CORS and how to enable one? ⭐⭐

**Answer:**

A request for a resource (like an image or a font) outside of the origin is known as a *cross-origin request*. CORS (cross-origin resource sharing) manages cross-origin requests. CORS allows servers to specify who (i.e., which origins) can access the assets on the server, among many other things.

**Access-Control-Allow-Origin** is an HTTP header that defines which foreign origins are allowed to access the content of pages on your domain via scripts using methods such as XMLHttpRequest.

For example, if your server provides both a website and an API intended for XMLHttpRequest access on a remote websites, only the API resources should return the Access-Control-Allow-Origin header. Failure to do so will allow foreign origins to read the contents of any page on your origin.

```sh
# Allow any site to read the contents of this JavaScript library, so that subresource integrity works
Access-Control-Allow-Origin: *
```

πŸ”— **Source:** [infosec.mozilla.org](https://infosec.mozilla.org/guidelines/web_security#https)

## Q14: Provide some "robots.txt" anti-pattern usage ⭐⭐

**Answer:**

`robots.txt` is a text file placed within the root directory of a site that tells robots (such as indexers employed by search engines) how to behave, by instructing them not to index certain paths on the website.

It should not be used as a way to prevent the disclosure of private information or to hide portions of a website. Although this does prevent these sites from appearing in search engines, it does not prevent its discovery from attackers, as robots.txt is frequently used for reconnaisance.

```sh
# Using robots.txt to hide certain directories is a terrible idea
User-agent: *
Disallow: /secret/admin-interface
```

πŸ”— **Source:** [infosec.mozilla.org](https://infosec.mozilla.org/guidelines/web_security#https)

## Q15: What is Session Hijacking? ⭐⭐

**Answer:**

**Session Hijacking** involves the exploitation of the web session control mechanism. The attacker basically exploits vulnerable connections and steals HTTP cookies to gain unauthorized access to sensitive information/data stored in web servers.

The most effective countermeasure network-level session hijacking is to pick encrypted transport protocols that enable secure connections.

πŸ”— **Source:** [checkmarx.com](https://www.checkmarx.com/knowledge/knowledgebase/session-hijacking)

## Q16: Explain what threat arises from not flagging HTTP cookies with tokens as secure? ⭐⭐

**Answer:**

*Access Control Violation* threat arises from not flagging HTTP cookies with tokens as secure.

πŸ”— **Source:** [career.guru99.com](https://career.guru99.com/top-14-owasp-interview-questions/)

## Q17: Mention what flaw arises from session tokens having poor randomness across a range of values? ⭐⭐

**Answer:**

*Session hijacking*, is the issue related to A2: 2017 – Broken Authentication. It is also called cookie hijacking. In this type of attack, there is the possibility of exploitation of a valid computer sessionβ€”sometimes also called a session keyβ€”to gain unauthorized access to information or services in a system. This flaw comes when there is a poor randomness in session key.

πŸ”— **Source:** [career.guru99.com](https://career.guru99.com/top-14-owasp-interview-questions/)

## Q18: How to mitigate the SQL Injection risks? ⭐⭐

**Answer:**

To mitigate SQL injection:

* **Prepared Statements with Parameterized Queries:** Always ensure that your SQL interpreterΒ always able to differentiate between code and data. Never use dynamic queries which fail to find the difference between code and data. Instead, use static SQL query and then pass in the external input as a parameter to query.Β  Use of Prepared Statements (with Parameterized Queries) force developer to first define all the SQL code, and then pass in each parameter to the query later.
* **Use of Stored Procedures:** Stored Procedure is like a function in C where database administrator call it whenever he/she need it. It is not completely mitigated SQL injection but definitely helps in reducing risks of SQL injection byΒ avoiding dynamic SQL generation inside.
* **White List Input Validation:** Always use white list input validation and allow only preapproved input by the developer. Never use blacklist approach as it is less secure than whitelist approach.
* **Escaping All User Supplied Input**
* **Enforcing Least Privilege**

πŸ”— **Source:** [career.guru99.com](https://career.guru99.com/top-14-owasp-interview-questions/)

## Q19: How can we Protect Web Applications From Forced Browsing? ⭐⭐

**Answer:**

To protect web applications from forced browsing, strictly monitor access-control settings are accurate and up to date on every page and application on the site.

πŸ”— **Source:** [allabouttesting.org](https://allabouttesting.org/top-10-interview-questions-sql-injection-owasp-application-security/)

## Q20: What is Cross Site Scripting (XSS)? ⭐⭐

**Answer:**

By using **Cross Site Scripting (XSS)** technique, users executed malicious scripts (also called payloads) unintentionally by clicking on untrusted links and hence, these scripts passΒ cookies information to attackers.

πŸ”— **Source:** [allabouttesting.org](https://allabouttesting.org/top-10-interview-questions-cross-site-scripting-owasp-application-security/)

## Q21: What is DOM-based XSS? ⭐⭐

**Answer:**

**DOM-based XSS**Β is a type of cross-site scripting which appears in DOM(Document Object Model), instead of HTML.

πŸ”— **Source:** [allabouttesting.org](https://allabouttesting.org/top-10-interview-questions-cross-site-scripting-owasp-application-security/)

## Q22: How can I prevent XSS? ⭐⭐

**Answer:**

XSS can be prevented by sanitizing user input to the application. Always allowed those elements as input which is absolutely essential for that field.

πŸ”— **Source:** [allabouttesting.org](https://allabouttesting.org/top-10-interview-questions-cross-site-scripting-owasp-application-security/)

## Q23: What is an SSL Certificate? ⭐⭐

**Answer:**

**SSL Certificates** are small data files that digitally bind a *cryptographic key* to an organization’s details. When installed on a web server, it activates the padlock and the https protocol (over port 443) and allows secure connections from a web server to a browser.

πŸ”— **Source:** [globalsign.com](https://www.globalsign.com/en-au/ssl-information-center/what-is-an-ssl-certificate/)

## Q24: Why is the Root Certificate important? ⭐⭐

**Answer:**

A **Root SSL certificate** is a certificate issued by a trusted certificate authority (CA).

In the SSL ecosystem, anyone can generate a signing key and sign a new certificate with that signature. However, that certificate is not considered valid unless it has been directly or indirectly signed by a trusted CA.

A **trusted certificate authority** is an entity that has been entitled to verify that someone is effectively who it declares to be. In order for this model to work, all the participants on the game must agree on a set of CA which they trust. All operating systems and most of web browsers ship with a set of trusted CAs.

πŸ”— **Source:** [https://support.dnsimple.com/articles/what-is-ssl-root-certificate/](support.dnsimple.com)

## Q25: What is ClickJacking? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q26: theCould you explain the difference between penetration testing and other forms of security testing? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q27: What is Cross-Site Request Forgery? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q28: What is a Honeypot? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q29: What is the difference between IDS and firewalls? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q30: List the attributes of Security Testing ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q31: What is the difference between encryption, encoding, and hashing? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q32: What is HTTP Public Key Pinning and when to use it? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q33: What is Cross-site request forgery and how to mitigate it? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q34: Mention what happens when an application takes user inserted data and sends it to a web browser without proper validation and escaping? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q35: Mention what threat can be avoided by having unique usernames produced with a high degree of entropy? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q36: List Top 10 OWASP Vulnerabilities ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q37: How to mitigate the risk of Weak authentication and session management? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q38: How to mitigate the risk of Sensitive Data Exposure? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q39: What Is Failure to Restrict URL Access? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q40: What information can an attacker steal using XSS? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q41: Apart from mailing links of error pages, are there other methods of exploiting XSS? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q42: Can XSS be prevented without modifying the source code? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q43: What is PKI? ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q44: Name the elements of PKI ⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q45: What are X-Frame-Options? ⭐⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q46: How come that hash values are not reversible? ⭐⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q47: What is HSTS? ⭐⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q48: How to check if HSTS is enabled? ⭐⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q49: What are the types of XSS? ⭐⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q50: What is a Bug Bounty? ⭐⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q51: How to Prevent Breaches Due to Failure to Restrict URL Access? ⭐⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q52: What is Stored XSS? ⭐⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q53: What is Reflected XSS? ⭐⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q54: What is Cross Site Tracing (XST)? How can it be prevented? ⭐⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q55: How does SSL/TLS work ? ⭐⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q56: What is Content Security Policy (CSP)? ⭐⭐⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q57: How to use Content Security Policy (CSP) against clickjacking? ⭐⭐⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**

## Q58: Mention what is the basic design of OWASP ESAPI? ⭐⭐⭐⭐⭐

See πŸ‘‰ **[Answer](https://www.fullstack.cafe/Web%20Security)**