[转帖]求助,JNI调用TUXEDO报错_MQ, Tuxedo及OLTP讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MQ, Tuxedo及OLTP讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 3084 | 回复: 0   主题: [转帖]求助,JNI调用TUXEDO报错        下一篇 
jun.zhang
注册用户
等级:上士
经验:278
发帖:76
精华:0
注册:2011-12-27
状态:离线
发送短消息息给jun.zhang 加好友    发送短消息息给jun.zhang 发消息
发表于: IP:您无权察看 2014-11-3 12:00:07 | [全部帖] [楼主帖] 楼主

求助,JNI调用TUXEDO报错
麻烦大家帮忙看看

 103225.cbly03!?proc.438306.1.0: 07-24-2009: Tuxedo Version 8.1, 32-bit
103225.cbly03!?proc.438306.1.0: GP_CAT:1561: ERROR: Problem with license file /tuxedo/tuxedo8.1/udataobj/lic.txt
103225.cbly03!?proc.438306.1.0: LIBTUX_CAT:6031: ERROR: Unable to pre-process buffer before tranmission.  Error code(4/3606)
103225.cbly03!?proc.438306.1.0: LIBWSC_CAT:1045: ERROR: Presend on message failed
103225.cbly03!?proc.438306.1.0: LIBWSC_CAT:1011: ERROR: tpcall() message send failure


我是在AIX5.2 上装的TUXDO8.1,是用C 的maikefile调用.so文件没有问题,用JNI调用就报这个错

xlc -c testconnect.c -I$TUXDIR/include -I/usr/java14/include
xlc -G -o libct.so testconnect.o -L${TUXDIR}/lib -I$TUXDIR/include -lwsc -lbuft -lwsc -lgpnet -lfml -lfml32 -lengine -lpthread


下面是我C文件调用的部分

JNIEXPORT jint JNICALL Java_testconnect_send_1recv(JNIEnv * env, jobject obj)
{
      char * sendbuf;
      char * rcvbuf;
      int sendlen;
      long rcvlen;
      int ret;
      jfieldID commStringfid;
      TPINIT * tpinfo = NULL;
      char * sendjstr;
      int tmpi;
      tuxputenv("WSNADDR=//192.168.221.105:4444");
      printf("wsnaddr=[%s]\n", tuxgetenv("WSNADDR"));
      tpinfo = (TPINIT *)tpalloc("TPINIT", NULL, TPINITNEED(32));
      if(tpinfo != NULL)
      {
            tpinfo->datalen = 0;
            sprintf(tpinfo->usrname, "");
            sprintf((char*) &(tpinfo->data), "");
            sprintf(tpinfo->cltname, "");
            sprintf(tpinfo->passwd, "");
            tpinfo->flags = TPU_IGN | TPSA_FASTPATH;
      }
      else {
            (void)fprintf(stderr, "\nERROR: tpalloc failed (%s)\n", tpstrerror(tperrno));
            tpterm();
            return -101;
      }
      tmpi = tpinit(tpinfo);
      printf("tpinit(tpinfo)=[%d]\n", tmpi);
      if (tmpi == -1)
      {
            (void)fprintf(stderr, "\nERROR: tpalloc failed (%s)\n", tpstrerror(tperrno));
            tpfree((char *)tpinfo);
            tpterm();
            return -101;
      }
      sendjstr = "339 0000@INQ A0005 TYUIO userid=A0005|brchno=9901|tmnlno=A005|prcscd=@INQ|RGCD=9901|TSRG=9901|SVID=A005|USID=A0005|PRID=@INQ|";
      sendlen = strlen(sendjstr);
      if((sendbuf = (char *) tpalloc("STRING", NULL, sendlen + 1)) == NULL) {
            (void) fprintf(stderr, "\nError allocating send buffer\n");
            tpterm();
            return -102;
      }
      (void) strcpy(sendbuf, sendjstr);
      if((rcvbuf = (char *) tpalloc("STRING", NULL, rcvlen)) == NULL) {
            (void) fprintf(stderr, "\nError allocating receive buffer\n");
            tpfree(sendbuf);
            tpterm();
            return -103;
      }
      printf("sendbuf=[%s],sendlen=[%d]\n", sendbuf, sendlen);
      ret = tpcall("MIDDB", (char *)sendbuf, 0, (char **)&rcvbuf, &rcvlen, (long)0);
      if(ret == -1) {
            if (tperrno==TPETIME)
            ret=-105;
            else
            ret=-104;
            (void) fprintf(stderr, "\nCan't send request to service MIDDB\n");
            (void) fprintf(stderr, "\nTperrno = %d\n", tperrno);
            tpfree(sendbuf);
            tpfree(rcvbuf);
            tpterm();
            printf("ret=[%d]\n", ret);
            return ret;
      }
      if (commStringfid != 0)
      {
            (*env)->SetObjectField(env, obj, commStringfid, JNU_NewStringNative(env, rcvbuf));
      }
      printf("rcvbuf =[%s],rcvlen =[%d]\n", rcvbuf, rcvlen);
      tpfree(sendbuf);
      tpfree(rcvbuf);
      tpfree((char *)tpinfo);
      return ret;
}


--转自
北京联动北方科技有限公司




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论