首先要说明的是支付宝SDK的使用,官方建议,数据加密和下单等操作尽量由商户后台服务器完成,这样才能保证财产和私密信息的安全性。因此本文介绍内容,是APP和自己公司后台服务器一起协作完成支付宝支付的方法。
一、首先需要介绍的是:支付宝的接入(可参考官方文档)
还是简单给大家理一下流程,(1)在蚂蚁金服后台创建应用,拿到APPID,给后台开发人员(2)添加APP支付功能(3)签约商户号,签约有一个审核时间,这中间可能会遇到各种问题,(4)配置秘钥,分别是公钥和私钥,这个让后台人员去弄
下载SDKhttps://docs.open.alipay.com/54/104509拖入工程里面。
手动导入静态库,然后command + B 编译一下,看报不报错。
二、接下来给大家介绍项目里面的配置。
(1)第一步点击工程名——>第二步点击info——>第三步在URL Types里面添加一个支付宝返回URL type.如图所示:
(2)在plist文件中确认URL是否添加成功。
(3)在需要用到支付的ViewController里面添加以下代码:
///支付宝sdk
#import <AlipaySDK/AlipaySDK.h>
#define AppScheme @"ShouNew"
注意上面三条的Scheme一定要保持一致,不然可能导致支付成功后不能返回原APP。
三、支付宝支付流程及代码体现
(1)支付宝流程图:
简单解释一下:
第一步:APP向自己公司服务器发起下单请求(下单的时候要把商品的各项信息传给服务器,比如价格,数量,商品名等),自己公司服务器向支付宝服务器统一下单,然后返回订单号给用户。
第二步:APP拿订单号向服务器请求加密后的订单信息,用于向支付宝服务器发起请求。
类似于这样一串数据
"alipayInfo":"partner=2088321034383926&seller_id=717449318@qq.com&out_trade_no=r2017051922165642529&subject=首牛云控APP充值-¥10.0&body=首牛云控APP充值-¥10.0&total_fee=10.0¬ify_url=http://*******.cn/*********/alipayNotify.do&service=mobile.securitypay.pay&payment_type=1&_input_charset=utf-8&it_b_pay=30m&sign=hS%2BJNs3FT9Sx0U2CGIK58xs6Cdjx%2FsvBqw18Ah%2BwrtBUdNjQnqP99fjW4YK6JxjuRG5YocZmS5ZfcrtnXq7fmq9jf%2Fj%2Fz858CBBWPxtoGQZuEAPy91q8vbYYHkSgwO8qM8mtCTast9LjXyJ2un%2B6nPhNxHN0cX1%2FZxUMWwwmQQc%3D&sign_type=RSA",这是后台用支付宝提供的RSA加密算法加密后的数据。
第三步:通过SDK向支付宝服务器发起支付请求。发起请求的时候要带上APPScheme,用于返回APP支付结果回调。
第四步:完成支付后,支付宝会返回一个字典给APP,这个里面就有支付结果,但是这并不能作为支付成功与否的判断结果,因为,这个结果只是APP端成功,所以还要将这个字典内容转成json传给服务器,查询服务器支付结果,可能有朋友会问,服务器支付结果从何而来,其实在APP端完成支付后,支付宝会根据这个订单异步通知商户服务器,让服务器记录这个订单的支付结果。中间任何一环断了,这个订单都不算支付成功。
最后根据服务器查询到的订单支付结果来反应给用户。
接下来我们看代码实现:
首先是下单:
NSString *urlStr = @"orderz.do?method=submitOrderz";
//这儿需要包装的参数由服务器来定
NSDictionary *dic = @{@"color":@"怪味胡豆60克",@"price":@"0.01",@"mallproductId":@"19",@"type" : @"1",@"num":@"1",@"jSessionId":@"这儿填写你们APP的唯一登录标示符,也可以说是token",@"locationId": @"94"
};
[[SNNetWorkTools sharedTools]requestWithUrl:urlStr withRequestStyle:POST parameters:dic callback:^(id data, NSError *error) {
NSNumber *num = data[@"statusCode"];
if (codeNum) {
self.orderNum = data[@"data"][@"orderzNo"];
[self payWithAlipay];
}
}];
向服务器拿到加密信息,并向支付宝发起支付
-(void)payWithAlipay{
NSString *str = @"pay.do?method=getAlipayInfo";
NSDictionary *para = @{@"orderzNo":self.orderNum,@"jSessionId":@"这儿填写你们APP的唯一登录标示符,也可以说是token"};
[[SNNetWorkTools sharedTools]requestWithUrl:str withRequestStyle:GET parameters:para callback:^(id data, NSError *error) {
NSNumber *num = data[@"statusCode"];
if (codeNum) {
NSString *orderStr = data[@"data"][@"alipayInfo"];
// 应用注册scheme,在AliPayDemo-Info.plist定义URL types
[[AlipaySDK defaultService]payOrder:orderStr fromScheme:AppScheme callback:^(NSDictionary *resultDic) {
}];
}
}];
}
在viewDidLoad方法中注册监听支付结果的通知
//注册通知-支付宝
[[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(dealALiPayResult:) name:@"ALiPayresult" object:nil];
在APPDelegate中接受支付宝返回的支付结果转化成Json传给服务器查询支付结果
#pragma mark -- 支付回调方法
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
{
//支付宝支付回调
if ([url.host isEqualToString:@"safepay"]) {
//跳转支付宝钱包进行支付,处理支付结果
[[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
// NSLog(@"result = %@",resultDic);
NSString *jsonStr = [self DataTOjsonString:resultDic];
//将支付宝返回的dictionary转成json再传给服务器,查询服务器支付状态。
NSString *urlStr = @"pay.do?method=checkAlipayOrderz";
NSDictionary *para = @{@"data":jsonStr,@"jSessionId":@"这儿填写你们APP的唯一登录标示符,也可以说是token"};
[[SNNetWorkTools sharedTools]requestWithUrl:urlStr withRequestStyle:POST parameters:para callback:^(id data, NSError *error) {
//发送通知,将支付结果传给ViewController
[[NSNotificationCenter defaultCenter] postNotificationName:@"ALiPayresult" object:data[@"data"][@"trade_state"]];
}];
}];
}
return false;
}
//字典转Json
-(NSString*)DataTOjsonString:(id)object
{
NSString *jsonString = nil;
NSError *error;
NSData *jsonData = [NSJSONSerialization dataWithJSONObject:object options:NSJSONWritingPrettyPrinted error:&error];
if (!jsonData) {
NSLog(@"字典转json错误: %@", error);
}else {
jsonString = [[NSString alloc] initWithData:jsonData encoding:NSUTF8StringEncoding];
}
return jsonString;
}
回到ViewController中实现通知监听事件
#pragma mark --支付宝支付后查询服务器订单结果,展示给用户
-(void)dealALiPayResult:(NSNotification*)notification{
NSString *result = notification.object;
NSLog(@"支付结果:%@",result);
if ([result isEqualToString:@"9000"]) {
NSLog(@"支付成功");
}else if([result isEqualToString:@"6001"]){
NSLog(@"支付失败,中途取消");
}else{
NSLog(@"支付失败,其他原因");
}
}