Skip to content

Latest commit

 

History

History
60 lines (46 loc) · 5.35 KB

Securing_Apps_91f3d87.md

File metadata and controls

60 lines (46 loc) · 5.35 KB
loio
91f3d8706f4d1014b6dd926db0e91070

Securing Apps

The following section provides information about security aspects of OpenUI5. The information is intended for OpenUI5 application and control developers, as well as to system administrators running applications based on OpenUI5.

OpenUI5 is a client-side JavaScript library, so while the library itself is designed and tested to be secure, it cannot ensure the application to be secure. Unlike WebDynpro, where the application is built against an abstract programming model and the framework handles the HTML rendering, JavaScript code and communication with the browser, in OpenUI5 the application controls the HTML output and provides its own JavaScript code. This code is executed on the client and it handles client/server communication.

While this brings a lot of freedom and possibilities for the application, it comes with a lot of responsibility with regards to security. Application developers need to understand the security threats and actively prohibit exploitation. Also important is the correct configuration of the used HTTP server.

Moreover, common security mechanisms, which are usually taken for granted, like user authentication, session handling, authorization handling, or encryption are not part of OpenUI5 and need to be handled by the server-side framework and/or custom code of the application.


Further Reading

OpenUI5 is not bound to any server implementation or server-side programming language and can, thus, be used with SAP NetWeaver AS for ABAP, Java, HANA XS Engine, or any standard web server. Therefore, the corresponding Security Guides also apply to OpenUI5.

Note:

We highly recommend that you implement SAP Note 1582870 for ABAP XSS escaping support, in case you are running on SAP_BASIS lower than 730.

  • Content Security Policy
    Content Security Policy (CSP) adds an additional layer of security that can detect and mitigate certain types of attacks, such as cross-site scripting and data injection.
  • Browser Security
    Browser security comprises several topics such as cross-site scripting, clickjacking, and local storage.
  • Transport Security
    Transport security comprises topics such as encryption and session security.
  • Server Security
    Server security comprises topics such as cross-origin resource sharing and resource handlers.
  • Third-Party Libraries
    For the third party libraries shipped with OpenUI5, security-related issues have to be observed.
  • Secure Programming Aspects
    The secure programming guide introduces topics that developers should note.
  • Cross-Site Scripting
    Cross-site scripting (XSS) is a widely known vulnerability most web sites have. This page does not provide general information about cross-site scripting but focuses on what you as an application developer using OpenUI5 can do to avoid these security issues.
  • URL List Validation
    The OpenUI5 framework provides a client-side API to manage allowed URLs using the URLListValidator. It can be used to validate arbitrary URLs.
  • Allowlist Service
    SAPUI5 supports the configuration of a central allowlist service.
  • Frame Options
    The frame-options configuration of OpenUI5 is a client-side feature that is used to prevent security vulnerabilities like clickjacking, that is, situations where a user could be misled to use the targeted application unintentionally.