本文主要讲述一下 android 接入微信支付 SDK 的步骤以及需要注意的一些 Tips。
前期准备
接入微信支付 SDK 前期需要许多前期准备。
微信开放平台登录账号,进入管理中心,创建你的 App 应用,创建应用的包名与签名要与你实际的应用一致。
进入应用详情,获取AppID,以及申请开通微信支付能力。
等待审核通过。
微信商户平台登录账号,在基本信息中获得微信支付商户号。
安装操作证书,然后进入 API 安全设置秘钥,最好使用 UUID 自动生成的,记住这个秘钥。
OK,前期准备做完,下面进行代码接入。
工程接入 SDK
新建应用工程
以 AS 为例,新建工程,注意包名与使用的签名要与微信开放平台申请应用时填写的一致。
引入 libs
将libammsdk.jar放到 libs 文件夹下。
配置 debug、release 的签名文件1
signingConfigs {
debug {
storeFile file("你的keystore路径")
storePassword "xxx"
keyAlias "xxx"
keyPassword "xxx"
}
release {
storeFile file("你的keystore路径")
storePassword "xxx"
keyAlias "xxx"
keyPassword "xxx"
}
}
这里 debug、realse 我采用的是一样的签名。不论是 debug,还是 release 都能对应上。
AndroidManifest.xml 中配置1
也别忘记加入网络权限。
获取 prepay_id
支付
获取到 prepay_id 之后,调用IWXAPI的sendReq方法即可完成支付。
添加支付成功回调 Activity
添加wxapi的包名,在这个包名下必须要有WXPayEntryActivity这个 Activity,支付成功后会显示此界面。
另外,声明此 Activity 需要添加如下属性:1
android:name=".wxapi.WXPayEntryActivity"
android:exported="true"
android:launchMode="singleTop" />
调用接口相关参数以及返回值参考开发者手册。
Tips
下面说一下接入过程中需要注意的点。
官网下的 demo,第一次支付时,能成功。之后就会一直支付失败。原因是:支付的时候商户唯一订单 ID 是唯一的,测试的时候请不断的更换订单 ID 参数支付。若要继续使用 demo 支付,可以微信清除数据、或者退出登录重新登录。
微信支付返回-1,一般是签名错误。这个签名有 2 种意思:1、Apk 签名文件,debug 与 release 最好使用同样的 keystore;2、参数 MD5 签名生成的 sign。要仔细检查是否正确。
签名、包名必须跟微信开放平台申请的一致.
获取 prepay_id 最好是在服务器完成,由服务器去跟微信服务器交互,客户端不需要参与,以免泄露重要信息。
与微信接口交互时,参数都需要签名。签名方法如下图:
这里重点说一下。参数名 ASCII 码从小到大排序(字典序)
参数名区分大小写,包括 sign。
需要添加商户 key 值,这个 key 即是在前期准备中,我所说的微信商户的那个秘钥。
若接入过程中注意到这些 Tips,一步一步来,那么应该是能支付成功了。