Эта библиотека должна помочь вам в работе с интерфейсом WebMoney Merchant: https://wiki.webmoney.ru/projects/webmoney/wiki/Web_Merchant_Interface
-
Устанавливаем Composer:
curl -sS https://getcomposer.org/installer | php -
Добавляем WebMoney Merchant в зависимость:
php composer.phar require vskut/webmoney-merchant:*@dev
Пример: https://github.com/VSKut/WebMoney-Merchant/blob/master/examples/form.php
Подключаем класс любым доступным образом
Native:
require_once('../src/WMMerchantForm.class.php');Composer:
require_once(__DIR__.'/vendor/autoload.php');Используем пространство имён
use VSKut\WebMoney_Merchant\WMMerchantForm;Передаём кошелёк продавца
$merchantForm = new WMMerchantForm('R000000000000');Устанавливаем сумму для оплаты
$merchantForm->setAmount(123.45);Устанавливаем описание платежа
$merchantForm->setDescription('Это описание платежа');Устанавливаем номер платежа
$merchantForm->setPaymentNumber(12);Устанавливаем дополнительные параметры (не обязательно)
$merchantForm->setDataCustom(array(
'USER_ID' => 15,
'ITEM_ID' => 24,
'CATEGORY_ID' => 1,
));Передаём RESULT Url посредством формы (не обязательно)
Для использования своих URL через форму не забудьте выставить в настройках кошелька галочку на "Позволять использовать URL, передаваемые в форме"
$merchantForm->setResultUrl('http://vskut.ru/result.php');Передаём SUCCESS Url и тип вызова посредством формы (не обязательно)
Для использования своих URL через форму не забудьте выставить в настройках кошелька галочку на "Позволять использовать URL, передаваемые в форме"
$merchantForm->setSuccessUrl('http://vskut.ru/success.php', 2);
/*
* * Типы вызова:
* 0 - GET
* 1 - POST
* 2 - URL
* */Передаём FAIL Url и тип вызова посредством формы (не обязательно)
Для использования своих URL через форму не забудьте выставить в настройках кошелька галочку на "Позволять использовать URL, передаваемые в форме"
$merchantForm->setFailUrl('http://vskut.ru/fail.php', 2);
/*
* * Типы вызова:
* 0 - GET
* 1 - POST
* 2 - URL
* */В конец формы добавляем JS скрипт с автоматической отправкой формы (не обязательно)
$merchantForm->setAutoSendForm();Получаем HTML сгенерированной формы
$html = $merchantForm->getHTML();Just do it :)
echo $html;Пример: https://github.com/VSKut/WebMoney-Merchant/blob/master/examples/result.php
Подключаем класс любым доступным образом
Native:
require_once('../src/WMMerchantCallback.class.php');Composer:
require_once(__DIR__.'/vendor/autoload.php');Используем пространство имён
use VSKut\WebMoney_Merchant\WMMerchantCallback;Передаём кошелёк продавца, секретный ключ, POST данные
$merchantCallback = new WMMerchantCallback('R000000000000', '000000000000000', $_POST);Устанавливаем стоимость (не обязательно)
Если не установлено, то стоимость проверяться не будет и скрипт пропустит все платежи вне зависимости от суммы
$merchantCallback->setAmount(123.45);Проверяем данные запроса на валидность
if ($merchantCallback->isInvalidData()) {
echo $merchantCallback->getError();
exit();
}Проверяем тип запроса (pre-request или finally-request)
if ($merchantCallback->isPreRequest()) {
/*
* * Пришёл предварительный запрос, деньги от пользователя ещё не переведены
* 1) Если нужно, то выполняем любые иные проверки
* */
$array = $merchantCallback->getData();
$array = $merchantCallback->getDataCustom();
/*
* 2) Возвращаем успешный ответ "YES" и тем самым разрешаем выполнить запрос
* */
echo 'YES';
} else {
/*
* * Пришёл окончательный запрос, деньги уже у нас на кошельке
* 1) Если нужно, то выполняем любые иные проверки
* */
$array = $merchantCallback->getData();
$array = $merchantCallback->getDataCustom();
/*
* 2) Производим выдачу товара
* */
}- Переходим на https://merchant.webmoney.ru
- Проходим авторизацию
- Идём в настройки https://merchant.webmoney.ru/conf/purses.asp
- Напротив нужного кошелька выбираем
настроить
- Указываем
тестовыйлиборабочийрежим работы - Указываем торговое имя
- Указываем
Secret Key - Указываем
Result URL - Выбираем check-box [x]
Передавать параметры в предварительном запросе - Указываем
Success URLи метод его вызова - Указываем
Fail URLи метод его вызова - При необходимости выбираем check-box [x]
Позволять использовать URL, передаваемые в форме - Выбираем в
Метод формирования контрольной подписи-SHA256 - Сохраняем :)