获取app应用的公钥

获取app应用的公钥

1、获取方法,代码如下:

private byte[] getSign(Context context) {
	        PackageManager pm = context.getPackageManager();
	        List<PackageInfo> apps = pm
	                .getInstalledPackages(PackageManager.GET_SIGNATURES);
	        Iterator<PackageInfo> iter = apps.iterator();
	        Log.i("签名1", iter+"");
	        Log.i("监听1","----------");
	        while (iter.hasNext()) {
	            PackageInfo info = iter.next();
	            String packageName = info.packageName;
	            //按包名 取签名
	            if (packageName.equals("com.example.babycare")) {
	            	Log.i("监听1",info.signatures[0].toByteArray()+"----------");
	                return info.signatures[0].toByteArray();
	                 
	            } 
	        }
	        
	        return null;
	    }
		
		public static String getPublicKey(byte[] signature) {
	        try {
	 
	            CertificateFactory certFactory = CertificateFactory
	                    .getInstance("X.509");
	            X509Certificate cert = (X509Certificate) certFactory
	                    .generateCertificate(new ByteArrayInputStream(signature));
	            Log.i("监听2", "22");
	            String publickey = cert.getPublicKey().toString();
	            Log.d("-------密码TRACK", publickey);
	           // publickey = publickey.substring(publickey.indexOf("modulus:") + 9,publickey.indexOf("\n", publickey.indexOf("modulus:")));
	 
	            Log.d("-------密码TRACK", publickey);
	            return publickey;
	        } catch (CertificateException e) {
	            e.printStackTrace();
	        }
	        return null;
	    }

2.在oncreate()中调用getPublicKey(this.getSign(getApplicationContext()));

3.即可在日志中查看公钥:

### 支付宝 App 公钥与私钥的生成、配置及使用说明 #### 一、公钥和私钥的作用 在支付宝集成过程中,为了保障交易的安全性和数据传输的真实性,采用非对称加密算法(如 RSA 或者 RSA2),其中涉及到一对密钥:公钥和私钥。应用私钥用于对请求内容进行签名;而支付宝公钥则用来验证来自支付宝服务器响应消息的真实有效性。 #### 二、获取AppId及相关密钥 对于想要接入支付宝服务的应用来说,在开始之前需要先注册成为开发者并创建相应的应用程序来获得唯一的标识符即APPID。之后通过访问开放平台页面下的【密钥管理】选项卡找到对应的【开放平台密钥】部分即可看到所拥有的APPID以及其他必要的安全凭证信息[^2]。 #### 三、生成RSA/RSA2类型的密钥对 当进入沙箱环境后,可以通过如下路径完成自定义密钥设置操作:依次点击“沙箱应用”,接着选择“网页&移动应用”,最后到达“自定义密钥”。在这里可以选择适合版本的加密标准(推荐使用更安全强度更高的RSA2),系统将会自动为你生成一组新的密钥对供后续开发测试阶段调用[^3]。 #### 四、配置公钥证书方式的具体步骤 按照官方文档指导,如果打算采取基于公钥证书的方式来进行身份认证,则除了常规意义上的四个要素外还需要额外准备两个文件——应用自身的公钥证书以及支付宝提供的根CA证书。具体而言: - 将上述提到的所有必要组件妥善保存至项目工程内部合适位置; - 修改源码里涉及网络通信逻辑的地方使之能够正确加载本地存储好的这些资源,并确保每次发起API调用前都已成功附加了必需的身份证明材料(app_cert_sn, alipay_root_cert_sn),因为默认情况下PHP SDK并不支持此特性所以可能要自行调整相关类库实现[^1]。 ```php // 示例代码片段展示如何向请求头添加所需参数 $params['app_cert_sn'] = 'your_app_certificate_serial_number'; $params['alipay_root_cert_sn'] = 'root_ca_certificate_serial_number'; // 假设这是执行远程HTTP POST请求函数的一部分... $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $gatewayUrl); curl_setopt($ch, CURLOPT_POST, true); curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($params)); ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值