项目中部分功能点需要用到支付功能,移动端主要集成支付宝支付和微信支付

支付宝sdk以及demo下载地址:https://doc.open.alipay.com/doc2/detail.htm?spm=a219a.7629140.0.0.JuZcSc&treeId=54&articleId=104509&docType=1

微信sdk以及demo下载地址:https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=8_1

支付宝支付最简单,而且文档,demo都有利于开发者阅读

微信支付集成和demo是最烂的

微信支付和支付宝支付封装基类,封装支付宝相关回调,和支付调用操作,以及微信调用操作:

import android.annotation.TargetApi;
import android.app.Dialog;
import android.content.res.Resources;
import android.os.Build;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.text.TextUtils;
import android.view.View;
import android.view.View.OnClickListener;
import com.alipay.sdk.app.PayTask;
import com.utils.logger.util.Logger;
import com.pay.library.alipay.PayResult;
import com.tencent.mm.sdk.modelpay.PayReq;
import com.tencent.mm.sdk.openapi.IWXAPI;
import com.tencent.mm.sdk.openapi.WXAPIFactory; @TargetApi(Build.VERSION_CODES.HONEYCOMB) public abstract class BasePayActivity
extends BaseFragmentActivity
implements OnClickListener {
private final static int DIALOG_PROGRESS = 1;
protected String TAG = "soyoungboy";
protected Resources res;
// private ProgressDialog progressDialog;
private Dialog progressDialog;
private static final int SDK_PAY_FLAG = 1;
private Handler mHandler = new Handler() {
public void handleMessage(Message msg) {
switch (msg.what) {
case SDK_PAY_FLAG: {
PayResult payResult = new PayResult((String) msg.obj);
/**
* 同步返回的结果必须放置到服务端进行验证(验证的规则请看https://doc.open.alipay.com/doc2/
* detail.htm?spm=0.0.0.0.xdvAU6&treeId=59&articleId=103665&
* docType=1) 建议商户依赖异步通知
*/
String resultInfo = payResult.getResult();// 同步返回需要验证的信息 String resultStatus = payResult.getResultStatus();
// 判断resultStatus 为“9000”则代表支付成功,具体状态码代表含义可参考接口文档
if (TextUtils.equals(resultStatus, "9000")) {
alipaySuccess(payResult);
}
else {
// 判断resultStatus 为非"9000"则代表可能支付失败
// "8000"代表支付结果因为支付渠道原因或者系统原因还在等待支付结果确认,最终交易是否成功以服务端异步通知为准(小概率状态)
if (TextUtils.equals(resultStatus, "8000")) {
alipayConfirm(payResult);
}
else {
Logger.i(payResult.toString());
// 其他值就可以判断为支付失败,包括用户主动取消支付,或者系统返回的错误
alipayFail(payResult);
}
}
break;
}
//case SDK_CHECK_FLAG: {
// Toast.makeText(PayDemoActivity.this, "检查结果为:" + msg.obj, Toast.LENGTH_SHORT).show();
// break;
//}
default:
break;
}
}
}; @Override protected void onCreate(Bundle arg0) {
super.onCreate(arg0);
} /**
* @Description: 初始化顶部TitleView
* @return:void
*/
protected abstract void initTitleView(); /**
* @Description: 初始化UI(setContentView放在initView)
* @return:void
*/
protected abstract void initView(); /**
* @Description: 点击事件
* @return:void
*/
protected abstract void click(View view); /**
* 支付宝支付
*
* @param payInfo 服务器端返回的订单信息
*/
protected void alipay(final String payInfo) {
Runnable payRunnable = new Runnable() { @Override public void run() {
// 构造PayTask 对象
PayTask alipay = new PayTask(BasePayActivity.this);
// 调用支付接口,获取支付结果
String result = alipay.pay(payInfo, true); Message msg = new Message();
msg.what = SDK_PAY_FLAG;
msg.obj = result;
mHandler.sendMessage(msg);
}
}; // 必须异步调用
Thread payThread = new Thread(payRunnable);
payThread.start();
} /**
* 支付结果确认中
* @param payResult
*/
protected abstract void alipayConfirm(PayResult payResult); /**
* 支付结果失败
* @param payResult
*/
protected abstract void alipayFail(PayResult payResult); /**
* 支付结果成功
* @param payResult
*/
protected abstract void alipaySuccess(PayResult payResult); /**
* 微信支付
* https://pay.weixin.qq.com/wiki/doc/api/app.php?chapter=9_12&index=2
*
* @param appid 微信分配的公众账号ID
* @param partnerid 微信支付分配的商户号
* @param prepayid 微信返回的支付交易会话ID
* @param noncestr 随机字符串,不长于32位。推荐随机数生成算法 https://pay.weixin.qq.com/wiki/doc/api/app.php?chapter=4_3
* @param timestamp 时间戳,请见接口规则-参数规定 https://pay.weixin.qq.com/wiki/doc/api/app.php?chapter=4_2
* @param packageX 暂填写固定值Sign=WXPay
* @param sign 签名,详见签名生成算法
* @param extData 额外的标记,未知
*/
protected void wechatPay(String appid, String partnerid, String prepayid, String noncestr, String timestamp, String packageX, String sign, String extData) {
IWXAPI api = WXAPIFactory.createWXAPI(BasePayActivity.this, appid);
PayReq req = new PayReq();
req.appId = appid;
req.partnerId = partnerid;
req.prepayId = prepayid;
req.nonceStr = noncestr;
req.timeStamp = timestamp;
req.packageValue = packageX;
req.sign = sign;
req.extData = extData;
// 在支付之前,如果应用没有注册到微信,应该先调用IWXMsg.registerApp将应用注册到微信
api.sendReq(req);
}
}

