Редактировать: https://github.com/agiliq/merchant/blob/master/billing/gateways/authorize_net_gateway.py
выглядит довольно красиво, еще не пробовал.
Редактировать: [Для следующего моего проекта, который использует authorize.net, я собираюсь подробно рассмотреть: http://github.com/zen4ever/django-authorizenet Это выглядит довольно красиво. Я не думаю, что он поддерживает повторяющиеся платежи.]
В прошлом я делал маленькие одноразовые реализации.
Для простой публикации на платежном шлюзе AIM вы можете использовать что-то вроде этого:
URL = 'https://test.authorize.net/gateway/transact.dll'
API = {'x_login':'XXX',
'x_tran_key':'XXX', 'x_method':'CC', 'x_type':'AUTH_ONLY',
'x_delim_data':'TRUE', 'x_duplicate_window':'10', 'x_delim_char':'|',
'x_relay_response':'FALSE', 'x_version':'3.1'}
def call_auth(amount, card_num, exp_date, card_code, zip_code, request_ip=None):
'''Call authorize.net and get a result dict back'''
import urllib2, urllib
payment_post = API
payment_post['x_amount'] = amount
payment_post['x_card_num'] = card_num
payment_post['x_exp_date'] = exp_date
payment_post['x_card_code'] = card_code
payment_post['x_zip'] = zip_code
payment_request = urllib2.Request(URL, urllib.urlencode(payment_post))
r = urllib2.urlopen(payment_request).read()
return r
def call_capture(trans_id): # r.split('|')[6] we get back from the first call, trans_id
capture_post = API
capture_post['x_type'] = 'PRIOR_AUTH_CAPTURE'
capture_post['x_trans_id'] = trans_id
capture_request = urllib2.Request(URL, urllib.urlencode(capture_post))
r = urllib2.urlopen(capture_request).read()
return r
Для авторизации вы делаете что-то вроде:
r = authorize.call_auth(
unicode(decimal_total),
request.POST.get('card_num'),
request.POST.get('exp_date'),
request.POST.get('card_code'),
request.POST.get('zip_code') if request.POST.get('zip_code') else address.zip_code,
)
if r.split('|')[0] == '1':
# it's good, we have authorized the card...
else:
error = "%s Please try again." % (r.split('|')[3])
тогда мы можем захватить:
r = authorize.call_capture(trans_id) # r.split('|')[6] in first response..
if r.split('|')[0] == '1':
# we captured it.
else:
error = r.split('|')[3]
Есть больше опций, способов запроса, нюансов в ответе на синтаксический анализ ... Я предполагаю, что b / c A
в AIM
означает advanced
, что доступны все опции authorize.net.
http://developer.authorize.net/guides/AIM/
Я знаю, что ваш вопрос в том, какая библиотека лучше ... ну, может быть, будет проще всего реализовать свой собственный небольшой специальный запрос и ответ для ваших конкретных требований, а не пытаться пробежать через API поверх API.