如题: 以前发过这个帖子,都说理论上说都可以,有没有真正在JAVA下调VB编译的动态连接库成功的?  急  急  急   谢谢各位大虾帮忙

解决方案 »

  1.   

    你是说调用dll文件吗?以前试过,网上有很多资料,由于必须读取客户端本地硬件,所以放弃,后来采用ocx,不过原理一样///////首先确保你的dll发布服务啦,然后实例化该服务器上的dll,在调用该dll文件的公用接口
      

  2.   

    因为我是用VB编译的动态库,提供给用户使用的.本人对于JAVA只了解皮毛.
    用户提出的在JAVA下不能调用VB编译的动态连接库
    "首先确保你的dll发布服务啦,然后实例化该服务器上的dll,在调用该dll文件的公用接口"
      请问这个是在VB下做的步骤还是在JAVA下做的步骤?
      

  3.   

    首先确保你的dll发布服务啦   这个是不是指要用regsvr32来注册VB下编译的动态连接库????
      

  4.   

    去网上搜jni的相关资料? 
    谢谢提醒 问过同学说是可以在JAVA下调用VB的动态库  
    他有同事在APPLET下调用成功过  有人试过吗?
      

  5.   

    JNI就是用Java和C,C++语言交互 能调用VB下的动态库吗?>
      

  6.   

    给你拷贝一文章,看看对你有帮助吗?刚才用javah MyNative生成的MyNative.h头文件内容如下: 
       /* DO NOT EDIT THIS FILE - it is machine generated */
       #include <jni.h>
      /* Header for class MyNative */
      #ifndef _Included_MyNative
       #define _Included_MyNative
       #ifdef __cplusplus
      extern "C" {
      #endif
      
    /*
      * Class:     MyNative
      * Method:    HelloWord
      * Signature: ()V
    */
      JNIEXPORT void JNICALL Java_MyNative_HelloWord (JNIEnv *, jclass);
      /*
      * Class:     MyNative
      * Method:    cToJava
      * Signature: ()Ljava/lang/String;
      */
      JNIEXPORT jstring JNICALL Java_MyNative_cToJava (JNIEnv *, jclass);
      #ifdef __cplusplus
      }
      #endif
      #endif
    接下来,就是如何实现它了。其实,用JNI作出的东西也是DLL,被JAVA所调用。
      在具体实现的时候,我们只关心两个函数原型:
      JNIEXPORT void JNICALL Java_MyNative_HelloWord(JNIEnv *, jclass);
         JNIEXPORT jstring JNICALL Java_MyNative_cToJava(JNIEnv *, jclass);
    在project里面选择win32 Dynamic-link Library,然后点击下一步,其余的取默认。如果不取默认的,将会有dllmain()函数。取空DLL工程的话,将无这个函数。
    然后选择new->File->C++ Source File,生成一个空*.cpp文件。取名为MyNative。把JNIEXPORT void JNICALL Java_MyNative_HelloWord(JNIEnv *, jclass);和JNIEXPORT jstring JNICALL Java_MyNative_cToJava(JNIEnv *, jclass);拷贝到CPP文件中去。然后把头文件包含进来。
      生成的MyNative.cpp内容如下:
      #include <stdio.h>
      #include "MyNative.h"
       JNIEXPORT void JNICALL Java_MyNative_HelloWord (JNIEnv *env, jclass jobject)
     {
      printf("hello word!\n");        
     }
      JNIEXPORT jstring JNICALL Java_MyNative_cToJavaJNIEnv *env, jclass obj)
      {
      jstring jstr;
      char str[]="Hello,word!\n";
      jstr=env->NewStringUTF(str);
      return jstr;
      } 
      在编译前一定要注意下列情况。
      注意:一定要把SDK中的include文件夹中(和它下面的win32文件夹下的头文件)的几个头文件拷贝到VC的include文件夹中。或者在VC的tools\options\directories中设置,把头文件给包含进来。
    对程序的一点解释:
      1)加了static和不加只是一个参数的区别吗。就是jclass的不同,不加static这里就是jobject。也就是JNIEXPORT void JNICALL Java_MyNative_HelloWord(JNIEnv *env, jobject obj)。
      2)这里JNIEXPORT和JNICALL都是JNI的关键字,表示此函数是要被JNI调用的。而jstring是以JNI为中介使JAVA的String类型与本地的string沟通的一种类型,我们可以视而不见,就当做String使用(具体对应见表一)。函数的名称是JAVA_再加上java程序的package路径再加函数名组成的(参见有包的情况)。参数中,我们也只需要关心在JAVA程序中存在的参数,至于JNIEnv*和jclass我们一般没有必要去碰它。
      3)NewStringUTF()是JNI函数,从一个包含UTF格式编码字符的char类型数组中创建一个新的jstring对象。
      4) 以上程序片断jstr=env->NewStringUTF(str);是C++中的写法,不必使用env指针。因为JNIEnv函数的C++版本包含有直接插入成员函数,他们负责查找函数指针。而对于C的写法,应改为:jstr=(*env)->NewStringUTF(env,str);因为所有JNI函数的调用都使用env指针,它是任意一个本地方法的第一个参数。env指针是指向一个函数指针表的指针。因此在每个JNI函数访问前加前缀(*env)->,以确保间接引用函数指针。
      在C和Java编程语言之间传送值时,需要理解这些值类型在这两种语言间的对应关系。这些都在头文件jni.h中,用typedef语句声明了这些类在目标平台上的代价类。头文件也定义了常量如:JNI_FALSE=0 和JNI_TRUE=1;
    表一说明了Java类型和C类型之间的对应关系。
      表一   Java类型和C类型
    Java编程语言 C编程语言 字节 
    boolean jboolean 1 
    byte jbyte 1 
    char jchar 2 
    short jshort 2 
    int jint 4 
    long jlong 8 
    float jfloat 4 
    double jdouble 8 现在开始对所写的程序进行编译。选择build->rebuild all对所写的程序进行编译。点击build->build MyNative.DLL生成DLL文件。
      也可以用命令行cl来编译。具体参看其他书籍。
      再次强调(曾经为这个东西大伤脑筋):DLL放置地方
      1) 当前目录。
      2) 放在path所指的路径中
      3) 自己在path环境变量中设置一个路径,要注意所指引的路径应该到.dll文件的上一级,如果指到.dll,则会报错。
    下面就开始测试我们的所写的DLL吧(假设DLL已放置正确)。
       public class mytest
      {
      public static void main(String[] args)
      {
      MyNative a=new MyNative();
      a.HelloWord();
      System.out.println(a.cToJava());
      }
      }
      注意也要把MyNative.class放在与mytest.java同一个路径下。现在开始编译运行mytest,是不是在DOS窗口上输出:
       Hello word!
      Hello,world!
      以上是通过JNI方法调用的一个简单C程序。但在实际情况中要比这复杂的多。特别是在通过JNI调用其他DLL时,还有很多的地方需要注意。
      现在开始来讨论包含包的情况,步骤与上面的相同,只是有一点点不同。来看其中的一个函数。
       JNIEXPORT void JNICALL Java_com_MyNative_MyNative_HelloWord (JNIEnv *env, jclass jobject)
      {
      printf("hello word!\n");        
      } 
      观察函数名称。函数的名称是JAVA_再加上java程序的package路径再加函数名组成的。
      

  7.   

    会用vb调用dll服务吗?将其放到[我的电脑]-->[控制面板]-->组件服务---〉发布运行即可
    然后客户端调用采用类示与三层架构中vb调用远程应用服务端 一样
         dim aa as object                      
         set aa=server.createobject("bb.class")  //实例化server应用服务器上bb.dll
         aa.函数                                 //调用bb内封装函数