Android编程之防止反编译的实现方法
本文实例讲述了Android编程之防止反编译的实现方法。分享给大家供大家参考,具体如下:
1.判断程序是否运行在模拟器上
booleanisRunningInEmualtor(){ booleanqemuKernel=false; Processprocess=null; DataOutputStreamos=null; try{ process=Runtime.getRuntime().exec("getpropro.kernel.qemu"); os=newDataOutputStream(process.getOutputStream()); BufferedReaderin=newBufferedReader(newInputStreamReader(process.getInputStream(),"GBK")); os.writeBytes("exit\n"); os.flush(); process.waitFor(); //getpropro.kernel.qemu==1在模拟器 //getpropro.product.model=="sdk"在模拟器 //getpropro.build.tags=="test-keys"在模拟器 qemuKernel=(Integer.valueOf(in.readLine())==1); Log.d("com.droider.checkqemu","检测到模拟器:"+qemuKernel); }catch(Exceptione){ qemuKernel=false; Log.d("com.droider.checkqemu","runfailed"+e.getMessage()); }finally{ try{ if(os!=null){ os.close(); } process.destroy(); }catch(Exceptione){ } Log.d("com.droider.checkqemu","runfinally"); } returnqemuKernel; }
2.检测keystore签名,再与之前得做比较
publicintgetSignature(StringpackageName){ PackageManagerpm=this.getPackageManager(); PackageInfopi=null; intsig=0; try{ pi=pm.getPackageInfo(packageName,PackageManager.GET_SIGNATURES); Signature[]s=pi.signatures; sig=s[0].hashCode(); }catch(Exceptione1){ sig=0; e1.printStackTrace(); } returnsig; }
3.检测包名,版本名和版本号,然后做判断:
privateStringgetAppInfo(){ try{ StringpkName=this.getPackageName(); StringversionName=this.getPackageManager().getPackageInfo( pkName,0).versionName; intversionCode=this.getPackageManager() .getPackageInfo(pkName,0).versionCode; returnpkName+""+versionName+""+versionCode; }catch(Exceptione){ } returnnull; }
4.把jpg图片写成是png格式得图片 但是最新版本的apktool已经修复了
5.花指令,影响jd-gui 但是最新版本的jd-gui已经修复
privatestaticfinalchar[]wJ="0123456789abcdef".toCharArray(); publicstaticStringimsi="204046330839890"; publicstaticStringp="0"; publicstaticStringkeyword="电话"; publicstaticStringtranlateKeyword="%E7%94%B5%E8%AF%9D";
在每个类里面加入如上字段。。。。
https://***/ 一个第三方得”爱加密“网站 1.需要使用官方的打包key工具打包后上传到"爱加密"网站进行处理,然后到网站上面下载,下载后还要用"爱加密"的打包工具再次进行打包即可。
希望本文所述对大家Android程序设计有所帮助。