iOS支付宝支付方法详解

2025-05-29 0 58

支付宝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的私密,签名通过请求服务端获取。官方是推荐服务端签名的,为了安全考虑。

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

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 iOS支付宝支付方法详解 https://www.kuaiidc.com/90764.html

相关文章

发表评论
暂无评论