获取内容资料
iOS开发

微信ios微信支付接口开发教程

摘要:本文将带你了解IOS开发入门iOS 教程 支付,希望本文对大家学IOS有所帮助。

本文将带你了解IOS开发入门iOS 教程 支付,希望本文对大家学IOS有所帮助。

最近项目要求添加一个支付的功能,要求是不需要服务端的配合,独立在客户端完成。

开始看官方demo的时候发现客户端只有短短的几行代码便成功了,更关键的是文档中那些参数都解释的含含糊糊。结果花了我好几天的时间才最终弄好。现在细数其辛酸历程。

PayReq* req             = [[[PayReq alloc] init]autorelease];

req.partnerId           = [dict objectForKey:@”partnerid”];

req.prepayId            = [dict objectForKey:@”prepayid”];

req.nonceStr            = [dict objectForKey:@”noncestr”];

req.timeStamp           = stamp.intValue;

req.package             = [dict objectForKey:@”package”];

req.sign                = [dict objectForKey:@”sign”];

[WXApi sendReq:req];

这就官方文档中最核心的调出支付的代码,我们所需要做的一切都是获取这六个参数。

首先来一个个的解释这些参数

partnerId :这个就是在你申请通过商户资料后发到你邮件的中的一个商户号

106A3038-E2CA-46D0-9AFC-B86DF979D588.png

prepayid : 这个是需要向服务器提交申请后返回的一个支付交易会话ID,详细的下面会提到。

nonceStr : 这个是你自己生成的一个随机数。

timeStamp : 这个是你生成的一个时间戳。10位!!!不是13位的那个!

package : 这个目前是一个定死的值 Sign=WXPay。

sign : 这个是自己根据参数生成的一个签名!最坑的就是它了!

现在来一个的说如何得到这些参数值

这个一般来说是在服务端申请好的,客户端直接获取就行。但是万恶的公司居然要求在客户端弄。

乍一看无非是向的一个接口提交数据,然后就会返回了。

但是这茫茫多的参数中其实隐藏着无数的细节,稍有不慎就返回一个大大失败,然后你就愁的一头包了。

这些参数里面有一个是需要生成一个签名。

大概就是说把一些参数按照ASCII的顺序先进行排序然后再拼接上一个key(这个key是你在申请成功商户资料后按照邮件中提示进行设置的,32位)。拼接好后进行MD5转码。看起来很轻松明了吧,但是这里面最大的一个坑就是他这个举例了!这个例子中只有寥寥几个参数,如果你就按照他这个也只是用这几个参数生成签名,那就怎么也获取不到这个prepayid了!实际上,这个签名里面所包含的参数是需要包含你所要提交获取prepayid的所有参数的!

也就是前面给的官方文档中所有表示必须要的参数,当然除了你现在要生成的这个sign。

顺便提一句,这里的提交数据是以XML的形式,解析数据也是XML的格式。

这样就可以顺利的获得prepayid了。

NSString * nonce_str = [self md5:[NSString stringWithFormat:@”%d”, arc4random % 10000]];

nonce_str = [nonce_str uppercaseString];

– (NSString *) md5: (NSString *) inPutText

const char *cStr = [inPutText UTF8String];

unsigned char result[CC_MD5_DIGEST_LENGTH];

CC_MD5(cStr, strlen(cStr), result);

return [[NSString stringWithFormat:@”%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X”,

result[0], result[1], result[2], result[3],

result[4], result[5], result[6], result[7],

result[8], result[9], result[10], result[11],

result[12], result[13], result[14], result[15]

] lowercaseString];

其实就是一个随机数,怎么生成随你。有个不得不提的地方,这里的noncestr就是你在第一次生成签名时的那个随机数,不用再次生成了!

3、timeStamp

NSString * timeString = [NSString stringWithFormat:@”%.0f”, [[NSDate date] timeIntervalSince1970]];

@property (nonatomic, assign) UInt32 timeStamp;

他的类型是这个样的,而你生成的是一个字符串类型的,最后提交的时候需要进行转化的!

这里的签名不同于你第一次申请prepayid的签名,这里的生成签名的参数是appid,prepayid,partnerid,timestamp,noncestr,package,这几个排序后再拼接key,最后生成一个sign。

本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标移动开发之IOS频道!

职坐标官网steam移动应用验证手机app赚钱软件本文由 @白羽 发布于职坐标。未经许可,禁止转载。

Similar Posts

发表评论

邮箱地址不会被公开。 必填项已用*标注