iOS支付宝支付方法详解

时间:2022-06-19 03:08:33

支付宝sdk下载地址:https://doc.open.alipay.com/doc2/detail?treeid=54&articleid=103419&doctype=1

支付宝集成

在支付宝集成的过程中,会遇到一些报错,下面就碰到的报错,和大家一起解决。

集成参考官方文档:

导入代码文档:https://doc.open.alipay.com/doc2/detail.htm?spm=0.0.0.0.rifava&treeid=59&articleid=103676&doctype=1

demo运行注意:https://doc.open.alipay.com/doc2/detail.htm?spm=0.0.0.0.ravnv1&treeid=59&articleid=103677&doctype=1

1.新建一个alipaysdk文件夹,提取sdk包中以下文件到此文件夹里,把文件拉到xcode里

iOS支付宝支付方法详解

2.在xcode中,点击项目名,选择build phases -->link binary with libraries 添加依赖库。

注意:如果漏了部分没有添加的,有时会报其它各种错。

iOS支付宝支付方法详解

3.编译项目,会出现以下错误。

1)cannot find interface declaration for 'nsobject', superclass of 'base64'

那么需要打开报错了的文件,增加头文件。

#import <foundation/foundation.h

2)"unknown type name ‘nsstring‘ "或者"unknown type name ‘nsdata‘ "等不识别常见类的问题。

iOS支付宝支付方法详解

这是因为缺少foundation类库和uikit类库,支付宝demo中之所以没有出现此错误,是因为在.pch文件中导入过这些类库

解决办法:只需要在出现错误的文件中导入这些类库即可,可以在.pch中添加,也可以直接在openssl_wrapper.h中添加

?
1
2
#import <uikit/uikit.h>
#import <foundation/foundation.h>

3)‘openssl/asn1.h‘ file not found

iOS支付宝支付方法详解

这个处理方式,参考上面链接“demo的运行注意”第4点。

点击项目名称,点击“build settings”选项卡,在搜索框中,以关键字“search”搜索,对“header search paths”增加头文件路径:$(srcroot)/项目名称。如果头文件信息已增加,可不必再增加。

iOS支付宝支付方法详解

$(srcroot)/项目名称 一定要注意这个路径。

4)如果你的app基于9.0编译,那么为了适配ios9.0中的app transport security(ats)对http的限制,这里需要对支付宝的请求地址alipay.com、alipayobjects.com做例外,在app对应的info.list中添加如下配置(文中以xml格式描述)。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
<key>nsapptransportsecurity</key>
 <dict>
  <key>nsexceptiondomains</key>
  <dict>
   <key>alipay.com</key>
   <dict>
    <key>nsincludessubdomains</key>
    <true/>
    <key>nstemporaryexceptionallowsinsecurehttploads</key>
    <true/>
    <key>nstemporaryexceptionminimumtlsversion</key>
    <string>tlsv1.0</string>
    <key>nstemporaryexceptionrequiresforwardsecrecy</key>
    <false/>
   </dict>
   <key>alipayobjects.com</key>
   <dict>
    <key>nsincludessubdomains</key>
    <true/>
    <key>nstemporaryexceptionallowsinsecurehttploads</key>
    <true/>
    <key>nstemporaryexceptionminimumtlsversion</key>
    <string>tlsv1.0</string>
    <key>nstemporaryexceptionrequiresforwardsecrecy</key>
    <false/>
   </dict>
  </dict>
 </dict>

5)配置支付宝返回

注意:定义的返回types,不能带下画线,建议字母或者字母+数字

?
1
2
//应用注册scheme,在alixpaydemo-info.plist定义url types
nsstring *appscheme = @"alisdkpaydemo";

iOS支付宝支付方法详解

基本上已经完成了,下面只需要拷贝demo里的测试代码,即可以进行支付宝支付了。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
#pragma mark ==============产生随机订单号==============
 
- (nsstring *)generatetradeno
{
 static int knumber = 15;
 
 nsstring *sourcestr = @"0123456789abcdefghijklmnopqrstuvwxyz";
 nsmutablestring *resultstr = [[nsmutablestring alloc] init];
 srand((unsigned)time(0));
 for (int i = 0; i < knumber; i++)
 {
  unsigned index = rand() % [sourcestr length];
  nsstring *onestr = [sourcestr substringwithrange:nsmakerange(index, 1)];
  [resultstr appendstring:onestr];
 }
 return resultstr;
}
 
