Oracle Application Express

Oracle APEX (or APEX) is an enterprise low-code application development platform offered by Oracle Corporation. APEX is used for developing and deploying cloud, mobile and desktop applications. The platform provides a web-based integrated development environment (IDE) that includes tools such as wizards, drag-and-drop layouts and property editors aimed at simplifying the process of building applications and designing user interfaces.

Oracle APEX
Developer(s)Oracle Corporation
Stable release
24.1 / June 17, 2024 (2024-06-17)
Operating systemWindows, Linux, Oracle Solaris, HP-UX, IBM AIX[1]
LicenseOracle Technical Network License (proprietary[2])
Websiteapex.oracle.com

Background

edit

APEX is currently a feature of the Oracle Database and can theoretically be installed anywhere an Oracle Database runs. APEX is also offered in Oracle's Cloud across various services including Autonomous Database Cloud Services and the stand-alone APEX Application Development service.[3]

Oracle APEX has had many name changes since its inception in 2000, including:

  • Flows[4]
  • Oracle Platform[5]
  • Project Marvel
  • HTML DB[6]
  • Application Express (APEX) aka Oracle APEX[7]

APEX was created by Michael Hichwa, a developer at Oracle. Following the development of his earlier project, WebDB, Hichwa began to diverge from his original vision. Although APEX shares some functionality with WebDB, it was developed entirely from scratch, and there is no direct upgrade path from WebDB to APEX. When tasked with building an internal web calendar, Hichwa employed Joel Kallman and began developing a project called Flows. Hichwa and Kallman also co-developed the Web Calendar, adding features to Flows as they needed them to develop the calendar. Early builds of Flows had no front-end, so all changes to an application had to be made in SQL*Plus via inserts, updates and deletes.[8]

With version 5.2, the numbering was changed to 18.1, indicating the year and quarter of release. This change is associated with Oracle's new numbering nomenclature. The latest version of the Oracle APEX is 24.1 and was released on June 17, 2024.[9]

Low-code environment

edit

Oracle APEX is a low-code development platform. These low-code environments can trace their origins to 4GL programming languages and rapid application development (RAD) tools. Since APEX was originally marketed as a RAD tool, this progression is a logical one. APEX allows building web applications with no code. When the requirements are more complex, APEX allows the extension of the Low-Code objects through a declarative framework. This framework lets the developer define custom logic, business rules, and user interfaces. The developer can do this through the inclusion of SQL, PL/SQL, HTML, JavaScript, or CSS as well as APEX plug-ins. APEX permits developers to go from no code to low-code to more code.[10][11]

Security

edit

There is a common misconception[vague] that the abstracted nature of APEX applications results in a relatively secure user environment. However, APEX applications suffer from the same classes of application security flaws as other web applications based on more direct technologies such as PHP, ASP.NET and Java.

The two main classes of vulnerability that affect APEX applications are SQL injection and cross-site scripting (XSS).[12]

APEX applications inherently use PL/SQL constructs as the base server-side language. As well as accessing data via PL/SQL blocks, an APEX application will use PL/SQL to implement authorization and to conditionally display web page elements. This means that generally APEX applications suffer from SQL injection when these PL/SQL blocks do not correctly validate and handle malicious user input. Oracle implemented a special variable type for APEX called Substitution Variables (with a syntax of "&NAME."); however, these are insecure and can lead to SQL injection. Where the injection occurs within a PL/SQL block an attacker can inject an arbitrary number of queries or statements to execute. Escaping special characters and using bind variables ensures the reduced likelihood of XSS and SQL injection vulnerabilities.

Cross-site scripting vulnerabilities arise in APEX applications just like other web application languages. Oracle provides the htf.escape_sc() function to replace literal characters with HTML entity names and avoid undesired behaviors.[13]

To control access to resources within an APEX application, a developer can assign authorization schemes to resources (such as pages and items). These schemes must be applied consistently to ensure that resources are appropriately protected. A typical example of inconsistent access control is when an authorization scheme is set for a button item but not for the associated process that is performed when the button is clicked. A malicious user can then perform the process through JavaScript without needing the actual Button to be accessible.

Since APEX 4.0, the Application Builder interface provides some limited assessment of the security posture through the Advisor utility.

Third-party libraries

edit

Developers may improve and extend their APEX applications by using third-party libraries. Among them are JQuery Mobile (HTML5-based user interface),[14] JQuery UI (user interface for the web),[15] AnyChart (JavaScript/HTML5 charts),[16] CKEditor (web text editor)[17] and others. Experts[who?] say it is an advantage of applying the latest APEX patches that the external libraries that come with APEX carry an update, too.[clarification needed] However, many of the libraries come out with newer versions more frequently than there are APEX patches.[18][19]

APEX and Oracle Database Express Edition (XE)

edit

Oracle APEX can be run inside Oracle Database Express Edition (XE), a free entry-level database. Although the functionality of APEX isn't intentionally limited when running on XE, the limitations of the database engine may prevent some APEX features from functioning. Also, Oracle XE has limits for CPU, memory and disk usage.[20]

See also

edit

References

edit
  1. ^ "Oracle Application Express - Downloads". Oracle. Retrieved December 10, 2015.
  2. ^ "Oracle Application Express Documentation". Oracle Help Center.
  3. ^ "Oracle Application Express (APEX): Overview" (PDF). Oracle Corporation.
  4. ^ "Welcome to Flows for APEX". apex-flowsforapex. Retrieved September 24, 2021.
  5. ^ "Implementing Oracle API Platform Cloud Service". Packt. Retrieved September 24, 2021.
  6. ^ "1 What is Oracle HTML DB?". docs.oracle.com. Archived from the original on September 24, 2021. Retrieved September 24, 2021.
  7. ^ "Apex Developer | Limestone Digital". limestonedigital.com. September 3, 2021. Retrieved September 24, 2021.
  8. ^ "Michael Hichwa". Apress. Michael Hichwa is the original developer and architect of Oracle Application Express (APEX), aka HTML DB. Michael created APEX as a 100% rewrite of an earlier browser-based application development tool he also created, called Oracle WebDB. He had invaluable technical assistance and guidance from Tom Kyte and the addition of Joel Kallman as a co-developer. Michael and Joel have led APEX development efforts since 1999
  9. ^ "Oracle APEX Downloads". oracle.com. Retrieved March 20, 2024.
  10. ^ Kallman, Joel. "From Low Code to High Control". Retrieved November 27, 2017.
  11. ^ "Low Code with Oracle Application Express". apex.oracle.com. Retrieved November 27, 2017.
  12. ^ "Securing Vulnerability Exploits with Apex – Part 3". content.dsp.co.uk. Retrieved October 8, 2024.
  13. ^ "Fusion Middleware PL/SQL Web Toolkit Reference". docs.oracle.com. Retrieved October 8, 2024.
  14. ^ "Building a Mobile Web Application Using Oracle Application Express 5.0". Oracle.
  15. ^ "Application Express Application Builder User's Guide". Oracle.
  16. ^ "Oracle APEX: Using AnyChart products with Oracle Application Express (APEX)". AnyChart.
  17. ^ "Oracle chooses FCKeditor for Application Express". CKEditor.com.
  18. ^ "Goodies - APEX 4.2.2 included Libraries". Dimitri Gielis Blog. May 8, 2013. Retrieved December 10, 2015.
  19. ^ "APEX 5 first peek". Grassroots Oracle. March 17, 2014. Retrieved December 10, 2015.
  20. ^ "Limitations of the Express Edition". Oracle Corporation. Retrieved May 22, 2013.

Bibliography

edit
edit