1.第一步在程序入口注册微信  (支付宝不需要)

func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
//向微信终端程序注册第三方应用
WXApi.registerApp(WX_APPID)
}

  2.微信支付管理类客户端只负责调用(支付信息什么的都是服务器完成的)

import UIKit
//微信appid
let WX_APPID=""
//AppSecret
let SECRET=""
//微信
class WXApiManager:NSObject,WXApiDelegate {
static let shared = WXApiManager()
// 用于弹出警报视图,显示成功或失败的信息()
private weak var sender:BaseViewController! //(UIViewController)
// 支付成功的闭包
private var paySuccessClosure: (() -> Void)?
// 支付失败的闭包
private var payFailClosure: (() -> Void)?
//登录成功
private var loginSuccessClosure:((_ code:String) -> Void)?
//登录失败
private var loginFailClosure:(() -> Void)?
// 外部用这个方法调起微信支付
func payAlertController(_ sender:BaseViewController,
request:PayReq,
paySuccess: @escaping () -> Void,
payFail:@escaping () -> Void) {
// sender 是调用这个方法的控制器,
// 用于提示用户微信支付结果,可以根据自己需求是否要此参数。
self.sender = sender
self.paySuccessClosure = paySuccess
self.payFailClosure = payFail
if checkWXInstallAndSupport(){//检查用户是否安装微信
WXApi.send(request)
}
}
//外部用这个方法调起微信登录
func login(_ sender:BaseViewController,loginSuccess: @escaping ( _ code:String) -> Void,
loginFail:@escaping () -> Void){
// sender 是调用这个方法的控制器,
// 用于提示用户微信支付结果,可以根据自己需求是否要此参数。
self.sender = sender
self.loginSuccessClosure = loginSuccess
self.loginFailClosure = loginFail
if checkWXInstallAndSupport(){
let req=SendAuthReq()
req.scope="snsapi_userinfo"
req.state="app"
WXApi.send(req)
}
} }
extension WXApiManager {
func onResp(_ resp: BaseResp!) {
if resp is PayResp {//支付
if resp.errCode == 0 {
self.paySuccessClosure?()
}else{
self.payFailClosure?()
}
}else if resp is SendAuthResp{//登录结果
let authResp = resp as! SendAuthResp
var strMsg: String
if authResp.errCode == 0{
strMsg="微信授权成功"
}else{
switch authResp.errCode{
case -4:
strMsg="您拒绝使用微信登录"
break
case -2:
strMsg="您取消了微信登录"
break
default:
strMsg="微信登录失败"
break
}
}
UIAlertController.showAlertYes(sender, title: "授权结果", message: strMsg, okButtonTitle:"确定", okHandler: { (alert) in
if authResp.errCode == 0 {
self.loginSuccessClosure?(authResp.code) }else{
self.loginFailClosure?()
}
})
}
}
} extension WXApiManager {
// 检查用户是否已经安装微信并且有支付功能
private func checkWXInstallAndSupport() -> Bool {
if !WXApi.isWXAppInstalled() {
///这里的弹窗是我写的扩展方法
UIAlertController.showAlertYes(sender,title:"", message: "微信未安装", okButtonTitle:"确定")
return false
}
if !WXApi.isWXAppSupport() {
///这里的弹窗是我写的扩展方法
UIAlertController.showAlertYes(sender,title:"", message: "当前微信版本不支持支付", okButtonTitle:"确定")
return false
}
return true
}
}

3. 支付宝管理类客户端只负责调用(支付信息什么的都是服务器完成的)

