Friday, December 14, 2012

Oracle Application Express 4.2.1 now available


Oracle Application Express 4.2.1 is now released and available for download.  If you wish to download the full release of Oracle Application Express 4.2.1, you can get it from the Downloads page on OTN.  If you have Application Express 4.2 already installed, then you need to download the APEX 4.2.1 patch set from My Oracle Support.  Look up patch number 14732511.

As is stated in the patch set note that accompanies the Oracle Application Express 4.2.1 patch set:

  • If you have Oracle Application Express release 4.2 installed, download the Oracle Application Express 4.2.1 patch set from My Oracle Support and apply it.  Remember - patch number 14732511.
  • If you have Oracle Application Express release 4.1.1 or earlier installed (including Oracle HTML DB release 1.5), download and install the entire Oracle Application Express 4.2.1 release from the Oracle Technology Network (OTN).
  • If you do not have Oracle Application Express installed, download and install the entire Oracle Application Express 4.2.1 release from the Oracle Technology Network (OTN).

As usual, there are a large number of issues corrected in the Application Express 4.2.1 patch set.  You can see the full list in the patch set note.

P.S.  Don't be alarmed when the patch set note refers to file p14732511_421_GENERIC.zip and the file you actually download from My Oracle Support is p14732511_420_Generic.zip.  These are the same file and this version number will be corrected over the weekend.

Monday, November 05, 2012

APEX 4.2 and Textareas

There is a change in behavior in Oracle Application Express 4.2.0.00.27 that I thought was worth making special mention of.

Most page items have a property named "Maximum Width".  The purpose of this attribute, as the item-level help states, is to "specify the maximum number of character users are allowed to type into this form element."  Thus, if you were to specify a value of 255, then end users theoretically would not be able to enter more than 255 characters for the item value.

Prior to Oracle Application Express 4.2.0.00.27, this attribute for Maximum Width was not emitted in the HTML for Textarea page items.  You could have had a Maximum Width of 255 or 4000 or 32000 - it didn't matter.  The amount of text that could be entered by your users was essentially unconstrained (up to the 32,000 limit that can be POSTed).  In Oracle Application Express 4.2.0.00.27, Textarea page items are now properly including this attribute in the HTML for the page item.

Prior to APEX 4.2.0.00.27, my Textarea named P2_RESUME, with a Maximum Width of 2000, might be rendered like this:



But in APEX 4.2.0.00.27, my Textarea named P2_RESUME, with a Maximum Width of 2000, will now render like this:


A number of internal and external customers have rightfully complained about Oracle Application Express 4.2.0.00.27 breaking functionality in their existing applications.  Previously, end users were able to enter a large amount of text in textareas, but now "APEX limits what can be entered by end users."  And this directly relates to the Maximum Width attribute, which most developers were able to safely ignore for textareas in the past, but in 4.2.0.00.27, it is very relevant.

I can offer the following suggestions and direction:

1) If you wish to query the APEX data dictionary for all items in your application(s) which may be impacted by this change, you can issue the query:

select application_id, page_id, page_name, item_name, item_element_max_length
  from apex_application_page_items
 where display_as_code = 'NATIVE_TEXTAREA'
 order by 1,2,3,4

2)  In the forthcoming Oracle Application Express 4.2.1 patch set, this Maximum Width property of textarea items will only be emitted when the application-level attribute Compatibility Mode is 4.2 or later.  Thus, if you are upgrading from Oracle Application Express 4.1.1 or earlier, the Compatibility Mode will not be set to 4.2 and your application behavior will remain the same.

3)  There is a patch set exception on My Oracle Support, Patch ID 15829665, which implements the above-mentioned "Compatibility Mode" behavior.  You can download this PSE (i.e., "one-off patch") and apply it to Oracle Application Express 4.2.0.00.27 today.

Note that this "maxlength" attribute for textareas is not enforced by Internet Explorer.

Saturday, October 13, 2012

Oracle Application Express 4.2 released


Oracle Application Express 4.2 was officially released today and is available for download from the Oracle Technology Network.

The main goal of Oracle Application Express 4.2 is to enable the easy development of mobile applications, using the same declarative infrastructure and methodology of APEX.  As detailed here, the marquee features of Oracle Application Express 4.2 include:

  • Application Builder for Mobile
  • Both mobile and responsive themes
  • HTML5 Charts
  • HTML5 Item Types
  • Packaged Applications
  • RESTful Web Services
  • and many more...

