苹果iap支付在哪?付

输入关键字或相关内容进行搜索
IOS平台最新集成了苹果官方提供的应用内支付(In-App Purchase),新的插件是在plus.payment的基础上进行了扩展,但是在使用方法上与原有的支付API的使用流程稍有区别,下面对IAP插件的使用方法进行说明手机用户可以在“设置-&通用-&访问限制-&App 内购买项目”中关闭支付,如果用户关闭了IAP,开发者将获取不到ID为“appleiap”的支付通道。IAP支付对PaymentChannel对象进行了扩展添加了以下几个方法
requestOrder
向Appstore请求有效的商品详情
restoreComplateRequest 向Appstore发送请求获取已经购买商品(非消耗型项目和订阅项目)的支付信息,获取成功以后会返回一个的已购商品收据列表。下面对应用内支付的使用方法进行说明,文中API的参数及使用实例请参考购买商品接口使用方法\n
首先调用plus.payment.getChannels获取支付通道,IAP支付通道的ID为“appleiap”
调用ID为“appleiap”的PaymentChannel对象的requestOrder方法,像Appstore请求有效的商品详情。注意:IAP支付必须在调用payment.request方法之前,调用requestOrder方法,否则调用payment.request将会报错。
调用plus.payment.request方法发起支付请求,传入statement的参数为JSON对象,可以设置如下参数
productid String(必选)要支付的商品的标识(必须是调用requestOrder返回的有效的商品标识)
username String(可选)购买商品用户的用户名
String (可选)购买商品的数量,如果不填写默认为1
&meta charset=&utf-8& /&
&meta name=&viewport& content=&initial-scale=1.0, maximum-scale=1.0, user-scalable=no& /&
&title&Hello H5+&/title&
&script type=&text/javascript&&
var IAPOrders = ['io.dcloud.payTest1', 'io.dcloud.payTest2'];
function plusReady() {
// 获取支付通道
plus.payment.getChannels(function(channels) {
for (var i in channels) {
if (channel[i].id == 'appleiap') {
iapChannel = channel[i];
iapChannel.requestOrder(IAPOrders, function(event) {
for (var index in event) {
var OrderItem = event[index];
outLine(&Title:& + OrderItem.title + &Price:& + OrderItem.price + &Description:& + OrderItem.description + &ProductID:& + OrderItem.productid);
}, function(errormsg) {
outLine(&获取支付通道失败:& + errormsg.message);
}, function(e) {
outLine(&获取支付通道失败:& + e.message);
document.addEventListener('plusready', plusReady, false);
function pay(id) {
plus.payment.request(iapChannel, {
&productid&: id,
&username&: &appusername&,
&quantity&: 2
}, function(result) {
alert(JSON.stringify(result));
}, function(e) {
plus.nativeUI.alert(&更多错误信息请参考支付(Payment)规范文档:http://www.html5plus.org/#specification#/specification/Payment.html&, null, &支付失败:& + e.code);
\n恢复已购项目接口使用方法\n
首先调用plus.payment.getChannels获取支付通道,IAP支付通道的ID为“appleiap”
调用ID为“appleiap”的PaymentChannel对象的restoreComplateRequest方法
\n示例:&!DOCTYPE HTML&
&meta charset=&utf-8& /&
&meta name=&viewport& content=&initial-scale=1.0, maximum-scale=1.0, user-scalable=no& /&
&title&Hello H5+&/title&
&script type=&text/javascript&&
var IAPOrders = ['io.dcloud.payTest1', 'io.dcloud.payTest2'];
function plusReady() {
// 获取支付通道
plus.payment.getChannels(function(channels) {
for (var i in channels) {
if (channel[i].id == 'appleiap') {
iapChannel = channel[i];
iapChannel.requestOrder(IAPOrders, function(event) {
for (var index in event) {
var OrderItem = event[index];
outLine(&Title:& + OrderItem.title + &Price:& + OrderItem.price + &Description:& + OrderItem.description + &ProductID:& + OrderItem.productid);
}, function(errormsg) {
outLine(&获取支付通道失败:& + errormsg.message);
}, function(e) {
outLine(&获取支付通道失败:& + e.message);
document.addEventListener('plusready', plusReady, false);
function getPayedTrances() {
iapChannel.restoreComplateRequest({
&username&: &waipptt&
},function(trancs){
outLine(“获取已经购买项目成功:” + JSON.stringify(trancs));
}, function(errormsg){
outLine(&获取支付通道失败:& + errormsg.message);
它给我返回 返回订单信息失败,http://ask./article/282 咋搞,itunes connect里面已经添加商品了,app也打包出来测试的
这里只说了如果获取产品跟恢复产品,在itune connect 里面如果生成产品没有说,我购买产品成功后,如果返回服务器如何修改状态也没有说。
我在channel里面也是获取不到appleiap,是不是我要打包安装到手机才会出现???
请问下,hbuilder最终是能不能接入IOS 应用内支付的??
苹果不让使用第三方SDK调用IAP支付,导致应用被打回,这种情况怎么处理?今天苹果APPSTORE REVIEW打电话说的。
你做好了苹果内购了吗?
我的目前也报这个错了,怎么解决啊,用的苹果沙盒测试账号支付完全没问题,换为正式账号就报这个错了。
检查一下itunes账号是否有测试的权限,或者商品为非消耗性商品重复购买了
payment_appleiap:-6
在文档中找不到这个报错
打印一下错误的message看下详细的错误信息
iap一直报-100.。。。怎么破@客服
你做好了吗
IAPOrders @ DCloud_SDK_骁骑 大神 这里面参数写什么
看你的支付涉及到什么东西,如果支付的商品时虚拟商品(类似:游戏币,视频等等),就必须用到苹果内支付(人家要收取提成的),如果是实物的话就可以不用苹果支付,微信或者支付宝都可以
谢谢亲,研究一下
支付申请的部分可以参考文档
/XimuYouzi/archive//5401749.html
请问有完整示例么?官方的html5+例子不能用,没明白原理,是跟微信一样需要在微信平台申请接口,然后客户服务器端写接口程序,app端按上面代码即可么?@大神
请问,您那边解决了么
苹果端有支付的话,必须用应用内支付接口么?客户需求是用微信支付,我提交了几个版本都没有通过审核,请问是这个原因么(说明里提到支付)
谁有具体的 苹果内购实例啊,苹果内购没法做出来,无法通过审核,开发苹果的APP就没有意义了啊
云端打包后测试,也还没有获取到appleiap 呢 代码也跟上边例子一样的
在manifest.json中的plus-&distribute-&plugins-&payment节点下添加“appleiap”相关的节点,并提交云端打包。
更多说明参考:
[http://ask./article/71](http://ask./article/71)
[http://ask./article/497](http://ask./article/497)
获取不到 appleiap 的channel呢?其他的都可以得到!
要回复文章请先或iOS内购(IAP,In App Purchases-在APP内部支付),设置及使用 - 简书
iOS内购(IAP,In App Purchases-在APP内部支付),设置及使用
项目中使用到了中间货币(金币)的形式来进行功能使用,模式是使用RMB换成-金币比如:(1RMB = 10金币),所以会集成第三方的支付平台,使用了微信和支付宝的第三方平台过后,发现审核失败,被苹果拒绝,查了一查原因,才是因为苹果对app内的中间币的购买必须走苹果内购(比如冲点券,比如买钻石....)。所以无奈只有使用苹果内购,由于苹果内购的步骤很多,设置的东西太多,所以将这步骤记录下来。
首先设置协议
1.打开itunes Connect,选择协议,税务和银行业务
2.点击Request Contracts(申请合同)下面的,request,点了几个确定和下一步后回到主界面。
Contact info:联系人信息
Bank info:银行信息
Tax info:税务信息
3.首先设置联系人信息,点击Contact info下面的 Set up(设置),点击Add New Contract(增加先的联系方式)
4.填写详情
填写完成后点击save(保存)
5.在下面的所有项目中都选择刚刚填写的信息,选择后点击右下角的done(完成),你可以创建很多联系人,在不同的职务选择不同的联系人。因为我是独立开发,所以我全部填写的我自己。
Senior Management:高管
Financial:财务
Technical:技术支持
Legal:法务
Marketing:市场推广
6.设置银行信息,点击Back info下面的Set up,弹出页面
点击Add Bank Account(添加银行账号)
选择china,后点击next。
填写了CNAPS Code后点击Next
会弹出你的银行卡开户地的信息,确认一下点击next
填写银行卡信息,注意:户主名只能写拼音,比如:李三(Li San)。填完后点击Next
弹出确定信息页面,在下面打钩后点击Save
点击了save后就可以在弹出的页面中选择刚刚填写的卡了。选择后点击Save
7.设置税务信息,点击Tax info下面的Set up,此时联系人信息已经变成可以编辑状态,银行信息为浏览状态。
弹出的界面中,税务分为三种
U.S Tax Forms: 美国税务
Australia Tax Forms:澳大利亚税务
Canada Tax Forms: 加拿大税务
这里我选择的美国税务,就是第一个
弹出第一个选择,点击submit(提交)后,弹出第二个选择
弹出第二个选择,选择后点击submit
弹出第三个页面,填写的资料后点击提交,记得勾选页面上的几个复选框
在提交成功后,状态就变成processing成功
到这里设置的协议就已经设置完了。
创建项目的内购
1.进入到项目的APP信息页面,点击功能,在弹出的页面点击App内购买项目后面的?。
2.在弹出的新对话框中选择你需要哪一种服务,由于我的项目需要兑换成消耗的金币,所以我选择第一个。选择后点击创建。
3.开始填写内购项目信息。填完后点击右上角的存储(所有信息必须填写完整)。
4.点击存储后,内购列表就会有刚刚创建的内购条目。
你app有几个内购级别就需要依次创建几个条目。
添加测试账号,用来测试支付功能
1.点击图中用户和职能
2.点击沙盒测试员,然后点击左边的?按钮。
3.设置好信息点击右上角存储就可以,记住里面的邮箱和密码用于支付的时候登陆Apple id
打开自己的项目,创建一个测试类。代码都有注释和步骤,直接上代码。
1.必须用真机测试。
2.测试的时候必须退出自己的apple ID。弹出页面后登陆沙盒的测试apple id。
#import "TestPayController.h"
// 1.首先导入支付包
#import &StoreKit/StoreKit.h&
// 2.设置代理服务
@interface TestPayController ()&SKPaymentTransactionObserver,SKProductsRequestDelegate&
@implementation TestPayController
- (void)viewDidLoad {
[super viewDidLoad];
self.view.backgroundColor = [UIColor whiteColor];
//3.创建测试按钮
UIButton *testBtn = [[UIButton alloc] initWithFrame:CGRectMake(100, 100, 100, 100)];
testBtn.backgroundColor = [UIColor redColor];
[testBtn addTarget:self action:@selector(clickTestBtnAction) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:testBtn];
// 4.设置支付服务
[[SKPaymentQueue defaultQueue] addTransactionObserver:self];
//点击测试按钮
- (void)clickTestBtnAction
// 5.点击按钮的时候判断app是否允许apple支付
//如果app允许applepay
if ([SKPaymentQueue canMakePayments]) {
NSLog(@"yes");
// 6.请求苹果后台商品
[self getRequestAppleProduct];
NSLog(@"not");
//请求苹果商品
- (void)getRequestAppleProduct
// 7.这里的com.czchat.CZChat01就对应着苹果后台的商品ID,他们是通过这个ID进行联系的。
NSArray *product = [[NSArray alloc] initWithObjects:@"com.czchat.CZChat01",nil];
NSSet *nsset = [NSSet setWithArray:product];
// 8.初始化请求
SKProductsRequest *request = [[SKProductsRequest alloc] initWithProductIdentifiers:nsset];
request.delegate =
// 9.开始请求
[request start];
// 10.接收到产品的返回信息,然后用返回的商品信息进行发起购买请求
- (void) productsRequest:(SKProductsRequest *)request didReceiveResponse:(SKProductsResponse *)response
NSArray *product = response.
//如果服务器没有产品
if([product count] == 0){
NSLog(@"nothing");
SKProduct *requestProduct =
for (SKProduct *pro in product) {
NSLog(@"%@", [pro description]);
NSLog(@"%@", [pro localizedTitle]);
NSLog(@"%@", [pro localizedDescription]);
NSLog(@"%@", [pro price]);
NSLog(@"%@", [pro productIdentifier]);
// 11.如果后台消费条目的ID与我这里需要请求的一样(用于确保订单的正确性)
if([pro.productIdentifier isEqualToString:@"com.czchat.CZChat01"]){
requestProduct =
// 12.发送购买请求
SKPayment *payment = [SKPayment paymentWithProduct:requestProduct];
[[SKPaymentQueue defaultQueue] addPayment:payment];
//请求失败
- (void)request:(SKRequest *)request didFailWithError:(NSError *)error{
NSLog(@"error:%@", error);
//反馈请求的产品信息结束后
- (void)requestDidFinish:(SKRequest *)request{
NSLog(@"信息反馈结束");
// 13.监听购买结果
- (void)paymentQueue:(SKPaymentQueue *)queue updatedTransactions:(NSArray *)transaction{
for(SKPaymentTransaction *tran in transaction){
switch (tran.transactionState) {
case SKPaymentTransactionStatePurchased:
NSLog(@"交易完成");
case SKPaymentTransactionStatePurchasing:
NSLog(@"商品添加进列表");
case SKPaymentTransactionStateRestored:
NSLog(@"已经购买过商品");
[[SKPaymentQueue defaultQueue] finishTransaction:tran];
case SKPaymentTransactionStateFailed:
NSLog(@"交易失败");
[[SKPaymentQueue defaultQueue] finishTransaction:tran];
// 14.交易结束,当交易结束后还要去appstore上验证支付信息是否都正确,只有所有都正确后,我们就可以给用户方法我们的虚拟物品了。
- (void)completeTransaction:(SKPaymentTransaction *)transaction
NSString * str=[[NSString alloc]initWithData:transaction.transactionReceipt encoding:NSUTF8StringEncoding];
NSString *environment=[self environmentForReceipt:str];
NSLog(@"----- 完成交易调用的方法completeTransaction 1--------%@",environment);
// 验证凭据,获取到苹果返回的交易凭据
// appStoreReceiptURL iOS7.0增加的,购买交易完成后,会将凭据存放在该地址
NSURL *receiptURL = [[NSBundle mainBundle] appStoreReceiptURL];
// 从沙盒中获取到购买凭据
NSData *receiptData = [NSData dataWithContentsOfURL:receiptURL];
BASE64 常用的编码方案,通常用于数据传输,以及加密算法的基础算法,传输过程中能够保证数据传输的稳定性
BASE64是可以编码和解码的
NSString *encodeStr = [receiptData base64EncodedStringWithOptions:NSDataBase64EncodingEndLineWithLineFeed];
NSString *sendString = [NSString stringWithFormat:@"{\"receipt-data\" : \"%@\"}", encodeStr];
NSLog(@"_____%@",sendString);
NSURL *StoreURL=
if ([environment isEqualToString:@"environment=Sandbox"]) {
StoreURL= [[NSURL alloc] initWithString: @"https://sandbox./verifyReceipt"];
StoreURL= [[NSURL alloc] initWithString: @"https://buy./verifyReceipt"];
//这个二进制数据由服务器进行验证;zl
NSData *postData = [NSData dataWithBytes:[sendString UTF8String] length:[sendString length]];
NSLog(@"++++++%@",postData);
NSMutableURLRequest *connectionRequest = [NSMutableURLRequest requestWithURL:StoreURL];
[connectionRequest setHTTPMethod:@"POST"];
[connectionRequest setTimeoutInterval:50.0];//120.0---50.0zl
[connectionRequest setCachePolicy:NSURLRequestUseProtocolCachePolicy];
[connectionRequest setHTTPBody:postData];
//开始请求
NSError *error=
NSData *responseData=[NSURLConnection sendSynchronousRequest:connectionRequest returningResponse:nil error:&error];
if (error) {
NSLog(@"验证购买过程中发生错误,错误信息:%@",error.localizedDescription);
NSDictionary *dic=[NSJSONSerialization JSONObjectWithData:responseData options:NSJSONReadingAllowFragments error:nil];
NSLog(@"请求成功后的数据:%@",dic);
//这里可以等待上面请求的数据完成后并且state = 0 验证凭据成功来判断后进入自己服务器逻辑的判断,也可以直接进行服务器逻辑的判断,验证凭据也就是一个安全的问题。楼主这里没有用state = 0 来判断。
[[SKPaymentQueue defaultQueue] finishTransaction: transaction];
NSString *product = transaction.payment.productI
NSLog(@"transaction.payment.productIdentifier++++%@",product);
if ([product length] & 0)
NSArray *tt = [product componentsSeparatedByString:@"."];
NSString *bookid = [tt lastObject];
if([bookid length] & 0)
NSLog(@"打印bookid%@",bookid);
//这里可以做操作吧用户对应的虚拟物品通过自己服务器进行下发操作,或者在这里通过判断得到用户将会得到多少虚拟物品,在后面([self getApplePayDataToServerRequsetWith:transaction];的地方)上传上面自己的服务器。
//此方法为将这一次操作上传给我本地服务器,记得在上传成功过后一定要记得销毁本次操作。调用[[SKPaymentQueue defaultQueue] finishTransaction: transaction];
[self getApplePayDataToServerRequsetWith:transaction];
//结束后一定要销毁
- (void)dealloc
[[SKPaymentQueue defaultQueue] removeTransactionObserver:self];
- (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
-(NSString * )environmentForReceipt:(NSString * )str
str= [str stringByReplacingOccurrencesOfString:@"\r\n" withString:@""];
str = [str stringByReplacingOccurrencesOfString:@"\n" withString:@""];
str = [str stringByReplacingOccurrencesOfString:@"\t" withString:@""];
str=[str stringByReplacingOccurrencesOfString:@" " withString:@""];
str=[str stringByReplacingOccurrencesOfString:@"\"" withString:@""];
NSArray * arr=[str componentsSeparatedByString:@";"];
//存储收据环境的变量
NSString * environment=arr[2];
注意:在需要修改已经上线的内购的时候需要重新创建新的内购条目,然后重新提交。
IOS开发,音乐,旅行,学习。标签:至少1个,最多5个
Controller
* IAP二次验证
* @param pingPayRequest
@RequestMapping("iap_verify")
public BaseResponse iapVerify(@RequestBody PayRequest payRequest){
Map verifyMap =
verifyMap = IAPVerify.getSecondaryVerify(pingPayRequest.getData(),pingPayRequest.getTp());
} catch (Exception e) {
e.printStackTrace();
log.warn("IAP返回:"+verifyMap);
if(null == verifyMap){
return ResponseUtils.returnResponse(ResponseEnum.PING_PAY_REWARD_ERROR);
pingPayRequest.setPingId("");//TODO 苹果返回id
PingPay pingPay_save = pingPayService.save(pingPayRequest);
if(null == pingPay_save){
return ResponseUtils.returnResponse(ResponseEnum.PING_PAY_REWARD_ERROR);
if(null != verifyMap){
return ResponseUtils.returnResponse(ResponseEnum.OK,verifyMap);
return ResponseUtils.returnResponse(ResponseEnum.PUBLICATION_IAP_V_FAIL);
public class IAPVerify {
public static Map getSecondaryVerify(String data,String tp) throws Exception {
Map verifyMap = new HashMap();
if (data != null
&& data.equals("") &&
null !=tp && !tp.equals("")) {
URL dataUrl = new URL("https://buy./verifyReceipt");
if(tp.equals("t")){
dataUrl = new URL("https://sandbox./verifyReceipt");
HttpURLConnection con = (HttpURLConnection) dataUrl.openConnection();
con.setRequestMethod("POST");
con.setRequestProperty("content-type", "text/json");
con.setRequestProperty("Proxy-Connection", "Keep-Alive");
con.setDoOutput(true);
con.setDoInput(true);
OutputStreamWriter out = new OutputStreamWriter(con.getOutputStream());
String str = String.format(Locale.CHINA, "{\"receipt-data\":\"" + data + "\"}");
System.out.println(str);
out.write(str);
out.flush();
out.close();
InputStream is = con.getInputStream();
BufferedReader reader = new BufferedReader(new InputStreamReader(is));
String line =
String result = "";
while ((line = reader.readLine()) != null) {
result += line + "\r\n";
org.json.JSONO
j = new org.json.JSONObject(result);
String returnresult = j.get("status").toString();
if (returnresult.equals("0")) {
verifyMap.put("status", 0);
verifyMap.put("receipt", j.get("receipt"));
}else if (returnresult.equals("21002")) {
verifyMap.put("status", -6L);
verifyMap.put("receipt", j.get("receipt"));
verifyMap.put("status", Long.valueOf(returnresult));
verifyMap.put("receipt", j.get("receipt"));
return verifyM
} catch (Exception e) {
System.out.println("接收返回类型:" + e.getMessage());
0 收藏&&|&&1
你可能感兴趣的文章
1 收藏,372
1 收藏,1.2k
9 收藏,1.2k
分享到微博?
明天提醒我
我要该,理由是:

我要回帖

更多关于 苹果iap支付消费记录 的文章

 

随机推荐