ios开发者账号

2016-09-14  本文已影响33人  coder_hong

真机调试

Snip20160913_1.png Snip20160913_2.png Snip20160913_18.png Snip20160913_2.png Snip20160913_20.png Snip20160913_22.png Snip20160913_21.png Snip20160913_23.png Snip20160913_24.png Snip20160913_3.png Snip20160913_4.png Snip20160913_5.png Snip20160913_7.png

)

Snip20160913_8.png Snip20160913_9.png Snip20160913_11.png Snip20160913_12.png Snip20160913_13.png Snip20160913_15.png Snip20160913_16.png

测试打包

Snip20160913_25.png Snip20160913_27.png Snip20160913_29.png Snip20160913_30.png Snip20160913_31.png Snip20160913_32.png Snip20160913_33.png

发布APP

Snip20160914_34.png Snip20160914_35.png Snip20160914_36.png Snip20160914_37.png Snip20160914_38.png Snip20160914_41.png Snip20160914_42.png Snip20160914_43.png Snip20160914_45.png Snip20160914_46.png Snip20160914_48.png Snip20160914_49.png Snip20160914_50.png
Snip20160914_51.png
Snip20160914_52.png
Snip20160914_53.png
Snip20160914_54.png
Snip20160914_55.png
Snip20160914_56.png
Snip20160914_58.png
Snip20160914_59.png
Snip20160914_60.png
Snip20160914_62.png

内购(In-App Puchase)

简单说就是用户可以在app内购买产品
用户在App中购买产品有两种方式:

内购 方式 要求 盈利
第三方支付(微信、支付宝) 用户购买的物品和应用没有关系 想支付宝、微信交的钱比较少
App内购 用户购买的物品和应用本身有关系 和苹果 3:7

注意:如果程序内部集成了内购(发布信息填写NO, 苹果不允许上架)

内购App的集成

说一下内购的整个流程

// 向服务器请求要销售的商品productID 这里我们用plist模拟网络请求
    NSString *path = [[NSBundle mainBundle] pathForResource:@"pruducts.plist" ofType:nil];
    // 获得所有的产品数组
    NSArray *products = [NSArray arrayWithContentsOfFile:path];
    
#warning 注意这里用的是KVC
    // 利用KVC获取chanpinID数组
    NSArray *productIDs = [products valueForKeyPath:@"productID"];
    NSSet *set = [NSSet setWithArray:productIDs];
    
    // 创建一个商品请求对象
    SKProductsRequest *request = [[SKProductsRequest alloc] initWithProductIdentifiers:set];
    
    // 设置代理 遵守协议 `SKProductsRequestDelegate`
    request.delegate = self;
    
    // 开始请求
    [request start];
}


#pragma mark - SKProductsRequestDelegate
/**
 *  回调 response.products 对应的是可以销售的所有的商品对象 SKProduct
 */
- (void)productsRequest:(SKProductsRequest *)request didReceiveResponse:(SKProductsResponse *)response
{
    
    NSLog(@"%@", response.products);
    
    /*
     NSSortConcurrent  并发 速度快
     NSSortStable 线程安全
     */
    // 对数组进行排序
    [response.products sortedArrayWithOptions:NSSortConcurrent usingComparator:^NSComparisonResult(SKProduct *product1, SKProduct *product2) {
        
        return [product1.price compare:product2.price];
    }];
    
    // 拿到所有可以销售的产品 接下来tableView展示
    self.products = response.products;
// 用户选择购买之后是需要创建一个"票据"的
SKPayment *payment = [SKPayment paymentWithProduct:product];
// 将票据加入到交易队列中(单例)
 [[SKPaymentQueue defaultQueue] addPayment:payment];
// 给交易队列添加一个观察者 
[[SKPaymentQueue defaultQueue] addTransactionObserver:self];
#pragma 通过观察者回调方法,监听用户是否付钱成功
/**
 *  transactions  因为有可能用户点击购买的时候双击 容易生多个票据 但是在真是开发中我们一般点击购买之后立即不能再点击,防止一次购买多次
 *
 *  @param SKPaymentTransaction     交易
 *  @param transactions <#transactions description#>
 */
- (void)paymentQueue:(SKPaymentQueue *)queue updatedTransactions:(NSArray<SKPaymentTransaction *> *)transactions
{
    
    /**
     *  注意:如果是购买成功、恢复购买、购买失败, 必须将交易从交易队列中移除
     */
    for (SKPaymentTransaction *transaction in transactions) {
        
        // 交易装态
        int statu = transaction.transactionState;
        switch (statu) {
            case SKPaymentTransactionStatePurchasing:
                NSLog(@"用户正在购买商品");
                // 将交易从交易队列中移除
                [queue finishTransaction:transaction];
                break;
                
            case SKPaymentTransactionStatePurchased:
                NSLog(@"用户正已经付钱, 购买成功, 给用户对应的商品");
                // 将交易从交易队列中移除
                [queue finishTransaction:transaction];
                break;
                
            case SKPaymentTransactionStateFailed:
                NSLog(@"用户失败, 没有付钱");
                // 将交易从交易队列中移除
                [queue finishTransaction:transaction];
                break;
            // 一下两种情况不经常时候
            case SKPaymentTransactionStateRestored:
                NSLog(@"恢复购买");
                break;
                
            case SKPaymentTransactionStateDeferred: // ios8.0才有的
                NSLog(@"用户最终状态未决定");
                break;
                
            default:
                break;
        }
    }
}

总结需要注意是事项:
1.在`SKPaymentTransactionObserver`,观察返回交易装态的时候,不管交易是失败、成功都需要将交易移除交易队列
2.做内购必须是明确的AppID
3.在开发者账号创建程序填写内购商品的ID时候,请保持一定格式 例如,doudizhu.jibi
4.如果用户的购买的是`非消耗品`的内购商品之后,可以让服务器更爱用户信息.否者用户下次点击购买还是会弹出用购买流程,但是不会再次支付,虽然不造成再次购买,但是用户体验非常不好

广告

注意:首先在Build phases->导入iAD.Framework框架,否者程序运行崩溃

Snip20160916_2.png
/**
 *  监听接受到广告
 */
- (void)bannerViewDidLoadAd:(ADBannerView *)banner
{
    
    self.bannerBottomCT.constant = 0;
    [UIView animateWithDuration:0.6 animations:^{
        [self.view layoutIfNeeded];
    }];
}
上一篇下一篇

猜你喜欢

热点阅读