public void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        Button btn = new Button(this);
        btn.setText("测试ndk");
        btn.setOnClickListener(new ButtonOnClickListener());
        setContentView(btn);
        Toast.makeText(getApplicationContext(), PATH, Toast.LENGTH_LONG).show();
    }
    
    public final class ButtonOnClickListener implements OnClickListener{
     
  @Override
  public void onClick(View arg0) {
   // TODO Auto-generated method stub
   byte[] data = "zhanghongliu".getBytes();
   FileInputStream fis = null;
   FileOutputStream fos = null;
   int i = 0;
         for(i=1;i<=200000;i++){
    try {
     fis = new FileInputStream(RESOURCEPATH);
     int size = fis.available();
     data = new byte[size];
     fis.read(data, 0, size);
     String result = FileJNILib.videoCrypt(data,ENCRYPTPATH);
     Toast.makeText(getApplicationContext(), result, Toast.LENGTH_LONG).show();
     
           data = FileJNILib.videoDerypt(ENCRYPTPATH);
           fos = new FileOutputStream(DECRYPTPATH);
           fos.write(data);
    } catch (FileNotFoundException e) {
     // TODO Auto-generated catch block
     e.printStackTrace();
    } catch (IOException e) {
     // TODO Auto-generated catch block
     e.printStackTrace();
    }finally{
     try {
      if(null != fis){
       fis.close();
      }
      if(null != fos){
       fos.close();
      }
      data = null;
     } catch (IOException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
     }
    }
          Log.i("count", i+"");
          //data = null;
         }
         //Toast.makeText(getApplicationContext(), new String(data), Toast.LENGTH_LONG).show();
      //show();
  }
  
  public void show(){
   File newfile = new File(PATH);
         FileInputStream inStream = null;
   try {
    inStream = new FileInputStream(newfile);
   } catch (FileNotFoundException e) {
    // TODO Auto-generated catch block
    //e.printStackTrace();
   }
         String content = FileUtil.readInStream(inStream);
         Log.i("FileText", content);
         Toast.makeText(getApplicationContext(), content, Toast.LENGTH_LONG).show();
  }
     
    }

public static String readInStream(FileInputStream inStream){
  try {
   ByteArrayOutputStream outStream = new ByteArrayOutputStream();
   byte[] buffer = new byte[1024];
   int length = -1;
   while((length = inStream.read(buffer)) != -1 ){
    outStream.write(buffer, 0, length);
   }
   outStream.close();
   inStream.close();
   return outStream.toString();
  } catch (IOException e) {
   Log.i(TAG, e.getMessage());
  }
  return null;
 }

public class FileJNILib {
 
 static {
        System.loadLibrary("filejni");
    }
    public static native String videoCrypt(byte[] content, String dest_file);
    public static native byte[] videoDerypt(String dest_file);

public static native String videoDerypt(String dest_file, ByteArrayOutputStream outputstream);
    
}

/* DO NOT EDIT THIS FILE - it is machine generated */
#include <stdio.h>

#include <stdlib.h>

#include <string.h>

#include <sys/stat.h>

#include <jni.h> //jni的主要头文件

#include <android/log.h>
#define LOG_TAG "JNI"
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO, LOG_TAG, __VA_ARGS__)
/* Header for class com_test_jni_FileJNILib */

/*
 * Class:     com_test_jni_FileJNILib
 * Method:    videoCrypt
 * Signature: ([BLjava/lang/String;)V
 */
JNIEXPORT jstring JNICALL videoCrypt
  (JNIEnv * env, jclass thiz, jbyteArray content, jstring dest_file){
  //env->GetStringUTFChars(source,NULL);

const char *path = (*env)->GetStringUTFChars(env, dest_file, NULL);
  LOGI(path);

FILE *fp = fopen(path,"wb");
  if(fp==NULL){
   LOGI("fopen error");
   (*env)->ReleaseStringUTFChars(env,dest_file, path);
   return (*env)->NewStringUTF(env, "fopen error");
  }
  char *data = (*env)->GetByteArrayElements(env,content, 0);
  int size = (*env)->GetArrayLength(env,content);
  //int iLen = sizeof(data);//C语言中判断数据类型或者表达式长度符
  LOGI("file size is %d", size);

crypt(data,size);

/******文件写入方法***********/
  //fputc('c',fp);
  //fputs(data,fp);
  fwrite(data,size,1,fp);
  //fprintf(fp,"%s",data);
  /*****************/

fclose(fp);
  (*env)->ReleaseByteArrayElements(env,content,data,0);
  (*env)->ReleaseStringUTFChars(env,dest_file, path);
  LOGI("execute complete");
  return (*env)->NewStringUTF(env, "encrypt successful");
}

/*
 * Class:     com_test_jni_FileJNILib
 * Method:    videoDerypt
 * Signature: (Ljava/lang/String;)[B
 */