支付宝支付调用:

继承自上面这个类,代码里面如下调用:

pay_data为服务器端帮你处理后的订单信息。

String pay_data = data.getPay_data();
alipay(pay_data);

实现上面的抽象方法,即可处理支付宝成功,失败,确认中的操作来进行支付后的下一步操作。

微信支付调用:

weChatPayResult = Json.get()
.toObject(response,
WeChatPayResult.class);
WeChatPayResult.DataEntity data
= weChatPayResult.getData();
WeChatPayResult.DataEntity.PayDataEntity
pay_data = data.getPay_data();
boolean success = data.isSuccess();
if (success) {
String appid = pay_data.getAppid();
String partnerid = pay_data.getPartnerid();
String prepayid = pay_data.getPrepayid();
String noncestr = pay_data.getNoncestr();
String timestamp = pay_data.getTimestamp();
String packageX = pay_data.getPackageX();
String sign = pay_data.getSign();
String extData = "app data";
wechatPay(appid, partnerid, prepayid,
noncestr, timestamp, packageX, sign,
extData);

}

微信支付存在一个回调类WXPayEntryActivity.java,这个文件位置为(你的应用包名称+.wxapi)详情可以参考官方demo,也可以直接拿过来自己用,但是要修改为你的appid

public class WXPayEntryActivity extends Activity implements IWXAPIEventHandler {

    private static final String TAG = "MicroMsg.SDKSample.WXPayEntryActivity";

    private IWXAPI api;

    @Override public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.pay_result); api = WXAPIFactory.createWXAPI(this, "你的appid");
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) {
int errCode = resp.errCode;
Logger.i("onPayFinish, errCode = " + errCode);
if (errCode == 0) {
//0 成功 展示成功页面
ToastUtil.toasts(getApplicationContext(), "支付成功");
Intent intent = new Intent(Constant.ACTION_NAME);
sendBroadcast(intent);

finish();
}
else if (errCode == -1) {
//-1 错误 可能的原因:签名错误、未注册APPID、项目设置APPID不正确、注册的APPID与设置的不匹配、其他异常等。
ToastUtil.toasts(getApplicationContext(), "支付失败");
finish();
}
else if (errCode == -2) {
//-2 用户取消 无需处理。发生场景:用户不支付了,点击取消,返回APP。
ToastUtil.toasts(getApplicationContext(), "取消支付");
finish();
}
}
}

注意到上面的广播,是为了传给你支付的页面去进行下一步操作,记得注册和解除广播,然后在广播接受者里面进行微信支付成功下一步操作:

private BroadcastReceiver mBroadcastReceiver = new BaseBroadcastReceiver() {
@Override public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
Logger.i("action", action);
if (action.equals(Constant.ACTION_NAME)) {
if (WECHATPAY.equals(payMethod)) {
wechatPaySuccess();
}
}
}
};

还有就是为了你的微信支付不至于跳转到回调的页面而进入成功后的下一个页面,可以将回调页面设置为透明的,如下是AndroidManifest.xml中的配置:

 <!--微信支付回调界面-->
<activity
android:name=".wxapi.WXPayEntryActivity"
android:theme="@android:style/Theme.Translucent"
android:exported="true"
android:launchMode="singleTop"/>

