阿里支付的环境配置部分暂且略过,直接谈代码部分。(待确认)
- 阿里支付不需要在appliation:didFinishLaunchingWithOptions中注册或初始化只需要写系统回调
//这个方法已经被废弃,为了适应低版本,最好写上
- (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) {
//[由于在跳转支付宝客户端支付的过程中,商户app在后台很可能被系统kill了,所以pay接口的callback就会失效,请商户对standbyCallback返回的回调结果进行处理,就是在这个方法里面处理跟callback一样的逻辑]
NSLog(@"result = %@",resultDic);
[[AliPayManager sharedInstance] onResp:resultDic];
}];
}else if ([url.host isEqualToString:@"platformapi"]){//支付宝钱包快登授权返回authCode
[[AlipaySDK defaultService] processAuthResult:url standbyCallback:^(NSDictionary *resultDic) {
//【由于在跳转支付宝客户端支付的过程中,商户app在后台很可能被系统kill了,所以pay接口的callback就会失效,请商户对standbyCallback返回的回调结果进行处理,就是在这个方法里面处理跟callback一样的逻辑】
NSLog(@"result = %@",resultDic);
[[AliPayManager sharedInstance] onResp:resultDic];
}];
}else{
return (
([UMSocialSnsService handleOpenURL:url])
||
([WXApi handleOpenURL:url delegate:[WechatPayManager sharedInstance]])
);
}
return YES;
}
2.订单提交
- (void)payAction:(UIButton:)sender{
/*生成订单信息及签名*/
/******必选参数*****/
//将商品信息赋予AlixPayOrder的成员变量
Order *order = [[Order alloc] init];
//商户在支付宝签约时,支付宝为商户分配的唯一标识号(以2088开头的16位纯数字)
order.partner = partner;
//卖家支付宝账号对应的支付宝唯一用户号(以2088开头的16位纯数字)
//订单支付金额将打入该账户(一个partner可以对应多个seller_id)
order.sellerID = seller;
//商户网站商品对应的唯一订单号由商家自行制定)
order.outTradeNO = [self generateTradeNO];
//商品的标题/交易标题/订单标题/订单关键字等
order.subject = product.subject;
//对一笔交易的具体描述信息。如果是多种商品,请将商品描述字符串累加传给body。
order.body = product.body;
//该笔订单的资金总额,单位为RMB(Yuan)。取值范围为[0.01,100000000.00],精确到小数点后两位。
order.totalFee = [NSString stringWithFormat:@"%.2f",product.price];
//回调URL
order.notifyURL = @"http://www.xxx.com";
//接口名称,固定值
order.service = @"mobile.securitypay.pay";
//商户网站使用的编码格式,固定为utf-8。
order.inputCharset = @"utf-8";
/*******可选参数**********/
//支付类型,默认为1商品购买
order.paymentType = @"1";
//设置未付款交易的超时时间,一旦超时,该笔交易就会自动被关闭。当用户输入支付密码、点击确认付款后(即创建支付宝交易后)开始计时。取值范围:1m~15d,或者使用绝对时间(示例格式:2014-06-13 16:00:00)。m-分钟,h-小时,d-天,1c-当天(1c-当天的情况下,无论交易何时创建,都在0点关闭)。该参数数值不接受小数点,如1.5h,可转换为90m。
order.itBPay = @"30m";
//商品地址
order.showURL = @"m.alipay.com";
//应用注册scheme,在AlixPayDemo-Info.plist定义URL types
NSString *appScheme = @"alisdkdemo";
/*****将商品信息拼接成字符串******/
//order格式在Demo中直接拿过来即可
NSString *orderSpec = [order description];
//获取私钥并将商户信息签名,外部商户可以根据情况存放私钥和签名,只需要遵循RSA签名规范,并将签名字符串base64编码和UrlEncode
id<DataSigner> signer = CreateRSADataSigner(privateKey);
NSString *signedString = [signer signString:orderSpec];
//将签名成功字符串格式化为订单字符串,请严格按照该格式
if (signedString != nil) {
NSString *orderString = [NSString stringWithFormat:@"%@&sign=\"%@\"&sign_type=\"%@\"",
orderSpec, signedString, @"RSA"];
[[AlipaySDK defaultService] payOrder:orderString fromScheme:appScheme callback:^(NSDictionary *resultDic) {
[self onResp:resultDic]
}];
}
}
-(void) onResp:(NSDictionary *)resp
{
//在这个方法中处理支付结果
}