//支付宝
class AliPayManager:NSObject{
static let shared = AliPayManager()
// 用于弹出警报视图,显示成功或失败的信息
fileprivate weak var sender: UIViewController!
// 支付成功的闭包
fileprivate var paySuccessClosure: (() -> Void)?
// 支付失败的闭包
fileprivate var payFailClosure: (() -> Void)?
///登录成功的闭包
fileprivate var loginSuccessClosure:((_ auth_code:String) -> Void)?
///登录失败的闭包
fileprivate var loginFailClosure:(() -> Void)?
// 外部用这个方法调起支付支付
func payAlertController(_ sender: UIViewController,
request:String,
paySuccess: @escaping () -> Void,
payFail:@escaping () -> Void) {
// sender 是调用这个方法的控制器,
self.sender = sender
//用于提示用户支付宝支付结果,可以根据自己需求是否要此参数。
self.paySuccessClosure = paySuccess
self.payFailClosure = payFail
AlipaySDK.defaultService().payOrder(request, fromScheme:"这里是URL Types配置的URLShcemes",callback:nil)
}
//外部用这个方法调起支付宝登录
func login(_ sender:BaseViewController,withInfo:String,loginSuccess: @escaping (_ str:String) -> Void,loginFail:@escaping () -> Void){
// sender 是调用这个方法的控制器,
// 用于提示用户微信支付结果,可以根据自己需求是否要此参数。
self.sender = sender
self.loginSuccessClosure = loginSuccess
self.loginFailClosure = loginFail
AlipaySDK.defaultService().auth_V2(withInfo:withInfo, fromScheme:"这里是URL Types配置的URLSchemes", callback:nil)
}
///授权回调
func showAuth_V2Result(result:NSDictionary){
// 9000 请求处理成功
// 4000 系统异常
// 6001 用户中途取消
// 6002 网络连接出错
let returnCode:String = result["resultStatus"] as! String
var returnMsg:String = ""
switch returnCode{
case "6001":
returnMsg = "用户中途取消"
break
case "6002":
returnMsg = "网络连接出错"
break
case "4000":
returnMsg = "系统异常"
break
case "9000":
returnMsg = "授权成功"
break
default:
returnMsg = "系统异常"
break
}
UIAlertController.showAlertYes(sender, title: "授权结果", message: returnMsg, okButtonTitle:"确定", okHandler: { (alert) in
if returnCode == "9000" {
let r=result["result"] as! String
self.loginSuccessClosure?(r) }else{
self.loginFailClosure?()
}
})
}
//传入回调参数
func showResult(result:NSDictionary){
// 9000 订单支付成功
// 8000 正在处理中
// 4000 订单支付失败
// 6001 用户中途取消
// 6002 网络连接出错
let returnCode:String = result["resultStatus"] as! String
// var returnMsg:String = ""
// switch returnCode{
// case "6001":
// returnMsg = "用户中途取消"
// break
// case "6002":
// returnMsg = "网络连接出错"
// break
// case "8000":
// returnMsg = "正在处理中"
// break
// case "4000":
// returnMsg = "订单支付失败"
// break
// case "9000":
// returnMsg = "支付成功"
// break
// default:
// returnMsg = "订单支付失败"
// break
// }
// UIAlertController.showAlertYes(sender, title: "支付结果", message: returnMsg, okButtonTitle:"确定", okHandler: { (alert) in
// if returnCode == "9000" {
// self.paySuccessClosure?()
//
// }else{
// self.payFailClosure?()
// }
// })
if returnCode == "9000" {
self.paySuccessClosure?() }else{
self.payFailClosure?()
}
}
}

4.在AppDelegate中回调

// MARK: - 支付回调
extension AppDelegate{
// iOS 8 及以下请用这个
func application(_ application: UIApplication, open url: URL, sourceApplication: String?, annotation: Any) -> Bool {
if url.host == "safepay"{//支付宝
//支付回调
AlipaySDK.defaultService().processOrder(withPaymentResult: url, standbyCallback:{ (resultDic) in
if resultDic != nil{
AliPayManager.shared.showResult(result:resultDic! as NSDictionary)
}
})
//授权回调
AlipaySDK.defaultService().processAuth_V2Result(url, standbyCallback: { (resultDic) in
if resultDic != nil{
AliPayManager.shared.showAuth_V2Result(result:resultDic! as NSDictionary)
}
})
return true
}else{//微信
return WXApi.handleOpen(url, delegate:WXApiManager.shared)
} }
// iOS 9 以上请用这个
func application(_ app: UIApplication, open url: URL, options: [UIApplicationOpenURLOptionsKey : Any]) -> Bool {
if url.host == "safepay"{//支付宝
//支付回调
AlipaySDK.defaultService().processOrder(withPaymentResult: url, standbyCallback:{ (resultDic) in
if resultDic != nil{
AliPayManager.shared.showResult(result:resultDic! as NSDictionary)
}
})
//授权回调
AlipaySDK.defaultService().processAuth_V2Result(url, standbyCallback: { (resultDic) in
if resultDic != nil{
AliPayManager.shared.showAuth_V2Result(result:resultDic! as NSDictionary)
}
})
return true
}else{//微信
return WXApi.handleOpen(url,delegate:WXApiManager.shared)
}
}
}

5.支付调用 这里拿数据是用SwiftyJSON

1.微信支付
///从服务器拿到生成好的请求参数
let charge=json["charge"]
let req=PayReq()
req.timeStamp=charge["timestamp"].uInt32Value
req.partnerId=charge["partnerid"].stringValue
req.package=charge["package"].stringValue
req.nonceStr=charge["noncestr"].stringValue
req.sign=charge["sign"].stringValue
req.prepayId=charge["prepayid"].stringValue
WXApiManager.shared.payAlertController(self, request: req, paySuccess: {
print("支付成功")
}, payFail: {
print("支付失败")
})
2.支付宝支付
///从服务器拿到生成好的请求参数
let orderString=json["charge"]["orderString"].stringValue
AliPayManager.shared.payAlertController(self, request:orderString, paySuccess: {
print("支付成功")
}, payFail: {
print("支付失败")
})