android app 集成 支付宝支付 微信支付的更多相关文章

  1. Android App集成支付宝

    原地址:http://blog.csdn.net/wenbingoon/article/details/7933078 手机的在线支付,被认为是2012年最看好的功能,我个人认为这也是移动互联网较传统 ...

  2. 简聊iOS支付集成(支付宝和微信支付)

    一.支付集成是什么 1.现在大部分app都有快捷支付功能,支付集成将第三方支付平台集成到自己的项目中,能够完成自己项目中的支付功能, 二.支付集成的使用 <1>.支付宝: 下载SDK和De ...

  3. 关于app集成支付宝应用内支付的问题总结

    pem文件生成,将合作伙伴密钥复制到notepad++中,每45个字符回车,去除空格,头尾加上标题,文件需保存为无BOM的UTF8格式,就OK.  可以每行64个字符,共216个字符.   近来处理了 ...

  4. Android 支付宝以及微信支付快速接入流程

    简介 随着移动支付的普及,越来越多的App采用第三发支付,在这里我们以支付宝为例,做一个快速集成! 一.Android快速实现支付宝支付 1.首先,我们需要前往支付宝开放平台,申请我们的支付功能:ht ...

  5. Android开发——支付宝和微信支付快速接入流程

    一.Android快速实现支付宝支付 1.首先,我们需要前往支付宝开放平台,申请我们的支付功能:https://open.alipay.com/platform/home.htm 支付宝首页 这里 有 ...

  6. iOS app集成支付宝支付流程及后台php订单签名处理

    iOS app集成支付宝支付流程 1: 开通支付宝商户 由公司去支付宝 https://b.alipay.com/order/serviceIndex.htm 签约支付宝开通支付宝商家: 2:商户支付 ...

  7. Android学习系列(28)--App集成支付宝[已过期]

    手机的在线支付,被认为是2012年最看好的功能,我个人认为这也是移动互联网较传统互联网将会大放光彩的一个功能.人人有手机,人人携带手机,花钱买东西,不再需要取钱付现,不再需要回家上网银,想买什么,扫描 ...

  8. .net core 支付宝,微信支付 二

    源码: https://github.com/aspros-luo/Qwerty.Payment/tree/develop 今天开始微信支付 微信支付坑比较多,支付流程也不太一样,微信支付需要先生成预 ...

  9. 支付宝支付 微信支付SDK接口不统一? 盘他!

      开发过支付宝.微信支付的同学都知道,微信的支付 API 设计感觉是 Java 开发工程师写的,远不如支付宝 SDK 的接口设计用起来顺手.在这里,统一封装微信支付和支付宝支付的API,使两种支付方 ...

随机推荐

  1. Python自学笔记——Matplotlib风羽自定义

    [前言]对于气象专业的小学生来说,风场是预报重要的参考数据,我们所知的风羽有四种:短线代表风速2m/s,长线代表风速4m/s,空心三角代表风速20m/s,实心三角代表风速50m/s.而matplotl ...

  2. 他们最先开发微信小程序,为何现在又退出了?

    1.当前现状 这几天大家又被微信小程序刷屏了,"得到"退出了小程序,"今日头条"暂停了服务,各种股票交易类的小程序也在证监会的要求下纷纷暂停服务.如果大家还不知 ...

  3. SpringMVC 学习-上传文件分解器 CommonsMultipartResolver 类

    Spring 组件 CommonsMultipartResolver 类的主要作用是配置文件上传的一些属性,也可以控制上传文件的大小. 在 springmvc-servlet.xml 配置文件中: & ...

  4. 关于preg_match()函数的一点小说明

    int preg_match ( string $pattern , string $subject [, array &$matches [, int $flags = 0 [, int $ ...

  5. JavaScript(暂时弃坑...)

    简单数据类型:字符串型.布尔型.数值型 变量名可以包含数字.字母.下划线.$,但不能以数字开头,大小写敏感,不能是JavaScript关键字.避开保留字 //JavaScript保留字 break e ...

  6. HostOnly模式下的Centos克隆虚拟机+配置固定ip

    首先在你想克隆的虚拟机上右击,选择管理下的克隆 让我们骚等一会~ ok,现在开机,这个时候是没有ip的 来修改一个文件 删掉红框中的内容,把箭头指的eth1改为eth0 在来修改一个文件 删掉红框的内 ...

  7. Discuz! X3.2重置管理员账号

    主要是使用了Tools急诊箱.先看一下Tools急诊箱的主要功能: 多种模式在线安装Discuz!,或者重装 重置管理员账号:将把您指定的会员设置为管理员 关闭功能:一键关闭/打开 [站点|插件]的操 ...

  8. bat脚本学习

    工作需求,写个bat脚本来启动自己的守护进程:bat方面完全空白啊~稍微学习了下,记录下来,后面复习! 直接上代码: 示例一:for字符串切割,切割文本中的字符串: test.txt 文本内容如下: ...

  9. GNU Octave fact函数输出

    无意间发现了这么一个函数,可以随机输出关于RMS的笑话.挺有意思的. `fact' is a function from the file /usr/share/octave/3.6.2/m/misc ...

  10. [Centos] mod_wsgi 安装流程以及遇到问题解决办法。apxs: command not found 或 Sorry, Python developer package does not appear to be installed.

    前提: Centos 系统, apache 已安装, python 已安装. 1. 首先下载mod_wsgi-3.5.tar.gz 下载地址:https://code.google.com/p/mod ...