支持微信和支付宝两种主流支付的集成库, 两行代码实现微信支付, 三行代码实现支付宝支付
对应的项目中的build.gradle文件添加依赖:
dependencies {
//添加支付库
compile 'io.github.mayubao:pay_library:1.0.1'
}
<dependency>
<groupId>io.github.mayubao</groupId>
<artifactId>pay_library</artifactId>
<version>1.0.1</version>
<type>pom</type>
</dependency>
//1.创建微信支付请求
WechatPayReq wechatPayReq = new WechatPayReq.Builder()
.with(this) //activity实例
.setAppId(appid) //微信支付AppID
.setPartnerId(partnerid)//微信支付商户号
.setPrepayId(prepayid)//预支付码
// .setPackageValue(wechatPayReq.get)//"Sign=WXPay"
.setNonceStr(noncestr)
.setTimeStamp(timestamp)//时间戳
.setSign(sign)//签名
.create();
//2.发送微信支付请求
PayAPI.getInstance().sendPayRequest(wechatPayReq);
//关于微信支付的回调
//wechatPayReq.setOnWechatPayListener(new OnWechatPayListener);
注意:这里没有金额设置,金额的信息已经包含在预支付码prepayid了。
//1.创建支付宝支付配置
AliPayAPI.Config config = new AliPayAPI.Config.Builder()
.setRsaPrivate(rsa_private) //设置私钥 (商户私钥,pkcs8格式)
.setRsaPublic(rsa_public)//设置公钥(// 支付宝公钥)
.setPartner(partner) //设置商户
.setSeller(seller) //设置商户收款账号
.create();
//2.创建支付宝支付请求
AliPayReq aliPayReq = new AliPayReq.Builder()
.with(activity)//Activity实例
.apply(config)//支付宝支付通用配置
.setOutTradeNo(outTradeNo)//设置唯一订单号
.setPrice(price)//设置订单价格
.setSubject(orderSubject)//设置订单标题
.setBody(orderBody)//设置订单内容 订单详情
.setCallbackUrl(callbackUrl)//设置回调地址
.create()//
.setOnAliPayListener(null);//
//3.发送支付宝支付请求
PayAPI.getInstance().sendPayRequest(aliPayReq);
//关于支付宝支付的回调
//aliPayReq.setOnAliPayListener(new OnAliPayListener);
//1.创建支付宝支付订单的信息
String rawAliOrderInfo = new AliPayReq2.AliOrderInfo()
.setPartner(partner) //商户PID || 签约合作者身份ID
.setSeller(seller) // 商户收款账号 || 签约卖家支付宝账号
.setOutTradeNo(outTradeNo) //设置唯一订单号
.setSubject(orderSubject) //设置订单标题
.setBody(orderBody) //设置订单内容
.setPrice(price) //设置订单价格
.setCallbackUrl(callbackUrl) //设置回调链接
.createOrderInfo(); //创建支付宝支付订单信息
//2.签名 支付宝支付订单的信息 ===>>> 商户私钥签名之后的订单信息
//TODO 这里需要从服务器获取用商户私钥签名之后的订单信息
String signAliOrderInfo = getSignAliOrderInfoFromServer(rawAliOrderInfo);
//3.发送支付宝支付请求
AliPayReq2 aliPayReq = new AliPayReq2.Builder()
.with(activity)//Activity实例
.setRawAliPayOrderInfo(rawAliOrderInfo)//支付宝支付订单信息
.setSignedAliPayOrderInfo(signAliOrderInfo) //设置 商户私钥RSA加密后的支付宝支付订单信息
.create()//
.setOnAliPayListener(null);//
PayAPI.getInstance().sendPayRequest(aliPayReq);
//关于支付宝支付的回调
//aliPayReq.setOnAliPayListener(new OnAliPayListener);
之前微信支付是可以支付的,但是存在一个问题,就是微信支付回调的问题,我一直在寻找不同于官方的那样的回调方法,但是还是没有找到,只能想微信支付妥协~如果你想要微信支付的回调,还是可以实现的,只是做法跟微信支付官方文档一样。
解决方案:
1.在你的项目的包名下面新建wxapi包,
2.新建一个WXPayEntryActivity类,
3.实现IWXAPIEventHandler接口
4.在你对应的地方注册接收微信支付的广播即可
注意:
1.下面的是示例代码中的APP_ID需要替换为自己的
2.下面的是示例代码中的WeChatPayReceiver需要自己定义
下面是示例代码:
import android.app.Activity;
import android.app.AlertDialog;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.widget.Toast;
import com.tencent.mm.sdk.constants.ConstantsAPI;
import com.tencent.mm.sdk.modelbase.BaseReq;
import com.tencent.mm.sdk.modelbase.BaseResp;
import com.tencent.mm.sdk.openapi.IWXAPI;
import com.tencent.mm.sdk.openapi.IWXAPIEventHandler;
import com.tencent.mm.sdk.openapi.WXAPIFactory;
public class WXPayEntryActivity extends Activity implements IWXAPIEventHandler{
private static final String TAG = "MicroMsg.SDKSample.WXPayEntryActivity";
private IWXAPI api;
//TODO 这里需要替换你的APP_ID
private String APP_ID = "wx0xxxxxxxxx"; //这里需要替换你的APP_ID
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// setContentView(R.layout.pay_result);
api = WXAPIFactory.createWXAPI(this, APP_ID);
api.handleIntent(getIntent(), this);
}
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
setIntent(intent);
api.handleIntent(intent, this);
}
@Override
public void onReq(BaseReq req) {
}
@Override
public void onResp(BaseResp resp) {
Log.d(TAG, "onPayFinish, errCode = " + resp.errCode);
if (resp.getType() == ConstantsAPI.COMMAND_PAY_BY_WX) {
// AlertDialog.Builder builder = new AlertDialog.Builder(this);
// builder.setTitle(R.string.app_tip);
// builder.setMessage(getString(R.string.pay_result_callback_msg, String.valueOf(resp.errCode)));
// builder.show();
//以下是自定义微信支付广播的发送,微信支付广播请自己定义
Intent intent = new Intent();
intent.setAction(WeChatPayReceiver.ACTION_PAY_RESULT);
intent.putExtra("result", resp.errCode);
sendBroadcast(intent);
finish();
}
}
}
#pay_library
-dontwarn io.github.mayubao.pay_library.**
-keep class io.github.mayubao.pay_library.** {*;}
#wechat pay
-dontwarn com.tencent.**
-keep class com.tencent.** {*;}
#alipay
-dontwarn com.alipay.**
-keep class com.alipay.** {*;}
-dontwarn com.ta.utdid2.**
-keep class com.ta.utdid2.** {*;}
-dontwarn com.ut.device.**
-keep class com.ut.device.** {*;}
-dontwarn org.json.alipay.**
-keep class corg.json.alipay.** {*;}
https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=8_5
-
微信支付必须要在正式签名和正确包名的应用中才能成功调起。(**重点)
即商户在微信开放平台申请开发应用后对应包名和对应签名的应用才能成功调起。 详情请参考微信支付的开发流程文档。
https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=8_5
-
微信支付API没有在客户端显示的设置回调,回调是在Server端设置的。(与支付宝支付的区别,支付宝的回调是在客户端设置的)
-
支付宝支付为了保证交易双方的身份和数据安全, 需要配置双方密钥。
详情请参考支付宝支付的密钥处理体系文档。
如果你觉得此项目对你有用,能否赏我一杯咖啡呢?
Copyright 2017 mayubao
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.