• 支付宝接入支付集成总结


    支付宝接入支付集成总结

    我会详细的记录每一步,以便自己以后查看复习,包括:非代码部分、代码部分 配置
    • 支付宝集成文档 https://docs.open.alipay.com/204/105295/

    • SDK下载
      https://docs.open.alipay.com/54/104509

      1. 准备工作
        1> 非代码部分的准备工作:
        接入支付:点击蚂蚁金服开放平台->点击接入支付->将会进入登录页面(如果是公司开发,登录公司提供的支付宝账号;自己开发,登录自己的账号)->如果未填写过各项信息和同意协议,这这里会需要你填入地址,手机号,邮箱,等一系列东西 -> 然后就进入到主页里
     
    1.png

    在这里你可以选择“支付接入”,创建一个支付应用

     
    2.png

    选择自用型

     
    3.png

    创建成功的页面

    注意:这样并不代表你的应用现在就有支付能力,许多功能需要签约才能生效(如果公司已经有过处理,我所说的是从开始处理)

     
    4.png

    我们需要补全支付宝所需要的资料,然后提交审核,包括:身份证照片,和个体商户信息,商家信息

    配置公钥私钥,公钥上传支付宝

     
    5.png

    可点击“查看密钥生成”,下载生成工具生成上传
    配置应用网关:异步接受通知地址
    配置授权回调地址:第三方授权或用户信息授权后回调地址

    **更加详细文档:https://docs.open.alipay.com/200/105310

     
    6.png

    非技术部分的准备工作就这些,配置好这些东西我们就可一开始技术相关的准备工作了(支付宝的文档很全也很仔细,遇到问题,找文档)
    2> 技术相关的准备工作

    • 下载SDK,拖入两个文件到xcode
       
      7.png
    • 根据文档导入依赖库:https://docs.open.alipay.com/204/105295/

    • 添加schemes 为app name 或者起一个独一无二(应用于支付宝吊起app,这里的schemes,会在调用支付的接口中用到)

    • 因为本次项目是swift 所以还得考虑针对swift的接入
      1》只需要在桥接文件中导入 #import <AlipaySDK/AlipaySDK.h> #import <UIKit/UIKit.h>(加入UIKit的原因是会产生错误所以必须加入)

      1. 相关的准备工作走完成了,那么接下来是代码时间(相对来说还是很简单的)
        我封装了一个管理类
        代码需要关注几个问题:1。私钥不要放在前台,私钥加签放在后台 2. appDelegate 处理支付宝吊起回调

      2. 通过产品id,去后台获取签名之后的字符串

      3. 吊起支付,监听回调

      4. 服务器验证
        一:

        class AliPayManager: NSObject {
        static let manager = AliPayManager()
        // 调用者
        fileprivate weak var sender:UIViewController?
        // 支付成功回调
         fileprivate var paySuccess:((_ coin:String,_ diamond:String)->Void)?
        func aliPay(sender:UIViewController, id:String, paySuccess:@escaping (_ coin:String,_ diamond:String)->Void) {
            self.sender = sender
            self.paySuccess = paySuccess
            getAliPayDataSource(id: id)
        }
        
        
      // 第一步服务器请求加密的签名数据
      fileprivate func getAliPayDataSource(id:String){
          RequestManager.request(RequestUrl.aliPayGetSignOder.url, method: .get, parameters: ["item_id":id]).responseString { (responseData) in
              ResultBase<[String:String]>.parseJSON(dataResponse: responseData, currentViewController: self.sender!, errorAlertHandle: { (errorInfo, result) in
                  self.sender?.hide()
                  if let error = errorInfo {
                      self.sender?.showError(error)
                  } else {
                      self.sender?.showError("获取信息失败,请稍后再试!")
                  }
              }, successHandle: { (dict) in
                  if let result = dict {
                      let orderString = result["order_str"]
                      if let order = orderString {
                          self.aliPay(orderString: order, appScheme: "TexasPoker")
                      } else {
                          self.sender?.hide()
                          self.sender?.showError("获取信息失败,请稍后再试!")
                      }
                  } else {
                      self.sender?.hide()
                      self.sender?.showError("获取信息失败,请稍后再试!")
                  }
              }
              )
          }
      } 
      
      
      /// 第二步吊起支付
        fileprivate func aliPay(orderString:String, appScheme:String) {
     //   AlipaySDK.defaultService().setUrl("https://openapi.alipaydev.com/gateway.do")
            AlipaySDK.defaultService().payOrder(orderString, fromScheme: appScheme) { (resultDict) -> Void in
                let errorCode = resultDict!["resultStatus"] as! String
                if errorCode == "601" {
                    self.sender?.hide()
                    self.sender?.showError("您取消了支付")
                } else if errorCode == "9000" ||  errorCode == "8000" {
                    let dataString = resultDict!["result"] as! String
                    self.clientAliPayToServer(dataString: dataString)
                } else {
                    self.sender?.hide()
                    self.sender?.showError("支付失败")
    
                }
            }
        }  
    
    

    /// 第三步服务器验证 fileprivate func clientAliPayToServer(dataString:String){ RequestManager.request(RequestUrl.aliPayGetResult.url, method: .post, parameters: ["result": dataString]).responseString { (responseData) in self.sender?.hide() ResultBase<[String:Any]>.parseJSON(dataResponse: responseData, currentViewController: self.sender!, errorAlertHandle: { (errorInfo, resultBase) in if let error = errorInfo { self.sender?.showError(error) } else { self.sender?.showError("验证支付失败") } }, successHandle: { (dict) in let is_verify = dict!["is_verify"] as! Bool let diamond = (dict!["diamond"] as! NSNumber).stringValue let coin = (dict!["coin"] as! NSNumber).stringValue if is_verify { self.paySuccess!(coin, diamond) self.sender?.showSuccess(text: "支付成功") } else { self.sender?.showError("验证支付失败") } }) } } }

    二:AppDelegate 代理方法处理支付宝吊起app
    iOS 8.0之后
    - (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation { if (!result) { if ([url.host isEqualToString:@"safepay"]) { [[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) { NSLog(@"result = %@",resultDic); }]; } } return YES; }

    iOS9 以上新方法

    - (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey,id> *)options {
        if ([url.host isEqualToString:@"safepay"]) {
            [[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
                NSLog(@"result = %@",resultDic);
            }];
            return YES
        } 
    }
    
    

    支付宝是如何防止漏单、错单的:附上一张图我想是最能说明情况的

     
    8.png

    第一:我们会将支付成功的返回结果提交于自己服务器做验证,后台服务器进行同步验证,验证交易成功
    第二:防止我们不正常交易,比如没有正确的吊起app,支付宝会异步通知后台服务器,后台服务器会进行验签,从而判断是否交易成功

    通过这两种方式,基本上我们交易的订单就不会出现支付成功了,却导致订单没成功,也就是漏单

    基本上支付宝支付就这些东西吧,好多,安全复杂的都是在后台进行的

     
  • 相关阅读:
    书到用时方恨少---记录读书历程
    JAVASCRIPT数据类型(值类型-引用类型-类型总览)
    jQuery基本API小结(下)---工具函数-基本插件
    jQuery基本API小结(上)--选择器-DOM操作-动画-Ajax
    【转】javascript 执行环境,变量对象,作用域链
    JavaScript知识总结--对象的相关概念
    JavaScript知识总结--引用类型(Object-Array-Function-Global-Math)
    JavaScript知识总结--历史-html引用方式-基础概念
    Java--神奇的hashcode
    Java-从堆栈常量池解析equals()与==
  • 原文地址:https://www.cnblogs.com/wannaGoBoy/p/8513226.html
Copyright © 2020-2023  润新知