Bienvenue...
Soumis par kacy le
...sur mon blog, j'utilise ce site pour noter les petites choses qui me sont utiles, que ça soit informatique ou autre :)
Soumis par kacy le
...sur mon blog, j'utilise ce site pour noter les petites choses qui me sont utiles, que ça soit informatique ou autre :)
Dans le cadre de la mise en place du site d'e-commerce d'une filiale, j'ai pu travailler sur la refonte des interfaces Java <-> Back Office.
En effet, actuellement, le site d'e-commerce de la filiale France communique avec l'ensemble des magasins. Le futur site internet de la Suisse communiquera de la même manière avec l'ensemble des magasins Suisses.
Ayant une bonne connaissance de l'existant pour la France, il était clair qu'une refonte était necessaire pour le futur site, ceci pour reprendre la main sur la maintenance des interfaces ainsi que pour garantir un meilleur niveau de performances. Compte tenu des enjeux du Web, une montée en puissance des flux temps rééls n'est pas à exclure. Il était donc impossible de partir sur les interfaces existantes...
Deux solutions ont été envisagées :
- Attaquer les programmes 4GL au travers de Java en utilisant JNI
- Trouver une autre solution en cas d'impossibilité... :)
J'ai donc commencé par la solution 1 (;), on trouve plein de tutos sur le net concernant JNI, en gros c'est super simple, il faut créer une méthode native
qui sera le déclencheur de l'appel à la fonction C. Ensuite on appelle l'utilitaire javah sur la classe créée afin de générer le fichier prototype (.h) qui sera utilisé dans le programme C :
public class TestJNI { static { System.loadLibrary("testjni"); } private native void helloWorld(); private native void processMessage(String aMessageId); public static void main(String[] args) { new TestJNI().helloWorld(); new TestJNI().processMessage("bidon"); } }
Le fichier .h généré est de la forme :
/* DO NOT EDIT THIS FILE - it is machine generated */ #include <jni.h> /* Header for class TestJNI */ #ifndef _Included_TestJNI #define _Included_TestJNI #ifdef __cplusplus extern "C" { #endif /* * Class: TestJNI * Method: processMessage * Signature: (Ljava/lang/String;)V */ JNIEXPORT void JNICALL Java_TestJNI_processMessage (JNIEnv *, jobject, jstring); /* * Class: TestJNI * Method: helloWorld * Signature: ()V */ JNIEXPORT void JNICALL Java_TestJNI_helloWorld (JNIEnv *, jobject); #ifdef __cplusplus } #endif #endif
Bon, donc voilà pour la partie Java, reste à développer un petit programme C qui implémente les deux fonctions :
/* testjni.c */ #include <jni.h> #include "testjni.h" #include <fglapi.h> #include <fglsys.h> JNIEXPORT void JNICALL Java_TestJNI_print (JNIEnv *env, jobject obj) { printf("COUCOU !!\n"); return; } void appel4GL() { fgl_start(); int1 res[80]; printf("AVANT PUSH\n"); ibm_lib4gl_pushQuotedStr(res, strlen(res)); printf("AVANT get_server_today\n"); fgl_call(get_server_today, 0); printf("AVANT POP\n"); ibm_lib4gl_popQuotedStr(res, 80); printf("get_server_today: %s\n", res); free(res); fgl_end(); } JNIEXPORT void JNICALL Java_TestJNI_processMessage (JNIEnv *env, jobject obj, jstring str) { /* Get the native string from str */ const char *nativeString = (char *) GetStringUTFChars(env, str, 0); printf("ID message : %s\n", nativeString); /* DON'T FORGET THIS LINE!!! */ ReleaseStringUTFChars(env, str, nativeString); appel4GL(); } int main() { printf("COUCOU !!\n"); appel4GL(); return 0; }
Je vais tuer tout de suite le suspens inhérent à la mise en œuvre de tout ça, une fois que j'ai eu vaincu les directives de compilation et donc compilé mes petits programmes... ... ...Ça ne marche pas...
Chaque appel aux fonctions 4GL au travers de Java se solde par une erreur :
[oa@XRF4] : java -Djava.compiler=NONE -Djava.library.path=$LIBPATH COUCOU !! ID message : bidon Unhandled exception Type=Illegal instruction vmState=0x00040000 J9Generic_Signal_Number=00000010 Signal_Number=00000004 Error_Value=00000000 Signal_Code=0000001e Handler1=F10FF238 Handler2=F10FB064 R0=00000000 R1=2FF21300 R2=00000000 R3=2FF21340 R4=00000001 R5=F0FD85CC R6=00000000 R7=4D343000 R8=3430004D R9=00008000 R10=7F7F7F7F R11=00000003 R12=00000000 R13=30151900 R14=3017FBF8 R15=304A5A9C R16=00000007 R17=00000000 R18=F1100F48 R19=30151940 R20=3047E260 R21=3017FC10 R22=00000000 R23=DEADBEEF R24=1000F868 R25=30000330 R26=30151900 R27=300105A8 R28=EC065B50 R29=0000007E R30=00000001 R31=00000001 IAR=00000000 LR=D31B8BC0 MSR=0000D0B2 CTR=00000000 CR=22424284 FPSCR=82008000 XER=00000000 TID=00000000 MQ=DEADBEEF FPR0 4a39524f4d434c41 (f: 1296256128.000000, d: 3.700745e+49) FPR1 5353434f4f4b4945 (f: 1330334080.000000, d: 2.511314e+93) FPR2 c1e0000000000000 (f: 0.000000, d: -2.147484e+09) FPR3 408f400000000000 (f: 0.000000, d: 1.000000e+03) FPR4 4330080000000000 (f: 0.000000, d: 4.512396e+15) FPR5 3f60624de0000000 (f: 3758096384.000000, d: 2.000000e-03) FPR6 3ff0000000000000 (f: 0.000000, d: 1.000000e+00) FPR7 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR8 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR9 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR10 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR11 4030000000000000 (f: 0.000000, d: 1.600000e+01) FPR12 3fe8000000000000 (f: 0.000000, d: 7.500000e-01) FPR13 4028000000000000 (f: 0.000000, d: 1.200000e+01) FPR14 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR15 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR16 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR17 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR18 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR19 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR20 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR21 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR22 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR23 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR24 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR25 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR26 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR27 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR28 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR29 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR30 0000000000000000 (f: 0.000000, d: 0.000000e+00) FPR31 0000000000000000 (f: 0.000000, d: 0.000000e+00) Target=2_30_20070420_12448_bHdSMR (AIX 5.3) CPU=ppc (4 logical CPUs) (0x80000000 RAM) JVMDUMP006I Processing Dump Event "gpf", detail "" - Please Wait. JVMDUMP007I JVM Requesting System Dump using '/var/oa/v3/core.20081125.102624.245960.dmp' JVMDUMP010I System Dump written to /var/oa/v3/core.20081125.102624.245960.dmp JVMDUMP007I JVM Requesting Snap Dump using '/var/oa/v3/Snap0002.20081125.102624.245960.trc' JVMDUMP010I Snap Dump written to /var/oa/v3/Snap0002.20081125.102624.245960.trc JVMDUMP007I JVM Requesting Java Dump using '/var/oa/v3/javacore.20081125.102624.245960.txt' JVMDUMP010I Java Dump written to /var/oa/v3/javacore.20081125.102624.245960.txt JVMDUMP013I Processed Dump Event "gpf", detail "". [oa@XRF4] :
...la suite dans un prochain billet ;)
Une p'tite note en passant : lorsqu'on créé un utilisateur système sous AIX, pour l'execution d'un process par exemple (dans mon cas OpenAdaptor), une fois l'utilisateur créé (smit user
en root) il faut executer la commande :
pwdadm -c <login>
Ceci permet d'éviter des soucis lors de connexion FTP avec le compte par exemple...
Pour configurer l'authentification LDAP sur Drupal avec Active Directory : http://drupal.org/node/115146
Que faire lorsque l'on souhaite parser du contenu XML dans une application ?
Installer la librairie libxml2
:
> Sous AIX, si on a pas le CD IBM contenant les packages OpenSource, des sites existent sur lesquels on peut télécharger les packages à installer ensuite avec RPM (cela évite de tout avoir à recompiler) :
J'ai donc effectué une installation sur le serveur :
rpm -Uvh /var/oa/rpm/libxml2-2.6.32-1.aix5.1.ppc.rpm
zlib is needed by libxml2-2.6.32-1
Les dépendances rencontrées : zlib
-> zlib-1.2.3-5.aix5.1.ppc.rpm
... en fait y'en avait qu'une ;)
Bon du coup chui un fou, j'installe aussi de quoi faire des transfo XML : XSLT. Ca se passe donc dans la librairie libxsl :
rpm -Uvh /var/oa/rpm/libxslt-1.1.24-1.aix5.1.ppc.rpm
libgcrypt is needed by libxslt-1.1.24-1
... bon je passe rapidement mais en fait il faut aussi installer les librairies suivantes : libgpg-error
et libgcrypt
...
Voilà pour l'installation des librairies GNU XML et XSLT sous AIX !
Lors de la compilation d'un programme C qui utilise l'API Informix 4GL, il peut arriver que vous rencontriez ce message d'erreur :
XLO2-mag-dev-F > cc -c \ > -I/home/etud/agoun/include/libxml2 -I/infx9.40/incl/tools -I/infx9.40/incl/esql \ > proto_xml_api.c -o proto_xml_api.o "/infx9.40/incl/tools/locator.h", line 124.7: 1506-334 (S) Identifier loc_t has already been defined on line 195 of "/usr/include/sys/localedef31.h".
Il faut alors ajouter la directive -D_H_LOCALEDEF au compilateur.