JNIEXPORT jbyteArray JNICALL videoDerypt
  (JNIEnv * env, jclass thiz, jstring dest_file){
   const char *path = (*env)->GetStringUTFChars(env, dest_file, NULL);
   LOGI(path);

/*****得到文件长度*******/
   int size;
   struct stat  tFileStat;
   if( stat(path, &tFileStat ) )
   {
    LOGI("file not found error");
    (*env)->ReleaseStringUTFChars(env,dest_file, path);
    return NULL;
   }
   size=tFileStat.st_size;
   LOGI("file size is %d",size);//报错 int
   /************/

/*****分配内存*******/
   char *temp = NULL;
   temp=(char*)malloc(size);
   if(temp == NULL)
   {
    LOGI("malloc error");
    (*env)->ReleaseStringUTFChars(env,dest_file, path);
    return NULL;
   }
   // memset(temp,0x00,size*sizeof(char)+1);//初始化内存
   /************/

FILE *fp = fopen(path,"rb");
   if(fp==NULL){
    LOGI("fopen error");
    (*env)->ReleaseStringUTFChars(env,dest_file, path);
    free(temp);//释放内存
    temp=NULL;
    return NULL;
   }

/******文件读方法***********/
   //fgetc(fp);
   //fgets(temp,100,fp);
   fread(temp,size,1,fp);
   //fscanf(fp,"%s",temp);
   /*****************/

fclose(fp);

crypt(temp,size);

jbyteArray jarrRV =(*env)->NewByteArray(env,size);
   jbyte *jby =(*env)->GetByteArrayElements(env,jarrRV, 0);
   memcpy(jby, temp, size);//复制数据
   (*env)->SetByteArrayRegion(env,jarrRV, 0,size, jby);//将Jbyte 转换为jbarray数组
   (*env)->ReleaseByteArrayElements(env,jarrRV,jby,0);//释放jby数组* 解决长时间运行退出问题 内部引用超过指定数量
   //(*env)->DeleteLocalRef(env,jarrRV);//影响程序
   //(*env)->DeleteLocalRef(env,temp);//不对  一般用malloc申请内存,free释放
   free(temp);
   temp=NULL;
   (*env)->ReleaseStringUTFChars(env,dest_file, path);
   LOGI("execute complete");
   return jarrRV;
}

void crypt(char *data, int size){
 int i;
 char sPwd[]="************************";
    int pwdLen = sizeof(sPwd);
    //LOGI("dongao.com mobile_encrypt %d",pwdLen);
 int count=0;
 for(i=0; i<size; i++)
 {
            if(count >= pwdLen) count = 0;
   data[i]=data[i]^sPwd[count++];
   //LOGI("%c",sPwd[count >= 10 ?count=0:count++]);
 }
}

/*
 * Class:     com_test_jni_FileJNILib
 * Method:    videoDerypt
 * Signature: (Ljava/lang/String;Ljava/io/ByteArrayOutputStream;)V
 */
JNIEXPORT jstring JNICALL videoDerypt2ByteArray
  (JNIEnv * env, jclass thiz, jstring dest_file, jobject outputstream){
 return NULL;
}

static const JNINativeMethod gMethods[] = { //定义批量注册的数组,是注册的关键部分
{"videoCrypt", "([BLjava/lang/String;)Ljava/lang/String;", (void*)videoCrypt} ,// func2是在java中声明的native函数名,"()V"是函数的签名,可以通过javah获取。
{"videoDerypt", "(Ljava/lang/String;)[B", (void*)videoDerypt},
{"videoDerypt", "(Ljava/lang/String;Ljava/io/ByteArrayOutputStream;)Ljava/lang/String;", (void*)videoDerypt2ByteArray}
};

JNIEXPORT jint JNI_OnLoad(JavaVM* vm, void *reserved) //这是JNI_OnLoad的声明,必须按照这样的方式声明

{

JNIEnv* env = NULL; //注册时在JNIEnv中实现的,所以必须首先获取它

jint result = -1;

if((*vm)->GetEnv(vm, (void**)&env, JNI_VERSION_1_4) != JNI_OK) //从JavaVM获取JNIEnv,一般使用1.4的版本

return -1;

jclass clazz;

static const char* const kClassName="com/test/jni/FileJNILib";

clazz = (*env)->FindClass(env, kClassName); //这里可以找到要注册的类,前提是这个类已经加载到java虚拟机中。 这里说明,动态库和有native方法的类之间,没有任何对应关系。

if(clazz == NULL)

{

LOGI("cannot get class:%s\n", kClassName);

return -1;

}

if((*env)->RegisterNatives(env, clazz,gMethods, sizeof(gMethods)/sizeof(gMethods[0]))!= JNI_OK) //这里就是关键了,把本地函数和一个java类方法关联起来。不管之前是否关联过,一律把之前的替换掉!

{

LOGI("register native method failed!\n");

return -1;

}

return JNI_VERSION_1_4; //这里很重要,必须返回版本,否则加载会失败。

}

原文 http://blog.csdn.net/zhanghongliu1122/article/details/9411921

