微信和支付宝二码合一和微信都不能更新

一.支付宝支付
1. 集成说明
1.1 作为当下最热门的支付宝和微信支付,相信有很多的app都很乐意的将支付宝集成在app中,毕竟只要你开发的app有一点涉及到买卖的,都需要集成支付宝或者微信支付.那么接下来我将为大家一一列举举出我在集成支付宝和微信中遇到的难点和其中出现的一些坑.
2. 集成前的准备(里面的步骤在集成文档中都有介绍)
2.1 注册支付宝帐号(账户最好采用公司邮箱注册)——附上网址
&code class=&hljs perl has-numbering& style=&display: padding: 0 background-color: color: box-sizing: border- font-family: 'Source Code Pro',font-size: white-space: border-top-left-radius: 0 border-top-right-radius: 0 border-bottom-right-radius: 0 border-bottom-left-radius: 0 word-wrap: background-position: background-repeat:&&https:&span class=&hljs-regexp& style=&color: rgb(0, 136, 0); box-sizing: border-&&//www&/span&./&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&s&/span&?wd=&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E6&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%94&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%AF&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E4&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%BB&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%98&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E5&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%AE&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%9D&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E5&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%BC&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%80&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E5&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%8F&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%91&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E8&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%80&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%85&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E5&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%B9&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%B3&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E5&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%8F&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%B0&/span&&rsv_spt=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&1&/span&&rsv_iqid=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&0xfe0ab&/span&&issp=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&1&/span&&f=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&3&/span&&rsv_bp=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&0&/span&&rsv_idx=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&2&/span&&ie=utf-&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&8&/span&&tn=monline_3_dg&rsv_enter=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&1&/span&&rsv_sug3=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&14&/span&&rsv_sug1=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&10&/span&&rsv_sug7=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&100&/span&&rsv_sug2=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&0&/span&&prefixsug=&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E6&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%94&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%AF&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E4&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%BB&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%98&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E5&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%AE&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%9D&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E9&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%9B&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%86&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E6&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%88&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%90&/span&&rsp=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&4&/span&&inputT=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&9885&/span&&rsv_sug4=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&10467&/span&&/code&&ul class=&pre-numbering& style=&box-sizing: border- position: width: 50 background-color: rgb(238, 238, 238); top: 0 left: 0 margin: 0 padding: 6px 0px 40 border-right-width: 1 border-right-style: border-right-color: rgb(221, 221, 221); list-style: text-align:&&&li style=&box-sizing: border- padding: 0px 5&&1&/li&&/ul&
2.2 设置(申请)支付密码
2.3 设置密码提示问题
2.4 绑定手机
2.5 创建应用(目的 : 获取APPID帐号)
2.6 然后就等待支付宝那边审核通过了
3. 开始集成
3.1 打开集成文档
&code class=&hljs avrasm has-numbering& style=&display: padding: 0 background-color: color: box-sizing: border- font-family: 'Source Code Pro',font-size: white-space: border-top-left-radius: 0 border-top-right-radius: 0 border-bottom-right-radius: 0 border-bottom-left-radius: 0 word-wrap: background-position: background-repeat:&&&span class=&hljs-label& style=&box-sizing: border-&&https:&/span&//doc&span class=&hljs-preprocessor& style=&color: rgb(68, 68, 68); box-sizing: border-&&.open&/span&&span class=&hljs-preprocessor& style=&color: rgb(68, 68, 68); box-sizing: border-&&.alipay&/span&&span class=&hljs-preprocessor& style=&color: rgb(68, 68, 68); box-sizing: border-&&.com&/span&/&/code&&ul class=&pre-numbering& style=&box-sizing: border- position: width: 50 background-color: rgb(238, 238, 238); top: 0 left: 0 margin: 0 padding: 6px 0px 40 border-right-width: 1 border-right-style: border-right-color: rgb(221, 221, 221); list-style: text-align:&&&li style=&box-sizing: border- padding: 0px 5&&1&/li&&/ul&
3.2 按步骤执行
3.2.1 点击文档中的 支付能力—-&App支付—-&SDK下载(&SDK&DEMO(将demo和sdk下载下来)
3.2.2 运行支付宝支付Demo,了解支付宝整个支付的流程(如果里面出现错误,直接百度或者查看文档,里面有详细的解释,我这里就不再一一说明了)
4. 系统交互流程(红色部分是重点部分)
4.1 流程 : 商户客户端发送请求(获取签名后的订单信息)—-&商户服务端(返回签名后的订单信息sign)—-&调用支付宝支付接口,发送支付请求—-&返回支付结果
5. 订单 : 由服务器生成
6. 注意 : 只需得到服务器返回的sign
7. 导入相关文件(此处导入文件最好看官方文档,比较正式)
8. 导入相关库
8.1 TARGETS—-&General—-&Linked Frameworks and Libraries—-&点击”+”导入相关的库(此处导入的文件当已开发文档中规定的为主)
9.1 支付宝的集成本来是和Demo上代码书写的顺序一样,但是由于我们后台是第一次做支付,所以最终无法返回一个正确的sign,这样导致我们集成的时候中间有一个步骤是多余的.
10.1 发送请求给后台,请求需要的字串(由于我们做的app设计到需要传入10个参数给后台,才能返回结果)—-& 下面贴上请求代码
&code class=&hljs objectivec has-numbering& style=&display: padding: 0 background-color: color: box-sizing: border- font-family: 'Source Code Pro',font-size: white-space: border-top-left-radius: 0 border-top-right-radius: 0 border-bottom-right-radius: 0 border-bottom-left-radius: 0 word-wrap: background-position: background-repeat:&&
&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&long&/span& activityId = _activitiy&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.ActivityId&/span&;
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *stringActivityId = [@(activityId) stringValue];
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&//活动ID&/span&
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *userId = [AppConfig shareInstance]&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.UserID&/span&;
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&//用户ID&/span&
[&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&self&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.paramDic&/span& setObject:stringActivityId forKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&activityId&&/span&];
[&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&self&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.paramDic&/span& setObject:userId forKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&userId&&/span&];
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *bodyStr = _activitiy&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.title&/span&;
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *subjectStr = _activitiy&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.title&/span&;
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSInteger&/span& total_amount = _activitiy&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.totalFee&/span&;
NSDateFormatter* formatter = [NSDateFormatter new];
[formatter setDateFormat:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&yyyy-MM-dd HH:mm:ss&&/span&];
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSDictionary&/span& *lastDic = @{
@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&body&&/span&:bodyStr,
@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&subject&&/span&:subjectStr,
@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&total_amount&&/span&:[&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& stringWithFormat:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&%.2ld&&/span&,(&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&long&/span&)total_amount],
@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&spbillCreateip&&/span&:[&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&self&/span& deviceIPAdress]
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSMutableDictionary&/span& *bigDic = [lastDic mutableCopy];
[bigDic addEntriesFromDictionary:dic];&/code&&ul class=&pre-numbering& style=&box-sizing: border- position: width: 50 background-color: rgb(238, 238, 238); top: 0 left: 0 margin: 0 padding: 6px 0px 40 border-right-width: 1 border-right-style: border-right-color: rgb(221, 221, 221); list-style: text-align:&&&li style=&box-sizing: border- padding: 0px 5&&1&/li&&li style=&box-sizing: border- padding: 0px 5&&2&/li&&li style=&box-sizing: border- padding: 0px 5&&3&/li&&li style=&box-sizing: border- padding: 0px 5&&4&/li&&li style=&box-sizing: border- padding: 0px 5&&5&/li&&li style=&box-sizing: border- padding: 0px 5&&6&/li&&li style=&box-sizing: border- padding: 0px 5&&7&/li&&li style=&box-sizing: border- padding: 0px 5&&8&/li&&li style=&box-sizing: border- padding: 0px 5&&9&/li&&li style=&box-sizing: border- padding: 0px 5&&10&/li&&li style=&box-sizing: border- padding: 0px 5&&11&/li&&li style=&box-sizing: border- padding: 0px 5&&12&/li&&li style=&box-sizing: border- padding: 0px 5&&13&/li&&li style=&box-sizing: border- padding: 0px 5&&14&/li&&li style=&box-sizing: border- padding: 0px 5&&15&/li&&li style=&box-sizing: border- padding: 0px 5&&16&/li&&li style=&box-sizing: border- padding: 0px 5&&17&/li&&li style=&box-sizing: border- padding: 0px 5&&18&/li&&li style=&box-sizing: border- padding: 0px 5&&19&/li&&/ul&
10.2 发送请求(里面包含了调用支付宝的接口)
&code class=&hljs objectivec has-numbering& style=&display: padding: 0 background-color: color: box-sizing: border- font-family: 'Source Code Pro',font-size: white-space: border-top-left-radius: 0 border-top-right-radius: 0 border-bottom-right-radius: 0 border-bottom-left-radius: 0 word-wrap: background-position: background-repeat:&&[[[SpeedService alloc]init]FetchUserPayProduct:&span class=&hljs-literal& style=&color: rgb(0, 102, 102); box-sizing: border-&&nil&/span& paramDic:bigDic completionBlock:^(&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&id&/span& response, &span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSError&/span& *error) {
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSLog&/span&(@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&++++%@&&/span&,response);
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&//服务器返回的订单信息&/span&
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSDictionary&/span& *samllDic = [response objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&result&&/span&];
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&//服务器返回的签名&/span&
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *sign = [samllDic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&sign&&/span&];
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&//签名Encode编码&/span&
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *locationSignEncode = [&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&self&/span& encodeValue:sign];
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&//创建订单模型对象并且赋值&/span&
Order *order = [Order new];
order&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.biz_content&/span& = [BizContent new];
order&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.app_id&/span&
= [samllDic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&app_id&&/span&];
order&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.biz_content&/span&
= [samllDic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&biz_content&&/span&];
order&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.charset&/span&
= [samllDic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&charset&&/span&];
order&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.method&/span&
= [samllDic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&method&&/span&];
order&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.notify_url&/span&
= [samllDic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&notify_url&&/span&];
order&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.sign_type&/span&
= [samllDic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&sign_type&&/span&];
order&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.timestamp&/span&
= [samllDic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&timestamp&&/span&];
order&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.version&/span&
= [samllDic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&version&&/span&];
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&//订单信息Encode编码&/span&
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *messageEncode = [order orderInfoEncoded:&span class=&hljs-literal& style=&color: rgb(0, 102, 102); box-sizing: border-&&YES&/span&];
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&//最终订单信息字符串Encode编码&/span&
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *orderOneString = [&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& stringWithFormat:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&%@&sign=%@&&/span&,
messageEncode, locationSignEncode];
[[AlipaySDK defaultService] payOrder:orderOneString fromScheme:Scheme callback:^(&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSDictionary&/span& *resultDic) {
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSLog&/span&(@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&服务器返回的结果:%@&&/span&,resultDic);
}];&/code&&ul class=&pre-numbering& style=&box-sizing: border- position: width: 50 background-color: rgb(238, 238, 238); top: 0 left: 0 margin: 0 padding: 6px 0px 40 border-right-width: 1 border-right-style: border-right-color: rgb(221, 221, 221); list-style: text-align:&&&li style=&box-sizing: border- padding: 0px 5&&1&/li&&li style=&box-sizing: border- padding: 0px 5&&2&/li&&li style=&box-sizing: border- padding: 0px 5&&3&/li&&li style=&box-sizing: border- padding: 0px 5&&4&/li&&li style=&box-sizing: border- padding: 0px 5&&5&/li&&li style=&box-sizing: border- padding: 0px 5&&6&/li&&li style=&box-sizing: border- padding: 0px 5&&7&/li&&li style=&box-sizing: border- padding: 0px 5&&8&/li&&li style=&box-sizing: border- padding: 0px 5&&9&/li&&li style=&box-sizing: border- padding: 0px 5&&10&/li&&li style=&box-sizing: border- padding: 0px 5&&11&/li&&li style=&box-sizing: border- padding: 0px 5&&12&/li&&li style=&box-sizing: border- padding: 0px 5&&13&/li&&li style=&box-sizing: border- padding: 0px 5&&14&/li&&li style=&box-sizing: border- padding: 0px 5&&15&/li&&li style=&box-sizing: border- padding: 0px 5&&16&/li&&li style=&box-sizing: border- padding: 0px 5&&17&/li&&li style=&box-sizing: border- padding: 0px 5&&18&/li&&li style=&box-sizing: border- padding: 0px 5&&19&/li&&li style=&box-sizing: border- padding: 0px 5&&20&/li&&li style=&box-sizing: border- padding: 0px 5&&21&/li&&li style=&box-sizing: border- padding: 0px 5&&22&/li&&li style=&box-sizing: border- padding: 0px 5&&23&/li&&li style=&box-sizing: border- padding: 0px 5&&24&/li&&li style=&box-sizing: border- padding: 0px 5&&25&/li&&li style=&box-sizing: border- padding: 0px 5&&26&/li&&li style=&box-sizing: border- padding: 0px 5&&27&/li&&li style=&box-sizing: border- padding: 0px 5&&28&/li&&li style=&box-sizing: border- padding: 0px 5&&29&/li&&li style=&box-sizing: border- padding: 0px 5&&30&/li&&li style=&box-sizing: border- padding: 0px 5&&31&/li&&li style=&box-sizing: border- padding: 0px 5&&32&/li&&li style=&box-sizing: border- padding: 0px 5&&33&/li&&li style=&box-sizing: border- padding: 0px 5&&34&/li&&li style=&box-sizing: border- padding: 0px 5&&35&/li&&li style=&box-sizing: border- padding: 0px 5&&36&/li&&/ul&
10.3 签名Encode编码
&code class=&hljs objectivec has-numbering& style=&display: padding: 0 background-color: color: box-sizing: border- font-family: 'Source Code Pro',font-size: white-space: border-top-left-radius: 0 border-top-right-radius: 0 border-bottom-right-radius: 0 border-bottom-left-radius: 0 word-wrap: background-position: background-repeat:&&- (&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span&*)encodeValue:(&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span&*)value
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span&* encodedValue =
&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&if&/span& (value&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.length&/span& & &span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&0&/span&) {
encodedValue = (__bridge_transfer
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span&*)CFURLCreateStringByAddingPercentEscapes(kCFAllocatorDefault, (__bridge CFStringRef)value, &span class=&hljs-literal& style=&color: rgb(0, 102, 102); box-sizing: border-&&NULL&/span&, (__bridge CFStringRef)@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&!*'();:@&=+$,/?%#[]&&/span&, kCFStringEncodingUTF8 );
&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&return&/span& encodedV
}&/code&&ul class=&pre-numbering& style=&box-sizing: border- position: width: 50 background-color: rgb(238, 238, 238); top: 0 left: 0 margin: 0 padding: 6px 0px 40 border-right-width: 1 border-right-style: border-right-color: rgb(221, 221, 221); list-style: text-align:&&&li style=&box-sizing: border- padding: 0px 5&&1&/li&&li style=&box-sizing: border- padding: 0px 5&&2&/li&&li style=&box-sizing: border- padding: 0px 5&&3&/li&&li style=&box-sizing: border- padding: 0px 5&&4&/li&&li style=&box-sizing: border- padding: 0px 5&&5&/li&&li style=&box-sizing: border- padding: 0px 5&&6&/li&&li style=&box-sizing: border- padding: 0px 5&&7&/li&&li style=&box-sizing: border- padding: 0px 5&&8&/li&&/ul&
1. 订单信息Encode编码就不需要自己手动编码了,直接调用支付宝提供的接口,接口里面已经对排序,编码进行了设置,直接调用就行
2. 里面的集成步骤和Demo中的有所不同,你们也可以根据自己的需求,酌情的增加或者减少.
11. 支付宝如果按照上面的步骤集成,应该是没问题的,文章结尾后会贴上我集成的时候遇见的bug和坑,敬请期待(支付宝集成完毕)
二 . 微信支付
1. 集成说明 : 相对于支付宝集成,微信集成要简单的多了
2. 集成前的准备(完成一下需要的帐号信息)
2.1 微信帐号
2.2 微信帐号密码
2.3 微信支付商户号
2.4 商户平台登录帐号
2.5 商户平台登录密码
2.6 应用APPID
3. 注意 : 以上步骤在微信支付平台上都有说明,我这里就不一一介绍了
4. 微信开放平台(附上网址:只要注册过了,就可以直接登录查看相关信息)—&选择
[微信支付]APP支付开发者文档
&code class=&hljs perl has-numbering& style=&display: padding: 0 background-color: color: box-sizing: border- font-family: 'Source Code Pro',font-size: white-space: border-top-left-radius: 0 border-top-right-radius: 0 border-bottom-right-radius: 0 border-bottom-left-radius: 0 word-wrap: background-position: background-repeat:&&https:&span class=&hljs-regexp& style=&color: rgb(0, 136, 0); box-sizing: border-&&//www&/span&./&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&s&/span&?wd=&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E5&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%BE&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%AE&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E4&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%BF&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%A1&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E6&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%94&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%AF&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E4&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%BB&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%98&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E5&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%B9&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%B3&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E5&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%8F&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%B0&/span&&rsv_spt=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&1&/span&&rsv_iqid=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&0x970a0db&/span&&issp=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&1&/span&&f=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&3&/span&&rsv_bp=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&0&/span&&rsv_idx=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&2&/span&&ie=utf-&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&8&/span&&tn=monline_3_dg&rsv_enter=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&1&/span&&rsv_sug3=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&12&/span&&rsv_sug1=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&9&/span&&rsv_sug7=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&100&/span&&rsv_sug2=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&0&/span&&prefixsug=&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E5&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%BE&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%AE&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E4&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%BF&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%A1&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E6&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%94&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%AF&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%E4&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%BB&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&%98&/span&&rsp=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&8&/span&&inputT=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&7099&/span&&rsv_sug4=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&7846&/span&&/code&&ul class=&pre-numbering& style=&box-sizing: border- position: width: 50 background-color: rgb(238, 238, 238); top: 0 left: 0 margin: 0 padding: 6px 0px 40 border-right-width: 1 border-right-style: border-right-color: rgb(221, 221, 221); list-style: text-align:&&&li style=&box-sizing: border- padding: 0px 5&&1&/li&&/ul&
5. 下载微信支付sdk
&code class=&hljs avrasm has-numbering& style=&display: padding: 0 background-color: color: box-sizing: border- font-family: 'Source Code Pro',font-size: white-space: border-top-left-radius: 0 border-top-right-radius: 0 border-bottom-right-radius: 0 border-bottom-left-radius: 0 word-wrap: background-position: background-repeat:&&&span class=&hljs-label& style=&box-sizing: border-&&https:&/span&//pay&span class=&hljs-preprocessor& style=&color: rgb(68, 68, 68); box-sizing: border-&&.weixin&/span&&span class=&hljs-preprocessor& style=&color: rgb(68, 68, 68); box-sizing: border-&&.qq&/span&&span class=&hljs-preprocessor& style=&color: rgb(68, 68, 68); box-sizing: border-&&.com&/span&/wiki/doc/api/app/app&span class=&hljs-preprocessor& style=&color: rgb(68, 68, 68); box-sizing: border-&&.php&/span&?chapter=&span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&11&/span&_1&/code&&ul class=&pre-numbering& style=&box-sizing: border- position: width: 50 background-color: rgb(238, 238, 238); top: 0 left: 0 margin: 0 padding: 6px 0px 40 border-right-width: 1 border-right-style: border-right-color: rgb(221, 221, 221); list-style: text-align:&&&li style=&box-sizing: border- padding: 0px 5&&1&/li&&/ul&
6. 运行Demo(如果出现错误,直接照着官方文档修改或者百度就行—&通常下载微信支付sdk运行是不存在问题的)
7. 交互时序图(红色框是重点部分)
8. 总结 : 我们只需要给后台请求,返回需要的7个参数就可以了
9. 导入相关文件(注意 : 以微信支付开发文档为准)
10. 添加 URL Types(5)微信—-& 如果在集成微信支付之前使用了微信分享,那该步骤可以省略
11. 向微信注册AppID(代码如下)—-& 第一个空 : AppID(最好使用宏) 第二个空 : 可以随便填写
11.1 注意 : 如果在集成微信支付之前集成了微信分享,那么该句代码必须写在分享注册的代码之后
&code class=&hljs objectivec has-numbering& style=&display: padding: 0 background-color: color: box-sizing: border- font-family: 'Source Code Pro',font-size: white-space: border-top-left-radius: 0 border-top-right-radius: 0 border-bottom-right-radius: 0 border-bottom-left-radius: 0 word-wrap: background-position: background-repeat:&&- (&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&BOOL&/span&)application:(&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&UIApplication&/span& *)application didFinishLaunchingWithOptions:(&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSDictionary&/span& *)launchOptions {
[WXApi registerApp:WXapp_id withDescription:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&测试demo&&/span&];
}&/code&&ul class=&pre-numbering& style=&box-sizing: border- position: width: 50 background-color: rgb(238, 238, 238); top: 0 left: 0 margin: 0 padding: 6px 0px 40 border-right-width: 1 border-right-style: border-right-color: rgb(221, 221, 221); list-style: text-align:&&&li style=&box-sizing: border- padding: 0px 5&&1&/li&&li style=&box-sizing: border- padding: 0px 5&&2&/li&&li style=&box-sizing: border- padding: 0px 5&&3&/li&&/ul&
&code class=&hljs objectivec has-numbering& style=&display: padding: 0 background-color: color: box-sizing: border- font-family: 'Source Code Pro',font-size: white-space: border-top-left-radius: 0 border-top-right-radius: 0 border-bottom-right-radius: 0 border-bottom-left-radius: 0 word-wrap: background-position: background-repeat:&&&span class=&hljs-preprocessor& style=&color: rgb(68, 68, 68); box-sizing: border-&&#pragma mark - 微信支付&/span&
- (&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&void&/span&)setUpWxPay
&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&long&/span& activityId = _activitiy&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.ActivityId&/span&;
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *stringActivityId = [@(activityId) stringValue];
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *userId = [AppConfig shareInstance]&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.UserID&/span&;
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *userTel = [&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&self&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.paramDic&/span& objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&mobile&&/span&];
&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&if&/span& (userTel&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.length&/span& == &span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&0&/span& || userTel&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.length&/span& & &span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&11&/span&) {
[SVProgressHUD showErrorWithStatus:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&请输入正确的联系电话&&/span&];
&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&return&/span&;
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *userName = [&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&self&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.paramDic&/span& objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&name&&/span&];
&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&if&/span& (userName&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.length&/span& == &span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&0&/span&) {
[SVProgressHUD showErrorWithStatus:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&请输入姓名&&/span&];
&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&return&/span&;
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *userIdentity = [&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&self&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.paramDic&/span& objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&identity&&/span&];
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&BOOL&/span& identity = [&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&self&/span& isCorrect:userIdentity];
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *userEmail = [&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&self&/span&&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.paramDic&/span& objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&email&&/span&];
&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&if&/span& (userEmail&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.length&/span& == &span class=&hljs-number& style=&color: rgb(0, 102, 102); box-sizing: border-&&0&/span&) {
[SVProgressHUD showErrorWithStatus:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&请输入邮箱号&&/span&];
&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&return&/span&;
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSInteger&/span& totalFee = _activitiy&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.totalFee&/span&;
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *body = _activitiy&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.title&/span&;
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *subject = _activitiy&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.title&/span&;
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *spbillCreateip = [&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&self&/span& deviceIPAdress];
SpeedService *speedService = [[SpeedService alloc] init];
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSDictionary&/span& *dict = @{
@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&body&&/span&:body,
@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&subject&&/span&:subject,
@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&userId&&/span&:userId,
@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&activityId&&/span&:stringActivityId,
@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&name&&/span&:userName,
@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&email&&/span&:userEmail,
@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&mobile&&/span&:userTel,
@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&identity&&/span&:userIdentity,
@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&total_amount&&/span&:[&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& stringWithFormat:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&%d&&/span&,totalFee],
@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&spbillCreateip&&/span&:spbillCreateip
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSLog&/span&(@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&字典是 : %@&&/span&,dict);
&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&if&/span& (identity == &span class=&hljs-literal& style=&color: rgb(0, 102, 102); box-sizing: border-&&YES&/span&) {
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&//判断是否安装了微信&/span&
&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&if&/span& ([WXApi isWXAppInstalled]){
[speedService FetchUserWxPayProduct:dict completionBlock:^(&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&id&/span& response, &span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSError&/span& *error) {
&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&if&/span& (!error) {
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSLog&/span&(@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&返回的结果是 : %@&&/span&,response);
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& * str = [response objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&code&&/span&];
&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&if&/span& ([str isEqualToString:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&0000&&/span&]) {
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSDictionary&/span& *dic = [&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSDictionary&/span& dictionaryWithDictionary:[response objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&result&&/span&]];
[&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&self&/span& configRequest:dic stringStr:&span class=&hljs-literal& style=&color: rgb(0, 102, 102); box-sizing: border-&&nil&/span&];
}&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&else&/span&{
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSLog&/span&(@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&网络超时,返回的错误信息是 : %@&&/span&,error);
}&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&else&/span&{
[SVProgressHUD showErrorWithStatus:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&请安装微信&&/span&];
}&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&else&/span&{
[SVProgressHUD showErrorWithStatus:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&请输入正确的身份证号码&&/span&];
&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&return&/span&;
}&/code&&ul class=&pre-numbering& style=&box-sizing: border- position: width: 50 background-color: rgb(238, 238, 238); top: 0 left: 0 margin: 0 padding: 6px 0px 40 border-right-width: 1 border-right-style: border-right-color: rgb(221, 221, 221); list-style: text-align:&&&li style=&box-sizing: border- padding: 0px 5&&1&/li&&li style=&box-sizing: border- padding: 0px 5&&2&/li&&li style=&box-sizing: border- padding: 0px 5&&3&/li&&li style=&box-sizing: border- padding: 0px 5&&4&/li&&li style=&box-sizing: border- padding: 0px 5&&5&/li&&li style=&box-sizing: border- padding: 0px 5&&6&/li&&li style=&box-sizing: border- padding: 0px 5&&7&/li&&li style=&box-sizing: border- padding: 0px 5&&8&/li&&li style=&box-sizing: border- padding: 0px 5&&9&/li&&li style=&box-sizing: border- padding: 0px 5&&10&/li&&li style=&box-sizing: border- padding: 0px 5&&11&/li&&li style=&box-sizing: border- padding: 0px 5&&12&/li&&li style=&box-sizing: border- padding: 0px 5&&13&/li&&li style=&box-sizing: border- padding: 0px 5&&14&/li&&li style=&box-sizing: border- padding: 0px 5&&15&/li&&li style=&box-sizing: border- padding: 0px 5&&16&/li&&li style=&box-sizing: border- padding: 0px 5&&17&/li&&li style=&box-sizing: border- padding: 0px 5&&18&/li&&li style=&box-sizing: border- padding: 0px 5&&19&/li&&li style=&box-sizing: border- padding: 0px 5&&20&/li&&li style=&box-sizing: border- padding: 0px 5&&21&/li&&li style=&box-sizing: border- padding: 0px 5&&22&/li&&li style=&box-sizing: border- padding: 0px 5&&23&/li&&li style=&box-sizing: border- padding: 0px 5&&24&/li&&li style=&box-sizing: border- padding: 0px 5&&25&/li&&li style=&box-sizing: border- padding: 0px 5&&26&/li&&li style=&box-sizing: border- padding: 0px 5&&27&/li&&li style=&box-sizing: border- padding: 0px 5&&28&/li&&li style=&box-sizing: border- padding: 0px 5&&29&/li&&li style=&box-sizing: border- padding: 0px 5&&30&/li&&li style=&box-sizing: border- padding: 0px 5&&31&/li&&li style=&box-sizing: border- padding: 0px 5&&32&/li&&li style=&box-sizing: border- padding: 0px 5&&33&/li&&li style=&box-sizing: border- padding: 0px 5&&34&/li&&li style=&box-sizing: border- padding: 0px 5&&35&/li&&li style=&box-sizing: border- padding: 0px 5&&36&/li&&li style=&box-sizing: border- padding: 0px 5&&37&/li&&li style=&box-sizing: border- padding: 0px 5&&38&/li&&li style=&box-sizing: border- padding: 0px 5&&39&/li&&li style=&box-sizing: border- padding: 0px 5&&40&/li&&li style=&box-sizing: border- padding: 0px 5&&41&/li&&li style=&box-sizing: border- padding: 0px 5&&42&/li&&li style=&box-sizing: border- padding: 0px 5&&43&/li&&li style=&box-sizing: border- padding: 0px 5&&44&/li&&li style=&box-sizing: border- padding: 0px 5&&45&/li&&li style=&box-sizing: border- padding: 0px 5&&46&/li&&li style=&box-sizing: border- padding: 0px 5&&47&/li&&li style=&box-sizing: border- padding: 0px 5&&48&/li&&li style=&box-sizing: border- padding: 0px 5&&49&/li&&li style=&box-sizing: border- padding: 0px 5&&50&/li&&li style=&box-sizing: border- padding: 0px 5&&51&/li&&li style=&box-sizing: border- padding: 0px 5&&52&/li&&li style=&box-sizing: border- padding: 0px 5&&53&/li&&li style=&box-sizing: border- padding: 0px 5&&54&/li&&li style=&box-sizing: border- padding: 0px 5&&55&/li&&li style=&box-sizing: border- padding: 0px 5&&56&/li&&li style=&box-sizing: border- padding: 0px 5&&57&/li&&li style=&box-sizing: border- padding: 0px 5&&58&/li&&li style=&box-sizing: border- padding: 0px 5&&59&/li&&li style=&box-sizing: border- padding: 0px 5&&60&/li&&li style=&box-sizing: border- padding: 0px 5&&61&/li&&li style=&box-sizing: border- padding: 0px 5&&62&/li&&li style=&box-sizing: border- padding: 0px 5&&63&/li&&li style=&box-sizing: border- padding: 0px 5&&64&/li&&li style=&box-sizing: border- padding: 0px 5&&65&/li&&li style=&box-sizing: border- padding: 0px 5&&66&/li&&li style=&box-sizing: border- padding: 0px 5&&67&/li&&li style=&box-sizing: border- padding: 0px 5&&68&/li&&li style=&box-sizing: border- padding: 0px 5&&69&/li&&/ul&
13. 调用微信支付代码,即可完成微信支付
&code class=&hljs objectivec has-numbering& style=&display: padding: 0 background-color: color: box-sizing: border- font-family: 'Source Code Pro',font-size: white-space: border-top-left-radius: 0 border-top-right-radius: 0 border-bottom-right-radius: 0 border-bottom-left-radius: 0 word-wrap: background-position: background-repeat:&&&span class=&hljs-preprocessor& style=&color: rgb(68, 68, 68); box-sizing: border-&&#pragma mark - 调用微信支付的接口&/span&
- (&span class=&hljs-keyword& style=&color: rgb(0, 0, 136); box-sizing: border-&&void&/span&)configRequest:(&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSDictionary&/span& *)dic stringStr:(&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSString&/span& *)stringStr{
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&//需要创建这个支付对象&/span&
PayReq *req = [[PayReq alloc] init];
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&//由用户微信号和AppID组成的唯一标识,用于校验微信用户&/span&
req&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.openID&/span& = [dic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&appid&&/span&];
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&// 商家id,在注册的时候给的&/span&
req&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.partnerId&/span& = [dic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&partnerid&&/span&];
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&// 预支付订单这个是后台跟微信服务器交互后,微信服务器传给你们服务器的,你们服务器再传给你&/span&
req&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.prepayId&/span&
= [dic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&prepayid&&/span&];
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&// 随机编码,为了防止重复的,在后台生成&/span&
req&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.nonceStr&/span&
= [dic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&noncestr&&/span&];
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&// 这个是时间戳,也是在后台生成的,为了验证支付的&/span&
&span class=&hljs-built_in& style=&color: rgb(102, 0, 102); box-sizing: border-&&NSMutableString&/span& *stamp = [dic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&timestamp&&/span&];
req&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.timeStamp&/span& = stamp&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.intValue&/span&;
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&// 根据财付通文档填写的数据和签名&/span&
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&//这个比较特殊,是固定的,只能是即req.package = Sign=WXPay&/span&
req&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.package&/span& = [dic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&package&&/span&];
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&// 这个签名也是后台做的&/span&
req&span class=&hljs-variable& style=&color: rgb(102, 0, 102); box-sizing: border-&&.sign&/span& = [dic objectForKey:@&span class=&hljs-string& style=&color: rgb(0, 136, 0); box-sizing: border-&&&sign&&/span&];
&span class=&hljs-comment& style=&color: rgb(136, 0, 0); box-sizing: border-&&//发送请求到微信,等待微信返回onResp&/span&
[WXApi sendReq:req];
}&/code&&ul class=&pre-numbering& style=&box-sizing: border- position: width: 50 background-color: rgb(238, 238, 238); top: 0 left: 0 margin: 0 padding: 6px 0px 40 border-right-width: 1 border-right-style: border-right-color: rgb(221, 221, 221); list-style: text-align:&&&li style=&box-sizing: border- padding: 0px 5&&1&/li&&li style=&box-sizing: border- padding: 0px 5&&2&/li&&li style=&box-sizing: border- padding: 0px 5&&3&/li&&li style=&box-sizing: border- padding: 0px 5&&4&/li&&li style=&box-sizing: border- padding: 0px 5&&5&/li&&li style=&box-sizing: border- padding: 0px 5&&6&/li&&li style=&box-sizing: border- padding: 0px 5&&7&/li&&li style=&box-sizing: border- padding: 0px 5&&8&/li&&li style=&box-sizing: border- padding: 0px 5&&9&/li&&li style=&box-sizing: border- padding: 0px 5&&10&/li&&li style=&box-sizing: border- padding: 0px 5&&11&/li&&li style=&box-sizing: border- padding: 0px 5&&12&/li&&li style=&box-sizing: border- padding: 0px 5&&13&/li&&li style=&box-sizing: border- padding: 0px 5&&14&/li&&li style=&box-sizing: border- padding: 0px 5&&15&/li&&li style=&box-sizing: border- padding: 0px 5&&16&/li&&li style=&box-sizing: border- padding: 0px 5&&17&/li&&li style=&box-sizing: border- padding: 0px 5&&18&/li&&li style=&box-sizing: border- padding: 0px 5&&19&/li&&li style=&box-sizing: border- padding: 0px 5&&20&/li&&li style=&box-sizing: border- padding: 0px 5&&21&/li&&li style=&box-sizing: border- padding: 0px 5&&22&/li&&li style=&box-sizing: border- padding: 0px 5&&23&/li&&li style=&box-sizing: border- padding: 0px 5&&24&/li&&li style=&box-sizing: border- padding: 0px 5&&25&/li&&li style=&box-sizing: border- padding: 0px 5&&26&/li&&li style=&box-sizing: border- padding: 0px 5&&27&/li&&li style=&box-sizing: border- padding: 0px 5&&28&/li&&li style=&box-sizing: border- padding: 0px 5&&29&/li&&li style=&box-sizing: border- padding: 0px 5&&30&/li&&li style=&box-sizing: border- padding: 0px 5&&31&/li&&li style=&box-sizing: border- padding: 0px 5&&32&/li&&/ul&
14. 特别说明 : 由于调用微信支付的7个参数都是服务器返回来的,不需要客户端做任何事情.当然有些参数客户端也是可以自己生成的,这就留给你们自己去处理了.
1. 集成支付宝出现的错误 :
1.1 能拿到服务器那边的sign,但是在调用支付宝接口的时候,代码运行并不会执行支付宝接口的block块,并且打印信息直接是提示今天已经注册报道了.
1.2 支付宝注册时间问题 : 在8月9号之前注册的用户,使用支付宝2.0的版本会出现问题,但是可以使用支付宝1.0版本的(重申:如果解签再重新签约的话,就可以使用支付宝2.0,并且兼容支付宝1.0的sdk)
—-& 1.2.1 解决办法 : 解签,再重新签约大约花1个工作日的时间
1.3 集成支付宝的时候,给自己的服务器发送请求得到sign.当打印请求拼接的参数的时候,经过仔细对比,发现其中会出现key和value值顺序颠倒问题
—-& 1.3.1 解决办法:将原来导入的sdk删除,重新倒入一次sdk就可以解决问题(很有可能是sdk造成的问题,我重新导入就解决了这问题)
1.4 签名(sign)出现的问题: 运用服务器返回的sign拼接成字符串,真机上出现系统繁忙,请重试.
—-& 1.4.1 解决方案 : 经过和支付宝提供的demo对比,支付宝的demo是完全可以实现支付功能,但是字符串加上后台返回的sign就出现这样的错误提示,说明签名有问题,这时只能叫后台返回正确的签名.
1.5 顺序问题 :如果服务器返回的sign没问题,那么最终就是的发送给支付宝参数拼接顺序问题了,要严格按照服务器返回的字串顺序拼接,然后再请求支付宝接口.(最后的出的结论是,不需要程序员手动按照顺序拼接,直接调用支付宝提供的方法,就可以完成拼接).
2. 微信支付出现的错误 :
1.1 集成完微信支付之后,真机运行,微信支付的时候只出现一个白的确定按钮,点击的时候跳回原来的app,并且返回-2
—-& 1.1.1 解决办法 : 肯定是参数的问题,如果你能确定你这里没错,那么就是后台返回的参数有问题(我做的时候是后台将一个参数的小写写成了大写,所以出现了这样的问题.其它错误是不会造成这样的结果的.仔细检查参数就可以解决)
本文已收录于以下专栏:
相关文章推荐
1.下载相关sdk,支付宝sdk及demo下载,微信支付sdk及demo下载。
2.吐槽一下,无论是民间教程还是官方教程都有坑,大方向是对的,但是配置细节问题多多,不过还是建议大家多仔细看看教程理解...
【Android实战】移动支付(微信、支付宝、银联)集成
Android支付(支付宝,微信,银联)集成使用
最近比较闲,公司项目更换后台,于是自己来研究微信支付和支付宝支付,把自己学习的过程写下来,以备以后查看。
注:要集成微信支付和支付宝功能,必须要有以下几个配置信息,而这写信息需要公司去微信支付和支付...
《IOS 9  支付宝  and 微信支付的集成》
          支付做好了,只要7行代码,就可进行支付。不需要设置其他东西:举个例子:微信加什么.mm 和设置 other lInk 什么的。...
记录安卓支付(微信&支付宝)
最近比较闲,公司项目更换后台,于是自己来研究微信支付和支付宝支付,把自己学习的过程写下来,以备以后查看。
注:要集成微信支付和支付宝功能,必须要有以下几个配置信息,而这写信息需要公司去微信支付和...
支付宝集成对于一些刚出来的同学来说确实很头疼,因为没有公司的pid,也没有办法测试,但其实只要接触你就会发现,真的是很容易,有个朋友写了篇博客,我感觉是已经很详细了这里直接给出地址:支付宝集成接下来介...
最近比较闲,公司项目更换后台,于是自己来研究微信支付和支付宝支付,把自己学习的过程写下来,以备以后查看。
注:要集成微信支付和支付宝功能,必须要有以下几个配置信息,而这写信息需要公司去微信支付和支付...
一、支付宝移动支付SDK开放平台:/order/productDetail.htm?productId=9654&tabId=4#ps-...
他的最新文章
讲师:汪剑
讲师:刘道宽
您举报文章:
举报原因:
原文地址:
原因补充:
(最多只允许输入30个字)

我要回帖

更多关于 微信支付和支付宝区别 的文章

 

随机推荐