- (void)payforalipay
{
 /*
  *点击获取prodcut实例并初始化订单信息
  */
 //product *product = [self.productlist objectatindex:indexpath.row];
 nsstring *productname = @"支付宝测试商品"; //商品标题
 nsstring *productdescription = @"支付宝测试商品描述"; //商品描述
 nsstring *amount = @"0.01"; //商品价格
 nsstring *notifyurl = @"http://www.xxx.com"; //回调url
 /*
  *商户的唯一的parnter和seller。
  *签约后,支付宝会为每个商户分配一个唯一的 parnter 和 seller。
  */
 
 /*============================================================================*/
 /*=======================需要填写商户app申请的===================================*/
 /*============================================================================*/
 nsstring *partner = @"2088811956033819"; // 这是支付宝文档里的测试账号
 nsstring *seller = @"xinyuxingbangxinxi@163.com"; // 这是支付宝文档里的测试账号
 nsstring *privatekey = @"miicdwibadanbgkqhkig9w0baqefaascamewggjdageaaogbaj3u/f+cuyutwilefrywcwnvecix756fbyfkp3ymfy3mndzccpc7kk62rkcpvtgshhgvx0uuprgzsv1y6m17teoty/1kvsxhb6wvloktxf9syixwyr6iohyl1etxjnqotl0zqa3id1vjozmzzxm0+qe8dnc3rxoose7xovkib+rjagmbaaecgyade0rer+1pn6flbq2to4x6hwmuhzbf6my6ea8508owayovcumcohmfxwwdcm5tj9hkogzamobql1x/khcs8gxckwvesiqr0/a4b2wbcjqtyxyx9onhudjpfc/djj/djx0vdduepem5++djbtdxejzdmegk27trfpwm7cnbjjxpjqjbanb6bbpmunml22buu4jmevaqzekg+ho3tmr8aa/np0ck8jdq9je/hbhpxkvmgdhxlx4haoygi6wf2vrmz7exrdmcqqc78v+lcxrtmsmzjqze6tzavg8erfypfm+23ebn+36w8e+vnt+8wquocd8txsbssvbwdt6zrqmeeev77mdz18/zakbvcl1ohlmlw1vvht09uvr9bbm/w2gs5uolnrtrjn+w9xzo+ptxxpjuq/isjhm8q7ntmsdbfr1jdbojnlrhgjefakearferoeskjuit+7ukm3r3ka+ayx851vywdc5rwqgbz6xcy+abfnyvqpo+7fyjognw5l4t86d/cpc6rmsy8ohzjwjbalihgihuwhu8xw9qz5l6nwzn2w/vqa9brm3xokvlfoirpdox0oo6ou7wwdgbmz+86+qlmawx+zooihpgiz0mwr8=";
 /*============================================================================*/
 /*============================================================================*/
 /*============================================================================*/
 
 //partner和seller获取失败,提示
 if ([partner length] == 0 ||
  [seller length] == 0 ||
  [privatekey length] == 0)
 {
  uialertview *alert = [[uialertview alloc] initwithtitle:@"提示"
              message:@"缺少partner或者seller或者私钥。"
              delegate:self
            cancelbuttontitle:@"确定"
            otherbuttontitles:nil];
  [alert show];
  return;
 }
 
 /*
  *生成订单信息及签名
  */
 //将商品信息赋予alixpayorder的成员变量
 order *order = [[order alloc] init];
 order.partner = partner;
 order.seller = seller;
 order.tradeno = [self generatetradeno]; //订单id(由商家自行制定)
 order.productname = productname; //商品标题
 order.productdescription = productdescription; //商品描述
 order.amount = [nsstring stringwithformat:@"%.2f",[amount doublevalue]]; //商品价格
 order.notifyurl = notifyurl; //回调url
 
 order.service = @"mobile.securitypay.pay";
 order.paymenttype = @"1";
 order.inputcharset = @"utf-8";
 order.itbpay = @"30m";
 order.showurl = @"m.alipay.com";
 
 //应用注册scheme,在alixpaydemo-info.plist定义url types
 nsstring *appscheme = @"alisdkpaydemo";
 
 //将商品信息拼接成字符串
 nsstring *orderspec = [order description];
 nslog(@"orderspec = %@",orderspec);
 
 //获取私钥并将商户信息签名,外部商户可以根据情况存放私钥和签名,只需要遵循rsa签名规范,并将签名字符串base64编码和urlencode
 id<datasigner> signer = creatersadatasigner(privatekey);
 nsstring *signedstring = [signer signstring:orderspec];
 
 //将签名成功字符串格式化为订单字符串,请严格按照该格式
 nsstring *orderstring = nil;
 if (signedstring != nil) {
  orderstring = [nsstring stringwithformat:@"%@&sign=\"%@\"&sign_type=\"%@\"",
      orderspec, signedstring, @"rsa"];
  
  nslog(@"%@",orderstring);
  [[alipaysdk defaultservice] payorder:orderstring fromscheme:appscheme callback:^(nsdictionary *resultdic) {
   nslog(@"reslut = %@",resultdic);
   // 这里填写需要回调的页面,比如,跳转到支付成功页面。
//   bspayresultviewcontroller *paystate = [[bspayresultviewcontroller alloc] init];
//   paystate.title =[resultdic[@"resultstatus"] isequaltostring:@"9000"]?@"支付成功": @"支付失败";
//   paystate.orderid = self.paymentmodel.order_id;
//   paystate.amount = self.paymentmodel.order_amount;
//   paystate.paytype = @"支付宝支付";
//   paystate.failure = resultdic[@"memo"];
//   [self.navigationcontroller pushviewcontroller:paystate animated:no];
  }];
 }
 
}

当然,这个是在客户端进行签名的,实际上,客户端不需要知道ras的私密,签名通过请求服务端获取。官方是推荐服务端签名的,为了安全考虑。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。