As we do for every release, we offer our gratitude to the countless people who participated in the Application Express 4.2 Early Adopter program and provided feedback, suggestions and bug reports.

Wednesday, September 12, 2012

Application Express 4.2 Early Adopter instance going away...

It was just 3 short months ago that Application Express 4.2 Early Adopter was made available.  As of September 21, 2012, the Application Express 4.2 Early Adopter site will no longer be available.  The database will be permanently removed.  If you need to export anything, please do it well before September 21, 2012.  There will be no hope of restoration or recovery after this day.

The Application Express demonstration instance at http://apex.oracle.com has been upgraded to a pre-production version of Application Express 4.2.  This effectively replaces the Early Adopter instance.

We have received a tremendous amount of feedback, suggestions and bug reports.  The participation by over two thousand users was the the most we've ever had.  Once again, we are grateful to the APEX community for their interest, participation and support.


Tuesday, August 28, 2012

apex.oracle.com to be upgraded to Oracle Application Express 4.2

On the evening of Saturday, September 1, 2012 at 1800 PDT (0100 UTC), http://apex.oracle.com will be upgraded to a pre-release version of Oracle Application Express 4.2.

I know that apex.oracle.com is used by numerous people to host their sample APEX applications and sample plug-ins.  I simply wanted to give people ample opportunity to export whatever they wished before the upgrade.

After the upgrade, the applications on apex.oracle.com cannot be imported into an APEX 4.1.1 or earlier instance.

For any issues you believe are directly related to the upgrade, please feel free to post on the OTN discussion forum (preferred) or send an email to oracle-application-express_ww@oracle.com.

Monday, August 06, 2012

RESTful Services now available on Oracle Application Express 4.2 Early Adopter



Last week, on August 3, 2012, the Oracle APEX Listener 2.0 Early Adopter was made available for download from OTN.  And also this past weekend, the Oracle Application Express 4.2 Early Adopter 2 site was switched from Oracle HTTP Server/mod_plsql to the Oracle APEX Listener 2.0 Early Adopter (thanks goes to Colm from the APEX Listener team, Hilary from the APEX team, and Wei from PDIT for making this happen).

One area of functionality which is now exposed and available for testing on the Oracle Application Express 4.2 Early Adopter 2 site is RESTful Services.  These can now be easily created and tested within the Oracle Application Express RESTful Services module.

