Как реализовать в приложении покупки, используя Cordova плагин?
Пожалуйста, скажите мне, как реализовать in-app-purchase с помощью плагина Cordova.
Я разрабатываю приложение для Android, используя Cordova. Есть некоторые плагины для покупки в приложении, но я решил использовать Cordova Purchase Plugin.
Я сделал несколько установок вдоль README.md из покупки в приложении для PhoneGap / Cordova iOS и Android . В результате я смог вызвать плагин, используядемо плагина покупки для Cordova с моей небольшой модификацией. (Смотрите следующее, Это часть кода.)
app.initStore = function() {
if (!window.store) {
log('Store not available');
return;
}
// Enable maximum logging level
store.verbosity = store.DEBUG;
// Enable remote receipt validation
// store.validator = "https://api.fovea.cc:1982/check-purchase";
// Inform the store of your products
log('registerProducts');
store.register({
id: 'myProductA',
alias: 'myProductA',
type: store.CONSUMABLE
});
// When any product gets updated, refresh the HTML.
store.when("product").updated(function (p) {
console.info("app.renderIAP is called");
app.renderIAP(p);
});
// Log all errors
store.error(function(error) {
log('ERROR ' + error.code + ': ' + error.message);
});
// When purchase of an extra life is approved,
// deliver it... by displaying logs in the console.
store.when("myProductA").approved(function (order) {
log("You got a ProductA");
order.finish();
});
// When the store is ready (i.e. all products are loaded and in their "final"
// state), we hide the "loading" indicator.
//
// Note that the "ready" function will be called immediately if the store
// is already ready.
store.ready(function() {
var el = document.getElementById("loading-indicator");
console.info(el + "ready is called")
if (el)
el.style.display = 'none';
});
// When store is ready, activate the "refresh" button;
store.ready(function() {
var el = document.getElementById('refresh-button');
console.info(el + "ready is called and refresh-button show?");
if (el) {
el.style.display = 'block';
el.onclick = function(ev) {
store.refresh();
};
}
});
// Refresh the store.
//
// This will contact the server to check all registered products
// validity and ownership status.
//
// It's fine to do this only at application startup, as it could be
// pretty expensive.
log('refresh');
store.refresh();
};
Он не показал 'магазин недоступен', который отображается, когда плагин недоступен, показать 'registerProducts' и ' обновить.' (*Конечно, я добавил "myProductA"к продуктам в приложении на консоли разработчика Google Play.)
Но я заметил, что функция ниже не вызывается.store.when("product").updated(function (p)
А также я не мог понять, какой параметр должен заполнить его, поэтому я прокомментировал ниже. (*Я действительно удалил комментарий, но он все еще не работающий.)
store.validator = "https://api.fovea.cc:1982/check-purchase";
Я думаю, что эти вещи делают что-то неправильным. Я не знаю, что на мне лежит, поэтому мой вопрос не совсем ясен. Мне нужны какие-то подсказки, чтобы решить эту проблему... или мне не следовало реализовать в приложении покупки, используя плагин Cordova?
Пожалуйста, дайте мне вашу руку.
(я не бегло говорю по-английски, поэтому прошу прощения за любую путаницу.)
2 ответа:
Вы можете попробовать этот плагин в качестве альтернативы: https://github.com/AlexDisler/cordova-plugin-inapppurchase
Вот пример загрузки продуктов и совершения покупки:
inAppPurchase .buy('com.yourapp.consumable_prod1') .then(function (data) { // ...then mark it as consumed: return inAppPurchase.consume(data.productType, data.receipt, data.signature); }) .then(function () { console.log('product was successfully consumed!'); }) .catch(function (err) { console.log(err); });
Он поддерживает как Android, так и iOS.
Шаг для интеграции биллинга In-App в приложение Phone-gap.
1>> клонируйте этот проект на своем ПК по этой ссылке In-App billing Library
2 > > с помощью CMD перейдите в корневой каталог приложения phonegap
3>> после выполнения этой команды Кордова плагин добавить /путь/к/вашему/клонировать проект-переменная BILLING_KEY="QWINMERR..........RIGR "
Примечания: для BILLING_KEY перейдите в консоль разработчика, затем откройте приложение и перейдите в раздел Service& APIs для получения дополнительной информации информация смотрите прилагаемые скриншоты