Android(Java):jni源代码的更多相关文章

  1. 一、Android NDK编程预备之Java jni简介

    转自:  http://www.eoeandroid.com/thread-264384-1-1.html 游戏开发 视频教程 博客 淘帖     论坛›eoe·Android应用开发区›Androi ...

  2. Android使用JNI(从java调用本地函数)

    当编写一个混合有本地C代码和Java的应用程序时,需要使用Java本地接口(JNI)作为连接桥梁.JNI作为一个软件层和API,允许使用本地代码调用Java对象的方法,同时也允许在Java方法中调用本 ...

  3. Android系统进程间通信Binder机制在应用程序框架层的Java接口源代码分析

    文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6642463 在前面几篇文章中,我们详细介绍了A ...

  4. Android For JNI(一)——JNI的概念以及C语言开发工具dev-c++,编写你的第一个C语言程序,使用C启动JAVA程序

    Android For JNI(一)--JNI的概念以及C语言开发工具dev-c++,编写你的第一个C语言程序 当你的Android之旅一步步的深入的时候,你其实会发现,很多东西都必须去和framew ...

  5. 三、Android NDK编程预备之Java jni入门创建C/C++共享库

    转自: http://www.eoeandroid.com/thread-264971-1-1.html 应网友回复,答应在两天前要出一篇创建C/C++共享库的,但由于清明节假期,跟朋友出去游玩,丢手 ...

  6. 二、Android NDK编程预备之Java jni入门Hello World

    转自:  http://www.eoeandroid.com/forum.php?mod=viewthread&tid=264543&fromuid=588695 昨天已经简要介绍了J ...

  7. [Android Webkit]JNI基础及Java层与C++层的交互

    1. JNI 注册 1.1. JNI的基础结构       JAVA == JNI == Native Code      JNI(Java Native Interface)是Java与Native ...

  8. Android与JNI(二) ---- Java调用C++ 动态调用

    目录: 1. 简介 2. JNI 组件的入口函数 3. 使用 registerNativeMethods 方法 4. 测试 5. JNI 帮助方法 6. 参考资料 1. 简介 Android与JNI( ...

  9. [Android]-图片JNI(C++\Java)高斯模糊的实现与比較

    版权声明:本文作者:Qiujuer https://github.com/qiujuer; 转载请注明出处,盗版必究! !! https://blog.csdn.net/qiujuer/article ...

随机推荐

  1. TreeView Class Key Points

    TreeView keep selected node highlighted public QualityCheck() { InitializeComponent(); //trvIndexNam ...

  2. Java制作证书的工具keytool用法总结

    一.keytool的概念 keytool 是个密钥和证书管理工具.它使用户能够管理自己的公钥/私钥对及相关证书,用于(通过数字签名)自我认证(用户向别的用户/服务认证自己)或数据完整性以及认证服务.在 ...

  3. [整理]SSRS error:rsReportNotReady

    直接访问http://XXX/ReportServer/Pages/ReportViewer.aspx?reportpath&rs%3aCommand=Render执行查询是没有问题的. 但是 ...

  4. 使用 Entity Framework

    ORM 和 EF 当我们要开发一个应用程序,就要考虑怎样展示数据,怎样持久化数据.考虑这个问题时我们所要关心的东西,最重要的莫过于程序的性能.开发的简易性和代码的可维护.可扩展性. 持久化(Persi ...

  5. C++学习——类的继承

    公有继承(public).私有继承(private).保护继承(protected)是常用的三种继承方式. 1. 公有继承(public) 公有继承的特点是基类的公有成员和保护成员作为派生类的成员时, ...

  6. attribute和property兼容性分析

    上一篇文章中,详细的分析了他们的区别,请看Javascript中的attribute和property分析 这次,来详细的看下他们的兼容性,这些内容主要来自于对于jQuery(1.9.x)源代码的分析 ...

  7. IE 11 无法访问某些不兼容性视图的解决方法

    今天下午部署公司的项目时,用IE 11只能加载到JSP页面的静态元素,其中下拉文本框的信息获取不到, 后来,发现是IE 11不兼容的原因,于是,在菜单条“工具”——“兼容性视图设置”,将不兼容页面的网 ...

  8. C# 调用C++ DLL 的类型转换

    //C#调用C++的DLL搜集整理的所有数据类型转换方式,可能会有重复或者多种方案,自己多测试 //c++:HANDLE(void *) ---- c#:System.IntPtr //c++:Byt ...

  9. Ocelot中文文档-负载均衡

    Ocelot能通过可用的下游服务对每个ReRoute进行负载平衡. 这意味着您可以扩展您的下游服务,并且Ocelot可以有效地使用它们. 可用的负载均衡器的类型是: LeastConnection - ...

  10. spring启动component-scan类扫描加载过程(转)

    文章转自 http://www.it165.net/pro/html/201406/15205.html 有朋友最近问到了 spring 加载类的过程,尤其是基于 annotation 注解的加载过程 ...