jbyte * arrayBody = env->GetByteArrayElements(data,0);
jsize theArrayLengthJ = env->GetArrayLength(data);
BYTE * starter = (BYTE *)arrayBody;
jbyteArray 转 c++中的BYTE[]
//jbytearray strIn
jbyte * olddata = (jbyte*)env->GetByteArrayElements(strIn, 0);
jsize oldsize = env->GetArrayLength(strIn);
BYTE* bytearr = (BYTE*)olddata;
int len = (int)oldsize;
C++中的BYTE[]转jbyteArray
//nOutSize是BYTE数组的长度 BYTE pData[]
jbyte *by = (jbyte*)pData;
jbyteArray jarray = env->NewByteArray(nOutSize);
env->SetByteArrayRegin(jarray, 0, nOutSize, by);
jbyteArray 转 char *
char* data = (char*)env->GetByteArrayElements(strIn, 0);
char* 转jstring
jstring WindowsTojstring(JNIEnv* env, char* str_tmp)
{
jstring rtn=0;
int slen = (int)strlen(str_tmp);
unsigned short* buffer=0;
if(slen == 0)
{
rtn = env->NewStringUTF(str_tmp);
}
else
{
int length = MultiByteToWideChar(CP_ACP, 0, (LPCSTR)str_tmp, slen, NULL, 0);
buffer = (unsigned short*)malloc(length*2+1);
if(MultiByteToWideChar(CP_ACP, 0, (LPCSTR)str_tmp, slen, (LPWSTR)buffer, length) > 0)
{
rtn = env->NewString((jchar*)buffer, length);
}
}
if(buffer)
{
free(buffer);
}
return rtn;
}
下面这个没有用过,刚看到,也写进来,以后如果遇到可以验证下看。
jstring 转 char* 或者 const char*
// jstring str
const char *key = env->GetStringUTFChars(str, 0);
//jboolean isOffer
jsClient->modify(key, isOffer);
env->ReleaseStringUTFChars(str, key);
JNI 返回 jbyteArray
JNIEXPORT jbyteArray JNICALL Java_Test_getByteArray(JNIEnv *env, jobject obj)
{
jbyteArray firstMacArray = env->NewByteArray( 6 );
..elided...
jbyte *bytes = env->GetByteArrayElements( firstMacArray, 0);
for ( int i = 0; i < sizeof( pAdapterInfo->Address ); i++ )
{
bytes[ i ] = pAdapterInfo->Address[ i ];
}
env->SetByteArrayRegion(firstMacArray, 0, 6, bytes );
return firstMacArray;
}
//jstring to char*
char* jstringTostring(JNIEnv* env, jstring jstr)
{
char* rtn = NULL;
jclass clsstring = env->FindClass("java/lang/String");
jstring strencode = env->NewStringUTF("utf-8");
jmethodID mid = env->GetMethodID(clsstring, "getBytes", "(Ljava/lang/String;)[B");
jbyteArray barr= (jbyteArray)env->CallObjectMethod(jstr, mid, strencode);
jsize alen = env->GetArrayLength(barr);
jbyte* ba = env->GetByteArrayElements(barr, JNI_FALSE);
if (alen > 0)
{
rtn = (char*)malloc(alen + 1);
memcpy(rtn, ba, alen);
rtn[alen] = 0;
}
env->ReleaseByteArrayElements(barr, ba, 0);
return rtn;
}
//char* to jstring
jstring stoJstring(JNIEnv* env, const char* pat)
{
jclass strClass = env->FindClass("Ljava/lang/String;");
jmethodID ctorID = env->GetMethodID(strClass, "<init>", "([BLjava/lang/String;)V");
jbyteArray bytes = env->NewByteArray(strlen(pat));
env->SetByteArrayRegion(bytes, 0, strlen(pat), (jbyte*)pat);
jstring encoding = env->NewStringUTF("utf-8");
return (jstring)env->NewObject(strClass, ctorID, bytes, encoding);
}
//将jstring类型转换成windows类型
char* jstringToWindows( JNIEnv *env, jstring jstr )
{
int length = (env)->GetStringLength(jstr );
const jchar* jcstr = (env)->GetStringChars(jstr, 0 );
char* rtn = (char*)malloc( length*2+1 );
int size = 0;
size = WideCharToMultiByte( CP_ACP, 0, (LPCWSTR)jcstr, length, rtn,(length*2+1), NULL, NULL );
if( size <= 0 )
return NULL;
(env)->ReleaseStringChars(jstr, jcstr );
rtn[size] = 0;
return rtn;
}
//将windows类型转换成jstring类型
jstring WindowsTojstring( JNIEnv* env, char* str )
{
jstring rtn = 0;
int slen = strlen(str);
unsigned short * buffer = 0;
if( slen == 0 )
rtn = (env)->NewStringUTF(str );
else
{
int length = MultiByteToWideChar( CP_ACP, 0, (LPCSTR)str, slen, NULL, 0 );
buffer = (unsigned short *)malloc( length*2 + 1 );
if( MultiByteToWideChar( CP_ACP, 0, (LPCSTR)str, slen, (LPWSTR)buffer, length ) >0 )
rtn = (env)->NewString( (jchar*)buffer, length );
}
if( buffer )
free( buffer );
return rtn;
}
/*JNIEXPORT jstring JNICALL Java_test_cs_web_SWIFTAlianceCASmfTest_strcal
(JNIEnv *env, jclass obj, jstring jstr1, jstring jstr2)
{
jbyteArray bytes = 0;
jthrowable exc;
char *pszResult = NULL;
char *pszSTR1 = NULL;
char *pszSTR2 = NULL;
pszSTR1 = jstringTostring(env, jstr1);
pszSTR2 = jstringTostring(env, jstr2);
int nlen = sizeof(char)*(strlen(pszSTR1)+strlen(pszSTR2));
pszResult = (char*)malloc(nlen);
strcpy(pszResult, pszSTR1);
strcat(pszResult, pszSTR2);
jstring jstrRe = stoJstring(env, pszResult);
free(pszSTR1);
free(pszSTR2);
free(pszResult);
return(jstrRe);
}
*/
jni object的使用
每一个jni格式的dll中的object对应该java里面的一个类。
如下例有一个 ObjData类,类中有成员bData ,Len
public class ObjData {
public byte[] bData;
public int Len;
}
//------------------------jni获得传过来的Object类型的变量objDataIn--------
jclass clazz =(env)->FindClass("ObjData");
//从传进来的对象中取出byte[]
jfieldID byteData = (env)->GetFieldID(clazz,"bData","[B");
jbyteArray pDataIn = (jbyteArray) (env)->GetObjectField(objDataIn, byteData);
jsize theArrayLeng = env->GetArrayLength(pDataIn);
//byte[]转为BYTE[]
jbyte * arrayBody = env->GetByteArrayElements(pDataIn,0);
BYTE * jDataIn = (BYTE *)arrayBody;
//将BYTE数组转为jarray
jbyte* byte = (jbyte*)jDataOut;
jbyteArray jarray = env->NewByteArray(theArrayLeng);
env->SetByteArrayRegion(jarray, 0, theArrayLeng, byte);
//给每一个实例的变量付值
(env)->SetObjectField(objDataIn,byteData,jarray);
(env)->SetIntField(objDataIn,pDataInLen,jDataInLen);
(env)->ReleaseByteArrayElements(pDataIn, arrayBody, 0);
相关推荐
Chap1:JNI完全手册......Chap8:如何将java传递过来的jbyteArray转换成C/C++中的BYTE数组... 47 Chap5:使用JNI技术实现java程序调用第三方dll(c/c++)文件的功能... 47 Chap9:如何编写jni方法(转载)... 55
1. **jbyteArray转C/C++ BYTE数组**: ``` jbyte *arrayBody = env->GetByteArrayElements(data, 0); jsize theArrayLengthJ = env->GetArrayLength(data); BYTE *starter = (BYTE *)arrayBody; ``` 2. **C/...
- **jbyteArray转BYTE数组**:JNI提供`GetByteArrayElements`和`ReleaseByteArrayElements`用于在C/C++中操作Java的字节数组。 综上所述,JNI编程技术涉及到了Java与本地代码的交互,包括数据类型转换、方法调用、...
在Android开发中,有时我们需要利用C++的性能优势或者利用已有的C++库来处理一些复杂的计算任务。JNI(Java Native Interface)就是这样一个桥梁,它允许Java代码与本地(Native)代码,如C++,进行交互。在这个...
- **如何将java传递过来的jbyteArray转换成C/C++中的BYTE数组**:这一章节详细说明了如何将Java中的`jbyteArray`转换为C/C++中的`BYTE`数组,这对于处理二进制数据非常有用。 - **使用JNI技术实现java程序调用第三方...
Java_NativeCryptoHelper_verifySignature(JNIEnv *env, jobject /* this */, jbyteArray data, jbyteArray signature) { // 实现签名验证逻辑 // ... } ``` 3. 签名验证逻辑:在`verifySignature`函数中,你需要...
在深入学习如何在Java和C/C++之间传递参数的同时,本手册还介绍了JNI中的参数传递机制,特别是如何将Java中的jbyteArray转换为C/C++中的BYTE数组。此外,还讲解了如何使用JNI技术实现Java程序调用第三方动态链接库...
Chap8:如何将java传递过来的jbyteArray转换成C/C++中的BYTE数组... 47 Chap5:使用JNI技术实现java程序调用第三方dll(c/c++)文件的功能... 47 Chap9:如何编写jni方法(转载)... 55 1、实例一:在jni中调用标准c中...
例如,Java的`jbyteArray`在C++中需要转换为`BYTE`数组。`jbyteArray`可以使用`GetByteArrayElements`获取原始字节数据,完成后记得使用`ReleaseByteArrayElements`释放。 **调用C/C++库**: JNI允许Java程序调用第...
在这个过程中,`JNIEnv`指针用于访问Java对象和方法,`jbyteArray`代表Java的字节数组,我们可以直接在C/C++代码中操作这些数组来执行加密解密操作。 总结来说,通过JNI调用native方法实现加密解密,开发者可以充分...
例如,我们可以创建一个`convertJBigToBmp`方法,接受JBig数据的字节数组和目标BMP文件路径作为参数。 ```java public native void convertJBigToBmp(byte[] jbigData, String bmpFilePath); ``` 2. **编写JNI...
- **jbyteArray转换**:在处理`jbyteArray`时,通常需要将其转换为C/C++中的`BYTE`数组,以便于在本地代码中进行操作。 7. **调用第三方库** - **实现Java程序调用DLL文件**:通过JNI,Java程序能够调用由C/C++...
| `byte[]` | `jbyteArray` | 比特型数组 | | `char[]` | `jcharArray` | 字符型数组 | | `short[]` | `jshortArray` | 短整型数组 | | `int[]` | `jintArray` | 整型数组 | #### 八、结构体传递示例 对于结构体`...
public native static int getStrNum(byte[] str, int strLen); // 静态初始化块,用于加载动态链接库 static { System.loadLibrary("MakeDLL"); } public static void main(String[] args) { String str =...
在上面的代码中,我们首先创建了一个 byte 数组,然后将其传递给 Java 方法。最后,我们使用 JNIEnv 的 CallStaticBooleanMethod 函数来调用静态方法。 使用 C/C++ 语言调用 Java 语言的实例需要三个步骤:获得 ...
- **应用场景**:例如,如何将Java中的`jbyteArray`转换成C/C++中的`BYTE`数组,这对于处理二进制数据非常有用。 #### 知识点七:JNI方法编写实例 - **主要内容**:通过一系列具体实例展示了如何在JNI中实现不同...
例如,可以编写一个JNI函数,接收Java的字节数组,然后调用C/C++的Base64库进行编码。这里可能需要引入第三方的Base64库,如OpenSSL或自己实现Base64算法。以下是一个简单的JNI函数声明: ```java public native ...
JNIEXPORT jint JNICALL Java_Main_getStrNum(JNIEnv *env, jclass cls, jbyteArray str, jint strLen) { jbyte *buffer = (*env).GetByteArrayElements(str, 0); buffer[strLen] = '\0'; // 为字符串添加结束符 ...
例如,使用`JNIEnv`指针进行对象和数组的转换,以及在多线程环境下正确管理speex的上下文。此外,为了优化性能,可能需要将大块数据分块处理,避免一次性加载大量数据导致内存压力。 总结来说,JNI编程在Android...
1. 基本类型:JNI支持Java的基本数据类型,如`jboolean`, `jbyte`, `jchar`, `jshort`, `jint`, `jlong`, `jfloat`, `jdouble`等,它们分别对应Java的boolean, byte, char, short, int, long, float, double。...