- The use of innerHtml, outerHtml, write, or writeln is prohibited and can be replaced with innerText.
- The use of
<script>
,<iframe>
,<object>
, or<embed>
should be handled with caution. - The HTML string must be mandatorily purified before insertion (exemple : DOMPurify)
- React:
dangerouslySetInnerHTML
- Angular:
bypassSecurityTrustHtml
- React:
- The use of HTML inserstion should be minimal and limited to data received from the backend to avoid security issues.
- React:
dangerouslySetInnerHTML
- Angular:
bypassSecurityTrustHtml
- React:
- URLs and links (href or src) must be mandatorily sanitized. Example of a URL sanitizer.
- The use of javascript: or data: is prohibited. Example:
<a href="javascript: alert(1)">
. - The use of JSON.stringify should be done with caution to avoid dynamic vulnerability injection.
- Verification and securing of input fields (input, textarea, etc.) is very important, especially if the information entered will be sent to the backend.
- The use of LocalStorage, Session, and Cookie should be with caution (no data, sensitive or not, should be saved in the Frontend without the client's consent).
- It is prohibited to leave or store sensitive data (even mocks) in the Frontend or to log sensitive data in the console. Is the code defensive (thinking of the worst-case scenario: null, undefined, wrong type, etc.)?
- It is highly recommended to limit the use of external and internal npm modules to those recommended by the Technical Commitee. Create an issue to ask a modification to Bistro
- It is highly recommended to follow updates made on the Frontend Technical Commitee to avoid obsolescence and vulnerability risks.
- Do not rely solely on the Frontend for everything: Security, Business Rules, Rendering, Performance, etc. (it is easy to bypass the Frontend with a simple "inspect" or "spy" on requests).
- The use of these React capabilities is prohibited:
findDOMNode
,createElement
,createFactory
, andcloneElement
. - React capabilities
useRef
andcreateRef
should not be used with innerHtml or outerHtml.
- The use of Angular's
bypassSecurityTrustHtml
,bypassSecurityTrustStyle
,bypassSecurityTrustScript
,bypassSecurityTrustUrl
, andbypassSecurityTrustResourceUrl
should be limited to the most essential use cases and should be paired with robust input validation and sanitization processes to avoid security risks. - Avoid direct DOM manipulation using
ElementRef
,Renderer2
, ordocument
. If manipulation is necessary, ensure that the data being manipulated is safe and sanitized. - Use Angular's built-in sanitization methods, such as
DomSanitizer
, when working with user-generated content. This ensures that inputs are sanitized before they are used within the application. - Enable
Ahead-Of-Time
(AOT) compilation in Angular to reduce the risk of injection attacks by catching template errors during the build phase and optimizing the code for better security and performance. - Regularly update Angular and its dependencies to the latest versions to benefit from security patches and updates provided by the Angular team.
For further reading and resources on web security, refer to:
- OWASP Top 10 Web Application Security Risks
- Cross Site Scripting Prevention Cheat Sheet
- Pragmatic Web Security / Articles
- Pragmatic Web Security / Conferences
- Avoiding XSS in React applications
- Secure data storage in the browser
- deepscan Rules
- bearer Rules
- CWE Top 25 Most Dangerous Software Weaknesses
- Angular - Security Best Practices
Additionally, recommended books: