安卓获取某apk的签名信息,可用作防盗版进入。

本文介绍了如何在项目中获取并验证apk签名,包括获取已安装apk的签名信息,使用MD5算法验证签名,以及获取非系统预装的app信息。通过遍历已安装的apk,比较签名一致性,确保软件的正版性和安全性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    

              一般项目中有防盗版的需求,必须是正版软件才能使用,这就需要获取当前安装包的签名信息和提前规定的签名,Md5值做验证,或者发布时候要检验apk签名信息以防止发错包,造成不必要的损失。


    获取签名信息,通过遍历已安装的apk 获得安装过的对应apk是否与已知apk签名一致

,包名你也可以指定任意已安装过的apk,可以获取第三方apk的签名哦


[java]  view plain copy
  1. /** 
  2.      * 获取签名信息 
  3.      *  
  4.      * @param aContext 
  5.      *            Context 
  6.      * @return 签名String 
  7.      */  
  8.     @SuppressWarnings("unused")  
  9.     private byte[] getSign(String mPakgeName) {  
  10.   
  11.         List<PackageInfo> apps = pManager.getInstalledPackages(PackageManager.GET_SIGNATURES);  
  12.   
  13.         Iterator<PackageInfo> iter = apps.iterator();  
  14.   
  15.         PackageInfo info;  
  16.         while (iter.hasNext()) {  
  17.             info = iter.next();  
  18.               
  19.             if (TextUtils.equals(info.packageName, mPakgeName)) {  
  20.                 if (info.signatures.length > 0) {  
  21.                     return info.signatures[0].toCharsString().getBytes();  
  22.                 }  
  23.             }  
  24.         }  
  25.         return null;  
  26.     }  

 2   得到字节后 ,需要转化出成md5


[java]  view plain copy
  1.  /** 得到签名. 
  2.  * @param mPakgeName 
  3.  * @return 
  4.  */  
  5. private String  getgetSignMd5(String mPakgeName) {  
  6.         byte[] signatture = getSign(mPakgeName);  
  7.           
  8.         if (signatture == null) {  
  9.             return null;  
  10.         }  
  11.   
  12.         if (TextUtils.isEmpty(signatture.toString()))  {  
  13.            return null;  
  14.         }  
  15.           
  16.         try {  
  17.             digest = MessageDigest.getInstance("Md5");  
  18.             digest.update(signatture);  
  19.         } catch (NoSuchAlgorithmException e) {  
  20.             // TODO Auto-generated catch block  
  21.             e.printStackTrace();  
  22.         }  
  23.           
  24.         //此处为第三方应用使用的签名算法  
  25.           byte[] b = digest.digest();  
  26.           char[] HEXCHAR = {  
  27.                   //列举一个签名算法 ,此处应是你方应用自己的算法  
  28.                   '0''1''2''3''4''5''6''7''8''9',  
  29.                   'a''b''c''d''e''f'  
  30.           };  
  31.           StringBuilder sb = new StringBuilder(b.length * 2);  
  32.   
  33.           for (int i = 0; i < b.length; i++) {  
  34.               sb.append(HEXCHAR[(b[i] & 0xf0) >>> 4]);  
  35.               sb.append(HEXCHAR[(b[i] & 0x0f)]);  
  36.           }  
  37.           
  38.         return sb.toString();  
  39.  }  

  3 有时候我们需要获得非系统apk应用信息

[java]  view plain copy
  1. /** 获取非预装的app 
  2.      * @return 
  3.      */  
  4.     public static List<PackageInfo> getAllApps() {   
  5.         apps = new ArrayList<PackageInfo>();   
  6.         paklist = pManager.getInstalledPackages(0);   
  7.         for (int i = 0; i < paklist.size(); i++) {   
  8.             PackageInfo pak = (PackageInfo) paklist.get(i);   
  9.             //判断是否为非系统预装的应用程序   
  10.             if ((pak.applicationInfo.flags & pak.applicationInfo.FLAG_SYSTEM) <= 0) {   
  11.                  
  12.                 apps.add(pak);   
  13.             }   
  14.         }   
  15.         return apps;   
  16.     }  


 xml 布局很简单 因此不再多说了 不说了上图  比如获取微博的签名信息。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值