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程序设计有所帮助。