#django #session #integration #payment
Вопрос:
Я создал сайт электронной коммерции. Теперь я хочу интегрировать способ оплаты. Добавив SSLCommerce на мой сайт, вы позаботитесь обо всех способах оплаты в Бангладеш. Но я не знаю, как я могу добавить его в свое приложение Django. Пожалуйста, помогите!
Они сказали что-то еще. Но я этого не понял. Вот их репозиторий на github https://github.com/sslcommerz/SSLCommerz-Python?fbclid=IwAR0KkEH3H-AOwaWneQy0POGkTw6O3vvL9NiRM4amflyQEt54_W1g1rgYB48
Комментарии:
1. Как насчет установки pip sslcommerz-lib
Ответ №1:
Существует библиотека-оболочка под названием «sslcommerz-lib». Чтобы использовать его, вам сначала понадобится учетная запись в их безопасной среде. После завершения регистрации соберите свои учетные данные пользователя по электронной почте.
- Сначала установите пакет с
pip install sslcommerz-lib
- Импортируйте библиотеку в свой модуль
from sslcommerz_lib import SSLCOMMERZ
- Создайте экземпляр объекта
SSLCOMMERZ
класса с учетными данными пользователя песочницы
sslcz = SSLCOMMERZ({ 'store_id': <your_store_id>, 'store_pass': <your_password>, 'issandbox': True })
- Создайте словарь с некоторой информацией о транзакции и клиенте. В реальном приложении большая часть этих данных будет собрана из входных данных пользователя.
data = {
'total_amount': "100.26",
'currency': "BDT",
'tran_id': "tran_12345",
'success_url': "http://127.0.0.1:8000/payment-successful", # if transaction is succesful, user will be redirected here
'fail_url': "http://127.0.0.1:8000/payment-failed", # if transaction is failed, user will be redirected here
'cancel_url': "http://127.0.0.1:8000/payment-cancelled", # after user cancels the transaction, will be redirected here
'emi_option': "0",
'cus_name': "test",
'cus_email': "test@test.com",
'cus_phone': "01700000000",
'cus_add1': "customer address",
'cus_city': "Dhaka",
'cus_country': "Bangladesh",
'shipping_method': "NO",
'multi_card_name': "",
'num_of_item': 1,
'product_name': "Test",
'product_category': "Test Category",
'product_profile': "general",
}
- Получите ответ api
response = sslcz.createSession(post_body)
- После выполнения таких задач, как обновление базы данных и т. Д., Перенаправьте пользователя на «GatewayPageURL» Из ответа, который мы получили ранее —
from django.shortcuts import redirect
return redirect(response['GatewayPageURL'])
Комментарии:
1. здесь вы выполнили создание сеанса транзакции с помощью API сеанса SSLCommerz, после этого мы можем создать прослушиватель IPN (Уведомления о мгновенных платежах) для получения уведомления об успешном платеже, а затем SSLCommerz перенаправит клиента на ваш URL обратного вызова
Ответ №2:
SSLCOMMERZ — Python (sslcommerz-lib) Примечание: Если вы используете эту оболочку в нашей среде песочницы, значение issandbox равно true, а значение live issandbox равно false. (Подробности: Тестовая Или Изолированная Учетная Запись).
settings = { 'store_id': 'testbox', 'store_pass': 'qwerty', 'issandbox': True }
sslcommerz = SSLCOMMERZ(settings)
Установка
pip install sslcommerz-lib
Ключи аутентификации
Вы можете найти свой идентификатор хранилища и пароль хранилища на странице документации по API. Создайте учетную запись на SSLCOMMERZ, войдите в систему и перейдите по этой ссылке: https://developer.sslcommerz.com/registration/
Использование Создайте сеанс запроса на первоначальный платеж
from sslcommerz_lib import SSLCOMMERZ
settings = { 'store_id': 'testbox', 'store_pass': 'qwerty', 'issandbox': True }
sslcz = SSLCOMMERZ(settings)
post_body = {}
post_body['total_amount'] = 100.26
post_body['currency'] = "BDT"
post_body['tran_id'] = "12345"
post_body['success_url'] = "your success url"
post_body['fail_url'] = "your fail url"
post_body['cancel_url'] = "your cancel url"
post_body['emi_option'] = 0
post_body['cus_name'] = "test"
post_body['cus_email'] = "test@test.com"
post_body['cus_phone'] = "01700000000"
post_body['cus_add1'] = "customer address"
post_body['cus_city'] = "Dhaka"
post_body['cus_country'] = "Bangladesh"
post_body['shipping_method'] = "NO"
post_body['multi_card_name'] = ""
post_body['num_of_item'] = 1
post_body['product_name'] = "Test"
post_body['product_category'] = "Test Category"
post_body['product_profile'] = "general"
response = sslcz.createSession(post_body) # API response
print(response)
# Need to redirect user to response['GatewayPageURL']
Оплата Vaidate с помощью IPN
от sslcommerz_lib импорт SSLCOMMERZ
settings = { 'store_id': 'test_testemi', 'store_pass': 'test_testemi@ssl', 'issandbox': True }
sslcz = SSLCOMMERZ(settings)
post_body = {}
post_body['tran_id'] = '5E121A0D01F92'
post_body['val_id'] = '200105225826116qFnATY9sHIwo'
post_body['amount'] = "10.00"
post_body['card_type'] = "VISA-Dutch Bangla"
post_body['store_amount'] = "9.75"
post_body['card_no'] = "418117XXXXXX6675"
post_body['bank_tran_id'] = "200105225825DBgSoRGLvczhFjj"
post_body['status'] = "VALID"
post_body['tran_date'] = "2020-01-05 22:58:21"
post_body['currency'] = "BDT"
post_body['card_issuer'] = "TRUST BANK, LTD."
post_body['card_brand'] = "VISA"
post_body['card_issuer_country'] = "Bangladesh"
post_body['card_issuer_country_code'] = "BD"
post_body['store_id'] = "test_testemi"
post_body['verify_sign'] = "d42fab70ae0bcbda5280e7baffef60b0"
post_body['verify_key'] = "amount,bank_tran_id,base_fair,card_brand,card_issuer,card_issuer_country,card_issuer_country_code,card_no,card_type,currency,currency_amount,currency_rate,currency_type,risk_level,risk_title,status,store_amount,store_id,tran_date,tran_id,val_id,value_a,value_b,value_c,value_d"
post_body['verify_sign_sha2'] = "02c0417ff467c109006382d56eedccecd68382e47245266e7b47abbb3d43976e"
post_body['currency_type'] = "BDT"
post_body['currency_amount'] = "10.00"
post_body['currency_rate'] = "1.0000"
post_body['base_fair'] = "0.00"
post_body['value_a'] = ""
post_body['value_b'] = ""
post_body['value_c'] = ""
post_body['value_d'] = ""
post_body['risk_level'] = "0"
post_body['risk_title'] = "Safe"
if sslcz.hash_validate_ipn(post_body):
response = sslcz.validationTransactionOrder(post_body['val_id'])
print(response)
else:
print("Hash validation failed")
Получите статус или сведения о запросе на оплату с помощью sessionkey
from sslcommerz_lib import SSLCOMMERZ
settings = { 'store_id': 'testbox', 'store_pass': 'qwerty', 'issandbox': True }
sslcz = SSLCOMMERZ(settings)
sessionkey = 'A8EF93B75B8107E4F36049E80B4F9149'
response = sslcz.transaction_query_session(sessionkey)
print(response)
Получить статус или реквизиты Платежного запроса с помощью tranid
from sslcommerz_lib import SSLCOMMERZ
settings = { 'store_id': 'testbox', 'store_pass': 'qwerty', 'issandbox': True }
sslcz = SSLCOMMERZ(settings)
tranid = '59C2A4F6432F8'
response = sslcz.transaction_query_tranid(tranid)
print(response)