前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >一个key玩转第三方服务(微信支付、某某地图)

一个key玩转第三方服务(微信支付、某某地图)

作者头像
贺biubiu
发布2019-06-10 22:53:15
5040
发布2019-06-10 22:53:15
举报
文章被收录于专栏:HLQ_StruggleHLQ_Struggle

你不一定要点蓝字关注我的

LZ-Says:时过境迁,一切皆枉然~~~

写此文原因

之前LZ写项目的时候,多少都会使用一些第三方,主要为地图相关,无论从百度地图还是高德地图来讲,都需要一个SHA1+包名去配置key,而这个key,就是使用地图的关键因素。

昨天和小伙伴聊天,发现他们使用了一种比较nice的方案,觉得很不错,再次实验了下,顺便再次放出这家伙的博客地址链接,有兴趣可点击自行查看学习~

点我查看 〤twinkle╰ つ青春 博客地址

修改证书,来个瞒天过海

第一步:复制正式证书

这一步我们要做的就是将正式的证书单独复制出来,而这份复制出来的证书,则是我们下面要漫天过海的关键实践者。

第二步:修改复制后证书密钥口令

修改密码命令如下:

代码语言:javascript
复制
keytool -storepasswd -keystore 复制出来证书地址

如下图所示:

代码语言:javascript
复制
系统会要求你输入原有的密钥口令,新密钥口令以及确认新密钥口令。

这一步,需要切记:新密钥口令务必为(android)

第三步:修改复制后证书Alias

修改Alias的命令如下:

代码语言:javascript
复制
keytool -changealias -keystore 复制后的证书地址 
-alias 之前证书设置的Alias -destalias androiddebugkey

操作如下图所示:

而这里,系统会要求你输入俩个值:

  • 密钥口令 - 1: android,也就是我们之前设置的值;
  • 密钥口令 - 2: 之前的密钥口令

第四步:修改复制后证书密码

操作命令如下:

代码语言:javascript
复制
keytool -keypasswd -keystore 复制后证书地址 -alias androiddebugkey

而这一步比较繁琐,系统会核验当前的密钥口令以及之前的密钥口令,之后,才是输入密钥口令以及确认密钥口令,详情见下图:

第五步:查看正式证书以及经过改造证书SHA1值

查看证书SHA1命令如下:

代码语言:javascript
复制
keytool -list -v -keystore 证书地址

俩次结果为:

代码语言:javascript
复制
AC:XXXXXX:70
AC:XXXXXX:70

中间关键信息暂时屏蔽,可以看到,这俩个证书使用的SHA1一直,区别在于一个为测试时专用,一个为正式打包使用。

到此,大家会不会有种很nice的想法么???是不是又get了新技能???

额外拓展

最近在看腾讯的bugly,学到了一个比较nice的东西,正好本文相匹配,一块写出来了~

第一步:首先在app下创建keystore目录,并将正式证书以及测试证书拷贝进去。

第二步:build文件设置签名配置

代码语言:javascript
复制
   // 签名配置
    signingConfigs {
        release {
            try {
                storeFile file("./keystore/正式证书.jks")
                storePassword "密钥口令"
                keyAlias "设置的keyAlias"
                keyPassword "密钥口令"
            } catch (ex) {
                throw new InvalidUserDataException(ex.toString())
            }
        }
        debug {
            storeFile file("./keystore/测试证书.jks")
        }
    }
    buildTypes {
        release { 
            minifyEnabled false // 关闭混淆
            signingConfig signingConfigs.release
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
        debug {
            debuggable true // 开启调试
            minifyEnabled false // 关闭混淆
            signingConfig signingConfigs.debug
        }
    }

嘿嘿嘿,小思路

有的小伙伴说了,真TMD麻烦,有没有简单的?

这个必须有啊~

代码语言:javascript
复制
signingConfigs {
        debug {
            storeFile file('正式证书地址.jks')
            storePassword 'storePassword'
            keyPassword 'keyPassword'
            keyAlias 'keyAlias'
        }
        release {
            storeFile file('正式证书地址.jks')
            storePassword 'storePassword'
            keyPassword 'keyPassword'
            keyAlias 'keyAlias'
        }
    }

秒懂???测试的时候指定使用正式证书~所以???嘿嘿嘿

文末结束

啦啦啦,本文到此结束,希望大家和LZ一样有所收获~

欢迎更多的小伙伴分享自己的经验,让更多人Android开发的小伙伴提升开发B格~~~

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-03-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 贺biubiu 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档