Swift调用微信支付宝SDK(Swift4.0)的更多相关文章

  1. 调用微信js sdk

    场景:需要调用微信获取当前位置的借口. 途径:查看微信 https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115 .后 ...

  2. 从支付宝SDK的支付流程理解什么是公钥和私钥,什么是加密和数字签名

    ------------------- 这是自己总结: 支付宝SDK支付用到的公钥与私钥整理如下: 1.商户应用公钥    2.商户应用私钥 3.支付宝公钥 4.支付宝私钥   商户应用的公钥与私钥生 ...

  3. 免sdk实现微信/支付宝转账打赏功能

    版权声明:本文为xing_star原创文章,转载请注明出处! 本文同步自http://javaexception.com/archives/162 近期发现了一个很好的开源项目,可以给自己的app添加 ...

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

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

  5. 解决微信官方SDK给出1.4.0等版本没有预览文件(previewFile)等接口

    使用苹果手机测试 调用微信的js-sdk在系统中实现上传.预览附件的功能.在自己的手机测试通过后,直接丢给QA测试了 本以为相安无事了,没想到QA用安卓手机测的时候居然不得,使用的是下载下来的jwei ...

  6. 微信开放平台 公众号第三方平台开发 教程四 代公众号调用接口的SDK和demo

    原文:微信开放平台 公众号第三方平台开发 教程四 代公众号调用接口的SDK和demo 教程导航: 微信开放平台 公众号第三方平台开发 教程一 平台介绍 微信开放平台 公众号第三方平台开发 教程二 创建 ...

  7. 调用支付宝SDK问题

    近期做了一个项目里面要有支付.银联.支付宝,微信支付 我先一个一个写吧 先说支付宝SDK 支付宝SDK放进project里面之后肯定会报错.这时候你就要一个一个改掉 1. 2. 3. 哎 我懒得写了. ...

  8. React Native之支付集成(微信 支付宝)(ios android)

    React Native之支付集成(微信 支付宝)(ios android) 一,需求分析 1.1,app在线充值与提现 二,技术介绍与集成 2.1,微信支付 2.1.1,Android配置 详细配置 ...

  9. app微信支付宝支付后台的插件模式+回调通过spring广播处理后续业务(已亲测可用)

    写在前面的话:每当我们做一个项目,基本上都会涉及到支付的业务,最常用的莫过于微信和支付宝的支付了,项目有bug,有问题,都不叫问题,可一旦钱出了问题,那就是大问题了,所以在支付业务上我们必须慎之又慎! ...

随机推荐

  1. 在jsp页面如何获得url参数

    方法一:当一个url过来时,如:http://localhost:8080/pro/demo/hello.jsp?name=john,在hello.jsp页面,我们可以这样得到name的值: < ...

  2. c++ STL之map

    map内部自建一颗红黑树(一 种非严格意义上的平衡二叉树),这颗树具有对数据自动排序的功能,所以在map内部所有的数据都是有序的,map中的元素是自动按Key升序排序,所以不能对map用sort函数: ...

  3. ceph常用命令(3)

    1.查看集群配置信息 ceph daemon /var/run/ceph/ceph-mon.$(hostname -s).asok config show 2.在部署节点修改了ceph.conf文件, ...

  4. Linux开机启动过程分析

    开机过程指的是从打开计算机电源直到LINUX显示用户登录画面的全过程.分析LINUX开机过程也是深入了解LINUX核心工作原理的一个很好的途径. 启动第一步--加载BIOS 当 你打开计算机电源,计算 ...

  5. JRebel for IntelliJ

    好久没用jrebel了,跟前端进行项目联调总是有些许改动,还是热部署方便. 目前用的idea版本:IntelliJ IDEA 2019.2 JRebel插件版本:JRebel for IntelliJ ...

  6. Unity小白文——单例的定义

    当类继承与MonoBehaviour时 public class TestSingle : MonoBehaviour { public static TestSingle Instance; voi ...

  7. 开发 --- IDE及小工具

    django-debug-toolbar 介绍: django-debug-toolbar 是Django调试工具条,提供了各种信息的获取,拥有极强的调试功能. 官网: https://django- ...

  8. Loj 2230. 「BJOI2014」大融合 (LCT 维护子树信息)

    链接:https://loj.ac/problem/2230 思路: 设立siz数组保存虚点信息,sum表示总信息 维护子树信息link操作和access操作需要进行一些改动 可参考博客:https: ...

  9. SQLServer学习之表的操作

    SQLServer学习之表的操作 关系数据库通常包含多个表.数据库实际上是表的集合,数据库的数据或者信息都是存储在表中的.表是对数据进行存储和操作的一种逻辑结构,每一个表都代表一个对用户意义的对象. ...

  10. 灾备系统 RTO与RPO

    出处: https://blog.51cto.com/se7en/1085442 http://www.iso27001.org.cn/fuwu/it/iso22301/show_511.html h ...