A very rich example of a RESTful Service is created within each workspace.  To test this yourself:

  1. Login to your workspace (register for one, if you havent' done so already)
  2. Click "SQL Workshop"
  3. Click RESTful Services
  4. Click oracle.example.hr
  5. Click the "GET" resource handler under the "empinfo/" resource template, in the hierarchy on the left
  6. Scroll down and click the "Test" button

In my JOEL workspace on the Application Express 4.2 Early Adopter 2 site, with the JOEL path prefix for my workspace, this resulted in a URL like:

https://apexea.oracle.com/pls/apex/joel/hr/empinfo/

[Note - after APEX 4.2 is eventually released and the APEX 4.2 Early Adopter site is extinguished, the above URL will no longer function]


Show your (ā'pěks)

In 2009, I responded in a blog post to the question of how to properly pronounce the abbreviation for Oracle Application Express.  Since then, Chet Justice (*the* oraclenerd) has taken special delight in mispronouncing it to me at every opportunity, at every conference.  But I have to give Chet credit - he has helped the correct pronunciation cause by designing a shirt which will remove all ambiguity and doubt.  Get yours today!


Wednesday, July 25, 2012

ODTUG APEXposed 2012!



Three important questions for you:

  1. Did you want to go to the ODTUG Kscope12 conference but couldn't make it because of "[insert excuse here]"?
  2. Do you have an interest in learning about Oracle Application Express 4.2, APEX Listener 2.0, HTML 5, jQuery, plug-ins and more?
  3. Have you always wanted to visit the beautiful city of Montreal, Quebec, but never had a good reason?

Well...have I got the conference for you!  ODTUG is sponsoring another APEXposed conference.  The next one is scheduled for September 11/12 2012 in Montreal, Quebec.  If you've been around Oracle Application Express for even a short period of time, you'll surely recognize the names of these presenters.  And the content for this conference is very strong (as is the case for all of the ODTUG conferences that I've been to).

I thoroughly enjoy the ODTUG conferences for Oracle Application Express - very little fluff, all worthwhile technical content and education.  Until August 15, 2012, registration is 399 USD.

Monday, July 23, 2012

Application Express 4.2 Early Adopter 2 now available

Oracle Application Express 4.2 Early Adopter 2 is now available at https://apexea.oracle.com.  If you previously participated in Application Express 4.2 Early Adopter 1, you'll need to sign up for a new workspace.

You can get the updated feature list at http://apex.oracle.com/pls/apex/f?p=38997:1:0, but some notable introductions in APEX 4.2 EA2:

  • You can now create multiple user interfaces in the same application
  • You can unlock and download Packaged Applications
  • Team Development now supports file attachments for bugs, features and todo's.
  • You can define a "Global Page" per user interface, instead of relying upon page 0
  • You can "grid edit" the translation repository
  • The User Interface of the Application Express applications has been further improved.  Note - if you used EA1 previously, you may need to clear your browser cache or Shift-Reload on many of the pages in the Application Express applications
  • You can enable cascading LOVs for Select Lists, Checkboxes and Radio groups in mobile user interfaces
  • There are two new application-level Globalization attributes to control character value comparison (for those wishing to do accent-insensitive searching).  For now, this applies only to classic reports and Interactive Reports.
  • Existing item types were modified so they work with jQuery Mobile when used with dynamic actions
  • And many more....

The response for Oracle Application Express 4.2 Early Adopter 1 was overwhelming.  We are completely appreciative of the time and effort spent by over 1,000 people, helping to improve this release of Oracle Application Express.  You'll see that a large number of the great suggestions from the APEX community have been added to Application Express 4.2 Early Adopter 2.  Thank you for all of your invaluable feedback.

Tuesday, July 17, 2012

Partners Being Contacted


A number of partners have been receiving letters from a company named Advanced Dynamic Interfaces LLC.  Although Advanced Dynamic Interfaces LLC has not contacted Oracle, we are aware of, and are currently investigating, this matter.   Letters received from ADI can be forwarded to the following address:

Oracle Legal Department
Patent, Trademark & Copyright Group
500 Oracle Parkway, M/S 5OP7
Redwood Shores, CA 94065

Monday, July 16, 2012

APEX 4.2 EA2 coming, APEX 4.2 EA1 going away

Within approximately the next 5 - 10 days, the instance of Application Express 4.2 Early Adopter 1 (https://apexea.oracle.com) will be decommissioned.  It will be replaced by the second Early Adopter release of Application Express 4.2.

Nothing will be migrated from APEX 4.2 EA1 to APEX 4.2 EA2.  The entire database will be recreated, and all workspaces will be removed.  Additionally, there is a strong likelihood that anything exported from EA1 may not be import-able into APEX 4.2 EA2 or APEX 4.2 production.

As always, the APEX community has been extraordinarily helpful with the review and feedback of this early release.  There are over 1,100 workspaces participating in EA1 and the feedback has proven invaluable.

Thursday, June 21, 2012

Application Express 4.2 Early Adopter 1 available


Just in time for the ODTUG KScope12, the Early Adopter 1 version of Oracle Application Express 4.2 is now available at https://apexea.oracle.com.  Feel free to sign up for a workspace and kick the tires. We welcome your feedback (via the Feedback link from within APEX) at any time.

A few important points about Early Adopter 1 of Oracle Application Express 4.2:

  • Click the "What's New" link to get an overview of the new features in Application Express 4.2.  This has been a pretty aggressive release, as you'll see.

  • The application to view all feedback that has been filed is available via the Public Feedback application.  You'll need to login to your workspace to view this, so ensure you've signed up first.

  • We will refresh https://apexea.oracle.com in roughly 30 days with APEX 4.2 Early Adopter 2.  No information/data/workspaces will be migrated.  We'll scrap the database and start over again.  And there's also no guarantee that what you export from APEX 4.2 Early Adopter 1 can even be imported into a later Early Adopter release or APEX 4.2 production.

  • This is evaluation software. You cannot contact Oracle Support about any issues on apexea.oracle.com. They won't have any idea what you're talking about.  It's highly recommended to provide your feedback via the Feedback link from within Application Express itself.  This way, your information gets fed back into our development process and the rest of the community can also see what's been reported.

  • The RESTful Web Services functionality (through the APEX Listener) is not exposed in Early Adopter 1.  We will strive to enable this for Early Adopter 2.

  • This site is all SSL all the time.

  • When you get your link to the provisioned workspace and you have to choose a new password,  there are some password restrictions in place:
    • Minimum Password Length: 8
    • Minimum Password Differences: 2
    • Must Contain At Least One Alphabetic Character: Yes
    • Must Contain At Least One Numeric Character: Yes
    • Must Contain At Least One Upper Case Character: Yes
    • Must Not Contain Username: Yes
    • Must Not Contain Workspace Name: Yes

We average between 1,000 and 2,000 participants for each Early Adopter cycle.  I expect even more for this release.  I wish to extend my thanks in advance to the APEX Community for your participation in the Early Adopter program.  Everyone is so gracious with their time, not only in trying to learn about what's coming with Application Express, but also in helping to dramatically improve the quality, functionality and usability of the APEX framework.

Wednesday, May 09, 2012

APEX - it's only good for CRUD applications?

The views expressed on this blog are my own and do not necessarily reflect the views of Oracle.

Rather than ignore a potentially damaging report about Oracle Application Express and hope no one notices it, I wish to expose it to the light of day.

I read a blog post the other day on the offical Oracle blog site.  This blog post referenced a paper from an industry analyst.  The majority of the paper is about Oracle Forms, the current offering, the road map and planned longevity of Oracle Forms, and a listing of numerous new features being added to Oracle Forms which customers can use to capitalize upon and further extend their investment in Oracle Forms.

A very small portion of the paper mentions Oracle Application Express - 202 words, to be exact.  However, in these 202 words, the author seems to conclude that:

  • APEX is only good for simple CRUD applications
  • APEX is not well-suited for applications with complex business logic

To address both points, all I can offer is empirical evidence.  I guess the author was never informed about the Oracle customer who has implemented their entire call-center interface in Oracle Application Express, supporting nearly 700 call center employees.  Perhaps they were not made aware of the multi-billion dollar clothing retailer who has their entire ordering, fulfillment and shipping system front-ended by Oracle Application Express.  How about the American pharmaceutical company who wrote a custom CRM system for their 600+ member sales force, all in Application Express?  Maybe he should have been informed about the multinational chemical corporation which has more than 200 applications in production - one of those APEX applications providing rich functionality on top of an SAP system.  Perhaps we can share with him the story of a large cruise-line company that has rewritten their customer embarkation application in APEX and is in production today?  Shall I go on?

After reading this paper, though, I'm not sure what I find more bothersome - a) the conclusion by an analyst who was fed incorrect and/or misleading information about Oracle Application Express and believes it to be Oracle WebDB from 1998, or b) an Oracle blog would highlight a white paper that basically says "if you wish to move from Oracle Forms and you're not interested in Oracle Fusion Middleware, then please use .NET."  An odd direction, indeed, to suggest to customers who have invested heavily in SQL and PL/SQL.

I will let the successes of our customers be all the evidence that is needed to prove both of them wrong.

Thursday, April 19, 2012

Page protection violation in APEX 4.1.1

Earlier this week, Tom contacted me with an issue with the AskTom application.  When he was replying to a question in the AskTom application, he would occasionally encounter the error:

Page protection violation: This may be caused by manual alteration of protected page items. If you are unsure what caused this error, please contact the application administrator for assistance.  Contact your application administrator.


What made this problem even more interesting was that Tom could reproduce it only occasionally and I could not reproduce it.  The application logic in AskTom has remained essentially unchanged for a number of years.  The only thing that this could be related to was a bug in Application Express 4.1.1, right?  Since AskTom runs on apex.oracle.com (much to the chagrin of some), and apex.oracle.com was upgraded to Application Express 4.1.1 in February 2012, this must be the source of the problem.

Well...the answer is yes and no.  Certainly, in February 2012, apex.oracle.com was upgraded to Oracle Application Express 4.1.1.  And it is this changed behavior that Tom was running into.  But the reason for it is enhanced functionality in Application Express 4.1.1.

If you look at the source of a page from Application Express 4.1.1, towards the bottom of the page you'll see something like

<input name="p_page_checksum" type="hidden" value="577060F3783D7C8508474077662A80DE" />

This occurs right before the closing </form> tag.  This is a checksum value computed against selected items on a page.  When the page is submitted, APEX compares the checksum value to confirm the integrity of the page and these selected items on it.  In Tom's case, he was 1) in London on business travel, not on a super fast network, and 2) he was editing a relatively large page (792 KB).  The fundamental problem - he was submitting the page before the page had fully rendered, meaning the page_checksum_value was absent from the page.  The temporary workaround I suggested to Tom was "wait a few seconds" - at least for large pages like this one.  Fortunately, large pages like this are the exception for him.  We could get fancy by disabling the buttons until the page had fully rendered, via a dynamic action.

I have also seen a similar issue crop up for customers who were lacking the #FORM_CLOSE# substitution in their page template.  Since this page_checksum_value is anchored to the tag, if there is no #FORM_CLOSE#, then there is no page checksum value either.


Tuesday, February 21, 2012

Too Many Redirects When Cookies Are Not Enabled

A person (Wouter Verkuijl) was kind enough to post on my blog, not only the problem he encountered when accessing Oracle Learning Library mobile from his iPad, but also the actual problem.  If you access Oracle Learning Library (or any APEX 4.1 application) from a browser which does not accept cookies, you'll see the URL changing in the browser a number of times and then you'll get some nice message similar to:



Of course, the Oracle Learning Library team then asked me "Any ideas on how we can trap the 310 HTTP error code (too many redirects) and provide a user-friendly message (e.g. Enable cookies) on how to resolve the problem?"  As it turns out, it's actually quite easy.

  1. The first step is ensuring that the page that is being accessed has the page attribute 'Authentication' set to 'Page is Public' instead of 'Page Requires Authentication' (thanks Christian).  Even if you are using an application which has an authentication scheme of "No Authentication (using DAD)", the specific page attribute 'Authentication' must still be set to 'Page is Public'.  This will stop APEX from doing a wild number of redirects if cookies are not enabled.
  2. Detecting if Cookies are Enabled in the Browser
    • Our preferred approach (thanks Anthony) is to do this via a dynamic action on the public page with the following attributes:
      • Advanced
      • Name: Cookies not enabled
      • Event: Page Load
      • Condition: JavaScript expression
      • Value: !navigator.cookieEnabled
      • True Action: Alert
      • Text: Cookies are not enabled! 
      • No False Action, leave blank.
    • Alternatively, you could solve this via JavaScript in the page header, with something as simple as the following code in the page attribute "Execute when Page Loads":
if (!(navigator.cookieEnabled)) {alert('Cookies are not enabled');}

By doing this via a dynamic action, you get the benefit of not only having the alert message be translatable, but this is also much easier to find and maintain in your application instead of having JavaScript sprinkled around your application.

I have to point out that you will need Application Express 4.1.1 to achieve this.  Application Express 4.1.1 was released on February 21, 2012.  The Oracle Learning Library team has already updated their application to take advantage of this.

Oracle Application Express 4.1.1 now available

Oracle Application Express 4.1.1 is now released and available for download.  If you wish to download the full release of Application Express 4.1.1, you can get it from the Downloads page on OTN.  If you have Application Express 4.1 already installed, then you need to download the APEX 4.1.1 patch set from My Oracle Support.  Look up patch number 13331096.

As is stated in the patch set note that accompanies the Oracle Application Express 4.1.1 patch set:

  • If you have Oracle Application Express release 4.1 installed, download the Oracle Application Express 4.1.1 patch set from My Oracle Support and apply it.  Remember - patch number 13331096.
  • If you have Oracle Application Express release 4.0 or earlier installed (including Oracle HTML DB release 1.5), download and install the entire Oracle Application Express 4.1.1 release from the Oracle Technology Network (OTN).
  • If you do not have Oracle Application Express installed, download and install the entire Oracle Application Express 4.1.1 release from the Oracle Technology Network (OTN).

There are a large number of issues corrected in the Application Express 4.1.1 patch set.  You can see the full list in the patch set note.  Equally important, the Oracle Application Express 4.1.1 release has incorporated much of the infrastructure necessary for the Oracle Database Cloud service, coming sometime later.

For those of you (like my friend Dietmar Aust) who wait until the first patch set is released, this is your opportunity.

Thursday, January 26, 2012

Oracle Learning Library Mobile

The Oracle Learning Library team recently rolled out their new mobile application.  If you go to http://www.oracle.com/oll, you should see a mobile icon in the upper left.  Or you can simply bookmark this link on your mobile device.



As I discussed in the past, the Oracle Learning Library isn't just about Oracle Application Express or the Oracle Database.  There is content there for virtually every Oracle product offered - JD Edwards, NetBeans, Solaris, Java, Oracle Business Intelligence, Fusion Middleware, Oracle E-Business Suite, etc.  There are tutorials, white papers, Oracle By Examples, demonstrations, data sheets, and more.

And at the risk of being criticized (again), I can proudly proclaim that this is all running entirely on Oracle Application Express at http://apex.oracle.com - the same hosted instance of Oracle Application Express that gets over 10 million page views a week and between 600 - 700 new workspace requests every week.