1. 現在我有一個DLL文件,我想在java中調用DLL文件中的方法,請問如何實現
一般那種c#的dll是java不能直接調用的,但C\C++可以,你可以使用JNI。比如你要一個 public native void sengMsg(String msg); 來發送信息,先用native關鍵字聲明這個函數,然後再類裡面加一個靜態塊: static { System.loadLibrary("msg"); } 這里的msg是你的後來編譯的dll文件名,不是簡訊貓帶的。 然後寫其他的函數就可以調用這個方法了,寫完後用javac編譯,得到class文件,然後用 javah -jni 你的class文件 就會得到一個.h的頭文件,用visual studio新建一個dll,把那個.h文件包含進去,用C\C++調用你現有的dll,然後編譯得到你的msg.dll,把它復制到你的class文件目錄,然後就可以調試運行了。
2. java中怎麼調用vb編寫的dll文件啊,網上找了很多例子了,都不行。希望可以有詳細的代碼,謝謝大家了。
用JNI(Java Native Interface),它允許Java代碼和其他語言寫的代碼進行交互。JNI一開始是為了本地已編譯語言,尤其是C和C++而設計的,但是它並不妨礙你使用其他語言,只要調用約定受支持就可以了。
使用步驟:
·使用javac命令編譯所編寫的java類·編寫帶有native聲明的方法的java類
JNI
,然後使用javah + java類名生成擴展名為h的頭文件
·使用C/C++實現本地方法
·將C/C++編寫的文件生成動態連接庫
·ok
1) 編寫java程序:這里以HelloWorld為例。
代碼1:
public class HelloWorld {
public native void displayHelloWorld();//所有native關鍵詞修飾的都是對本地的聲明
static {
System.loadLibrary("hello");//載入本地庫
}
public static void main(String[] args) {
new HelloWorld().displayHelloWorld();
}
}
聲明native方法:如果你想將一個方法做為一個本地方法的話,那麼你就必須聲明該方法為native的,並且不能實現。其中方法的參數和返回值在後面講述。 Load動態庫:System.loadLibrary("hello");載入動態庫(我們可以這樣理解:我們的方法 displayHelloWorld()沒有實現,但是我們在下面就直接使用了,所以必須在使用之前對它進行初始化)這里一般是以static塊進行載入的。同時需要注意的是System.loadLibrary();的參數「hello」是動態庫的名字。
2) 編譯
沒有什麼好說的了javac HelloWorld.java
3) 生成擴展名為h的頭文件javah HelloWorld
jni HelloWorld 頭文件的內容:
/*DO NOT EDI TTHIS FILE - it is mach inegenerated*/
#include<jni.h>
/*Header for class HelloWorld*/
#ifndef_Included_HelloWorld
#define_Included_HelloWorld
#ifdef__cplusplus
extern"C"{
#endif
/*
*Class:HelloWorld
*Method:displayHelloWorld
*Signature:()V
*/
JNIEXPORTvoidJNICALL
Java_HelloWorld_displayHelloWorld(JNIEnv*,jobject);
#ifdef__cplusplus
}
#endif
#endif
JNI
(這里我們可以這樣理解:這個h文件相當於我們在java裡面的介面,這里聲明了一個Java_HelloWorld_displayHelloWorld (JNIEnv *, jobject);方法,然後在我們的本地方法裡面實現這個方法,也就是說我們在編寫C/C++程序的時候所使用的方法名必須和這里的一致)。
4) 編寫本地方法實現和由javah命令生成的頭文件裡面聲明的方法名相同的方法。
代碼2:
#include"jni.h"
#include"HelloWorld.h"
JNI3//#includeotherheaders
JNIEXPORTvoidJNICALL
Java_HelloWorld_displayHelloWorld(JNIEnv*env,jobjectobj)
{
printf("Helloworld!\n");
return;
}
JNI
注意代碼2中的第1行,需要將jni.h(該文件可以在%JAVA_HOME%/include文件夾下面找到)文件引入,因為在程序中的JNIEnv、 jobject等類型都是在該頭文件中定義的;另外在第2行需要將HelloWorld.h頭文件引入(我是這么理解的:相當於我們在編寫java程序的時候,實現一個介面的話需要聲明才可以,這里就是將HelloWorld.h頭文件裡面聲明的方法加以實現。當然不一定是這樣)。然後保存為 HelloWorldImpl.c就ok了。
5) 生成動態庫
這里以在Windows中為例,需要生成dll文件。在保存HelloWorldImpl.c文件夾下面,使用VC的編譯器cl成。 cl -I%java_home%\include -I%java_home%\include\win32 -LD HelloWorldImp.c -Fehello.dll 注意:生成的dll文件名在選項-Fe後面配置,這里是hello,因為在HelloWorld.java文件中我們loadLibary的時候使用的名字是hello。當然這里修改之後那裡也需要修改。另外需要將-I%java_home%\include -I%java_home%\include\win32參數加上,因為在第四步裡面編寫本地方法的時候引入了jni.h文件。
如果配置了MinGW,也可以這樣來編譯:gcc -Wall -D_JNI_IMPLEMENTATION_ -Wl,--kill-at -Id:/java/include –Id:/java/include/win32 -shared -o (輸出的dll文件名,如sum.dll) (輸入的c/c++源文件,如abc.c)。
6) 運行程序
javaHelloWorld就ok.
如果用eclipse,需將dll或so文件放在項目下,而不是src及其子目錄下。
如果用命令行編譯,把dll文件放在該包的同目錄下。
3. 用Java怎麼調用C語言已經編寫好的DLL
1.用System.getProperty("user.dir"),獲取程序抄的路徑,估計你的應該是 E:\\測試程序不清楚列印一下就可以了。System.getProperty("user.dir") + "\\DLL\\CardAPI"2.unsigned char 用char就可以了unsigned int 用int就可以了,java的int值很大.....C的無符號的記得是65535 unsigned char*、和unsigned int* 這兩個是指針,第一個是取1位地址內容的,第二個根據系統而定,一般是取4位地址值的,用java 的String對應,應該可以 。
4. 如何在java中調用.dll文件,詳細點帶上代碼這些辣
首先下截JNative組件
jnative.sourceforge.net/ 到這里下載JNative開源項目,我下載的是1.3.2
解壓JNative-<st1:chsdate isrocdate="False" islunardate="False" day="30"
month="12" year="1899">1.3.2</st1:chsdate>.zip
獲得三個文件,分別是:JNativeCpp.dll,libJNativeCpp.so,JNative.jar 。
JNativeCpp.dll
Windows下用的,拷貝到windows / system32目錄下;
libJNativeCpp.so
Linux下的,拷貝到系統目錄下;
JNative.jar這是一個擴展包,導入工程LIB中或將其拷貝到jdk\jre\lib\ext
下,系統會自動載入。
•使用說明
我的項目將使用JNative組件調用一個測試應用伺服器狀態的TestAppSvr.dll文件,Dll文件中包含一個TestConnect()方法,返回一個整形的結果(1或0)
首先配置好JNative組件的windows環境:
將Native要用到JNativeCpp.dll放在系統盤的\WINDOWS\system32下
將JNative.jar導入工程中,新建一個調用類:
java 代碼
復制代碼
代碼如下:
package com.tvjody;
import
java.io.File;
import java.io.FileOutputStream;
import
java.io.IOException;
import java.io.InputStream;
import
org.xvolks.jnative.JNative;
import org.xvolks.jnative.Type;
import
org.xvolks.jnative.exceptions.NativeException;
public class
AppSvrTestConnect {
public AppSvrTestConnect() {
}
/**
* 測試應用伺服器連接狀態
*
* TestConnect
* @param ip 應用伺服器IP
* @param port 埠
* @param
intrcpt 是否採用數據壓縮方式 1 :true 0:false
* @return int 1 :成功 0:失敗
* @throws NativeException
* @throws IllegalAccessException
*/
private static final int TestConnect(String ip, int port, int
intrcpt)throws NativeException, IllegalAccessException {
JNative n
= null;
try {
n = new
JNative("TestAppSvr.dll", "TestConnect");
n.setRetVal(Type.INT);
int i = 0;
n.setParameter(i++, Type.STRING, ip);
n.setParameter(i++,
Type.INT, "" + port);
n.setParameter(i++, Type.INT, "" +
intrcpt);
n.invoke();
return
Integer.parseInt(n.getRetVal());
} finally {
if
(n != null)
n.dispose();
}
}
/**
* 指定Dll文件路徑,動態載入本地鏈接庫,測試應用伺服器連接狀態
* setDllPath
* @param path Dll文件的路徑,不包含DLL名稱 例如:windows - d:\test\test\ unix -
root/test/test/
* @param ip 應用伺服器IP
* @param port 埠
* @param intrcpt 是否採用數據壓縮方式 1 :true 0:false
* @return int 1
:成功 0:失敗
* @throws NativeException
* @throws
IllegalAccessException
*/
public static final int
TestConnectFromDllPath(String path,String ip, int port, int intrcpt) throws
NativeException, IllegalAccessException{
path +=
"TestAppSvr.dll";
System.load(path);
return
TestConnect(ip,port,intrcpt);
}
/**
*
Dll文件放在JRE\bin目錄下面,ClassLoader就能通過System.loadLibrary()動態載入本地鏈接庫
*
TestConnectFromDllPath
* @param ip 應用伺服器IP
* @param port 埠
* @param intrcpt 是否採用數據壓縮方式 1 :true 0:false
* @return int 1
:成功 0:失敗
* @throws NativeException
* @throws
IllegalAccessException
*/
public static final int
TestConnectFromDllPath(String ip, int port, int intrcpt) throws NativeException,
IllegalAccessException{
System.loadLibrary("TestAppSvr");
return TestConnect(ip,port,intrcpt);
}
}
這個類實現了一個靜態私有方法,用來調用Dll文件中的方法返回結果
private static final int TestConnect(String ip, int port, int intrcpt)
兩個靜態公共方法,分兩種方式裝載DLL文件
public static final int TestConnectFromDllPath(String path,String ip, int
port, int intrcpt) //通過DLL文件的路徑
public static final int
TestConnectFromDllPath(String ip, int port, int intrcpt)
//通過ClassLoader
然後新建一個類,調用AppSvrTestConnect.java,實現方法一調用,我是將TestAppSvr.dll文件與Demo.java放在一個目錄下
,所以得到Demo.java的路徑後就可以得到TestAppSvr.dll的路徑,調用AppSvrTestConnect.TestConnectFromDllPath()方法後就能返回正確的信息.方法二是已經將TestAppSvr.dll放在了Jre\bin目錄下,在JVM的Classloader的時候會自動載入,然後通過System.loadLibrary("TestAppSvr")就可以裝配DLL文件.
java 代碼
復制代碼
代碼如下:
public class Demo {
public int
getInfo() throws NativeException, IllegalAccessException{
String path=getClass().getResource(File.separator).getPath();
path = path.substring(1,path.length());
System.out.println(path); //得到DLL文件的路徑
String ip =
"192.168.0.48"; //伺服器IP
int port = 221; //埠
int intrcpt = 1; //數據壓縮方式傳送,1為採用;0為不採用
//方法1 傳入Dll文件的路徑
//int info =
AppSvrTestConnect.TestConnectFromDllPath(path, ip, port, intrcpt);
//方法2 Dll文件已經放在JRE\bin目錄下面
int info =
AppSvrTestConnect.TestConnectFromDllPath(ip, port, intrcpt);
//1為成功,0為失敗
if (info == 1)
System.out.println("應用伺服器可用。");
else
System.out.println("應用伺服器不可用,請檢查IP地址和埠是否正確。");
return info;
}
System.loadLibrary():裝載Windows\System32下或jre\bin或Tomcat\bin目錄下的本地鏈接庫
System.load():根據具體的目錄來加截本地鏈接庫,必須是絕對路徑
•備注
上面的示例工程,因為是例子,所以沒有大多的設計,只是實現了裝載DLL文件,調用DLL文件方法,返回信息.
注意JVM只允許一個默認的ClassLoader來load native library,同時並不提供專門的API來unload一個loaded
native library,所以在項目調試的時候,獨立啟動Web Server.
5. 如何用java調用c 編寫成的DLL
雖然復java已經能夠幫我們做了很多制事情,幾乎大部分的東西現在都可以用java來編寫,但是有很多時候,用c 能夠更好的實現系統的一些功能,因此,在java中調用c 編寫的東西就顯得十分的必要。這邊文章將為你介紹用java調用vc 編寫的工程的dll文件。1 。編寫java的類,這個類中System loadLibrary 是載入動態鏈接庫,SallyDLL是由c 產生的文件,等下將有介紹,public native int add int num1 int num2 ;是一個聲明的方法,該方法的實現是由c 完成的,在java中可以跟一般的方法一樣調用。
6. java web怎麼調用dll
java調用dll要用到jni(java本地介面)
例如程序TestDll.java,內容為:
publicclassTestDll
{
static
{
System.loadLibrary("xxx.dll");
}
publicnativestaticintget();
publicnativestaticvoidset(inti);
publicstaticvoidmain(String[]args)
{
TestDlltest=newTestDll();
test.set(10);
System.out.println(test.get());
}
}
這個例子只是為了示意jni如何用,並不是實際的工程代碼。
你可以搜索一下jni的詳細信息,通常都有詳細的例子(如使用user32.dll的例子)