【问题标题】:How can i send receipt data using Swift to Node.js server如何使用 Swift 将收据数据发送到 Node.js 服务器
【发布时间】:2019-06-14 18:42:37
【问题描述】:

我目前正在尝试验证IAP iOS 中用户订阅的收据。首先,我发出一个发布请求,从当前存储在Bundle.main.appStoreReceiptURL 的收据中获取收据数据。我可以在我的服务器中使用此收据数据来验证收据,该收据运行良好。但是,此收据数据字符串在Node 中硬编码,特定于某个用户。根据要验证的任何用户,我如何能够将此收据字符串发送到我的服务器以获取任何收据。这是我的 Swift 和服务器代码。苹果在文档中说

要检索回执数据,使用 NSBundle 的 appStoreReceiptURL 方法定位应用的回执,然后读取整个文件。将此数据发送到您的服务器 - 与与您的服务器的所有交互一样,详细信息由您负责。

我想获取收据数据并将其发送到我的服务器。

func getReceipt() {
    if let receiptUrl = receiptUrl {
        do {
            let purchaseReceipt = try Data(contentsOf: receiptUrl)
            self.validatePurchaseReceipt(pReceiptData: purchaseReceipt)
        } catch {
            let receiptRefreshRequest = SKReceiptRefreshRequest(receiptProperties: nil)
            receiptRefreshRequest.delegate = self
            receiptRefreshRequest.start()
        }
    }
}

func validatePurchaseReceipt(pReceiptData: Data) {
    let base64encodedReceipt = pReceiptData.base64EncodedString()
    let secretKey = "myAppstoreConnectSecretKey"
    let requestReceiptDict = ["receipt-data": base64encodedReceipt, "password": secretKey]
    guard JSONSerialization.isValidJSONObject(requestReceiptDict) else { return }
    do {
        let data = try JSONSerialization.data(withJSONObject: requestReceiptDict)
        let validationString = "https://sandbox.itunes.apple.com/verifyReceipt"
        guard let validationUrl = URL(string: validationString) else { return }
        let session = URLSession(configuration: .default)
        var request = URLRequest(url: validationUrl, cachePolicy: .reloadIgnoringLocalCacheData)
        request.httpMethod = "POST"
        let task = session.uploadTask(with:request, from: data) { (data, response, error) in
            guard let data = data, error == nil else { return }
            do {
                let purchaseReceiptJSON = try JSONSerialization.jsonObject(with: data, options: .allowFragments)
                print("Success retrieved json:\(purchaseReceiptJSON)")
            } catch let error {
                print(error)
            }
        }
        task.resume()
    } catch let error {
        print(error)
    }
}

这是我的服务器代码

const express = require('express');
const requirePromise = require('request-promise');
const app = express();

let verificationURL = 'https://sandbox.itunes.apple.com/verifyReceipt';
let secretKey = 'myAppstoreConnectSecretKey';
let receiptData = 'MIIntgYJKoZIhvcNAQcCoIInpzCCJ6MCAQExCzAJBgUrDgMCGgUAMIIXVwYJKoZIhvcNAQcBoIIXSASCFetc'
const options = {
  url: verificationURL,
    method: 'POST',
    headers: {
    'User-Agent': 'Request-Promise',
        'Content-Type': 'application/x-www-form-urlencoded',
    },
    json: true
};

options.form = JSON.stringify({
    'receipt-data': receiptData,
    'password': secretKey
});

requirePromise(options).then((resData) => {
    console.log(resData);
    return resData;
}).catch(function (error) {
    console.log(error);
});

【问题讨论】:

    标签: javascript ios node.js swift in-app-purchase


    【解决方案1】:

    如果您要使用服务器来验证收据(您应该这样做),那么 validatePurchaseReceipt 方法应该调用您的服务器,而不是 /verifyReceipt 端点。收据数据被传递到您的服务器,就像您使用 requestReceiptDict 一样。

    另外,secretKey 应该在您的服务器上进行硬编码 - 而不是在客户端的任何位置。

    这是一个类似的问题:https://stackoverflow.com/a/54261816/3166209

    【讨论】:

    • 非常感谢。这更有意义
    猜你喜欢
    • 1970-01-01
    • 2018-04-17
    • 2021-03-20
    • 2021-09-05
    • 2012-12-31
    • 1970-01-01
    • 2020-09-03
    • 2018-06-14
    • 2012-04-03
    相关资源
    最近更新 更多