martes, 23 de julio de 2019

WebLogic Plug-In Enabled Parameter

Cuando usamos un proxy delante de nuestro servidor WebLogic, hay que indicarle a WebLogic que se está usando ya que dicho proxy capturará las solicitudes y cambiará ciertos aspectos de la llamada que WebLogic no sabrá interpretar o se esperará un funcionamiento no deseado.

Para ello existe la opción WebLogic Plug-In Enabled. Activando esta opción le estamos diciendo a WebLogic que existe un proxy server que está capturando las llamadas que le van a llegar. Sino incurrimos en errores como el que nos estaba pasando, que estábamos usando SSL y WebLogic nos devolvía la llamada por http en vez de por https que era como la estábamos solicitando (Mixed content: The page X was loaded over HTTPS, but requested an insecure RESOURCE. This content should also be served over HTTPS). En concreto esto es lo que hace WebLogic cuando activamos dicha opción:

The WLS setting “WebLogic plugin Enabled” when set to true informs the WLS of the presence of the proxy. With this setting is enabled, WLS sets the proprietary WL-Proxy-Client-IP header and consequently calls to getRemoteAddr will return the address of the browser client from the WL-Proxy-Client-IP header instead of the address of the web server.

Se puede activar en 3 niveles, en orden restrictivo decreciente: dominio, cluster o manejado. En nuestro caso la activamos para un servidor manejado de WebCenter, por lo que debemos navegar hasta el servidor en concreto, pestaña Configuración, sub-pestaña General y abrir la opción Avanzada. Una vez guardados los cambios, debemos reiniciar el servidor en cuestión.

Server_WLS_Plugin_Enabled

jueves, 18 de julio de 2019

Configuración plugin Weblogic para Apache 2.4

Nos hemos encontrado un problema a la hora de instalar el plugin para Weblogic en un Apache 2.4 siguiendo la documentación oficial (https://docs.oracle.com/middleware/1212/webtier/PLGWL/apache.htm#PLGWL395). Una vez descomprimido, puesto el módulo en la carpeta modules, y cargado el módulo en el httpd.conf, nos aparece el siguiente error:

"Cannot load /PATH_APACHE/wls_plugin/lib/mod_wl_24.so into server: libopmnsecure.so: cannot open shared object file: No such file or directory".

El problema parece estar en las librerías que usa el plugin, que el sistema no es capaz de leer. En Linux existe un fichero donde se especifican las librerías que usan los programas que se compilan y ejecutan, y en nuestro caso en un RH está en /etc/ld.so.conf

Lo único que hay que añadir en dicho directorio la ruta a la carpeta donde están las librerías del plugin de Weblogic para apache (/PATH_APACHE/wls_plugin/lib).

vi /etc/ld.so.conf => Añadir línea al fichero con la ruta

Una vez guardado, hay que decirle al sistema que cargue de nuevo en cache la lista de librerías que usa, para ello usamos el comando ldconfig:

ldconfig creates the necessary links and cache to the most recent shared libraries found in the directories specified on the command line, in the file /etc/ld.so.conf, and in the trusted directories (/lib and /usr/lib).

Una vez hecho esto, reiniciamos el Apache y ya debe estar funcionando.


miércoles, 20 de febrero de 2019

Atributo ClearCacheOnCommit en ADF

En un desarrollo reciente disponemos de una tabla ADF con varios registros, basado en un VO Entity updatable en donde se puede operar con acciones CreateInsert y Delete, con su posterior Commit, cada row con un atributo PK independiente.

Nos surgió la problemática de que, sin salir de la taskflow, al realizar el CreateInsert y a continuación realizar el Delete de esa misma row (con las opciones out of the box de binding mediante getCurrent) veíamos como se borraba de la tabla pero no de base de datos.

¿Cual era el problema? Para explicarlo mostramos el ciclo de vida de ADF:

Resultado de imagen de create insert delete adf diagram binding 


Cuando se realiza la operación CreateInsert, se inserta y accede al binding correspondiente, se accede al AppModule y se inserta en base de datos, pero no se actualiza el datacontrol con dicha información, es decir, se inserta la row en el iterator pero no ha refrescado con la PK que ha devuelto la base de datos, por lo que la row insertada y que se ve en la tabla no tiene actualizado el campo PK devuelto por el modelo.
Como se puede deducir, si no refrescas el iterator o pides de nuevo los datos a la base de datos, esa row no se actualiza con su verdadero PK por lo que al borrar inmediatamente después lo va a borrar del iterator pero no de base de datos.

La solución consiste en usar el atributo ClearCacheOnCommit en el fichero AppModule de nuestra aplicación:




Dicho atributo permite refrescar los VO después de realizar la operación Commit, por lo que siempre vamos a tener en este caso deseablemente el valor introducido en base de datos.
Si no se refleja esta variable en el AppModule, por defecto no aparecerá y tomará el valor "false", como se indica en la documentación (esto es del método isClearCacheOnCommit de la interfaz Transaction para consultar dicho valor):

isClearCacheOnCommit

public boolean isClearCacheOnCommit()
Returns the flag indicating whether all Entity Object caches will be cleared after the transaction is committed.After the transaction is committed, the value of this flag is used to determine whether the Entity Object caches are cleared or not. If this flag value is false, the cache contents are kept. In this case, the cache may contain data that is stale in that it does not match the newest data (changes made by another user and committed).
If this flag is true, the caches are cleared after the transaction is committed. When the user brings in data by traversing row collection, the latest data from the database will be brought into Entity caches.
Returns:
the current value of clear-cache-on-commit flag.
See Also:
RowSet.executeQuery(), setClearCacheOnCommit(boolean val)








viernes, 11 de enero de 2019

Importar y configurar un proyecto Maven en Eclipse

Cuando vamos a trabajar con un proyecto Maven que tenemos en nuestro SVN y lo vamos a configurar en nuestro entorno de desarrollo, necesitamos realizar los siguientes pasos:

1º) Hacemos checkout del SVN del proyecto, y con el asistente lo descargamos como proyecto Java.

 

 

2º) Debemos seleccionar la opción "Import" del menú "File", para a continuación importar el proyecto como Maven.

 

3º) Por último, seleccionamos la opción de convertir a Proyecto Maven, haciendo click derecho en el proyecto.