Braintree API在CreateCard上抛出Braintree. exceptions . authoriza
本文关键字:Braintree exceptions authoriza API CreateCard | 更新日期: 2023-09-27 18:06:06
我使用的是ASP。.NET MVC 4, .NET Braintree Payments API和Braintree.js.
这是我为Braintree构建的一个简单的包装器:
public class PaymentBL
{
private static BraintreeGateway _braintreeGateway = new BraintreeGateway
{
Environment = Braintree.Environment.SANDBOX,
MerchantId = "xxxxxxx",
PublicKey = "xxxxxxxxxxxx",
PrivateKey = "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
};
public Result<Transaction> ChargeCardOnce(decimal amount, string cardholderName, string cardNumber, string expiration,
string cvv)
{
TransactionCreditCardRequest creditCardRequest = new TransactionCreditCardRequest();
creditCardRequest.CardholderName = cardholderName;
creditCardRequest.Number = cardNumber;
creditCardRequest.ExpirationDate = expiration;
creditCardRequest.CVV = cvv;
TransactionOptionsRequest optionsRequest = new TransactionOptionsRequest();
optionsRequest.SubmitForSettlement = true;
TransactionRequest transactionRequest = new TransactionRequest();
transactionRequest.Amount = amount;
transactionRequest.CreditCard = creditCardRequest;
transactionRequest.Options = optionsRequest;
return _braintreeGateway.Transaction.Sale(transactionRequest);
}
/// <summary>
/// Stores a credit card in the Braintree vault. In some cases, will put a $1 temporary charge
/// on the credit card that will come off a few days later.
///
/// From BrainTree: Regardless of card type, any instance where a $1 authorization returns a successful result,
/// we immediately follow-up with an automatic void request to ensure that the transaction will fall off
/// of the cardholder's statement as soon as possible.
/// </summary>
public Result<CreditCard> StoreCustomer(int customerId, string cardholderName, string cardNumber, string expiration, string cvv)
{
//CreditCardAddressRequest addressRequest = new CreditCardAddressRequest();
//addressRequest.PostalCode = postalCode;
CreditCardOptionsRequest optionsRequest = new CreditCardOptionsRequest();
optionsRequest.VerifyCard = true;
optionsRequest.VerificationMerchantAccountId = _braintreeGateway.MerchantId;
CreditCardRequest creditCard = new CreditCardRequest();
creditCard.CustomerId = customerId.ToString();
creditCard.Token = customerId.ToString(); // Use same token to ensure overwrite
creditCard.CardholderName = cardholderName;
creditCard.Number = cardNumber;
creditCard.ExpirationDate = expiration;
creditCard.CVV = cvv;
creditCard.Options = optionsRequest;
return _braintreeGateway.CreditCard.Create(creditCard);
}
/// <summary>
/// Search BrainTree vault to retrieve credit card
/// </summary>
/// <param name="customerId"></param>
public CreditCard GetCreditCardOnFile(int customerId)
{
Customer customer = null;
try
{
customer = _braintreeGateway.Customer.Find(customerId.ToString());
}
catch (Braintree.Exceptions.NotFoundException)
{
return null;
}
if (customer.CreditCards == null || customer.CreditCards.Length == 0)
{
return null;
}
if (customer.CreditCards.Length >= 2)
{
throw new Exception(string.Format("Customer {0} has {1} credit cards",
customerId, customer.CreditCards.Length));
}
return customer.CreditCards[0];
}
}
当我调用这个方法时,它工作了:
Result<Transaction> result = paymentBL.ChargeCardOnce(
2.34m
, formCollection["name"]
, formCollection["number"]
, formCollection["exp"]
, formCollection["cvv"]
);
随后,我可以在Braintree仪表板中查看完成的测试事务。因此,我知道来自Braintree.js的加密表单值正确到达我的控制器操作,并且我的密钥和商家帐户id都正确设置。
当我用下面的StoreCustomer调用替换上面的ChargeCardOnce调用时,我在return _braintreeGateway.CreditCard.Create(creditCard);
Result<CreditCard> result = paymentBL.StoreCustomer(
systemHost.Customer.CustomerId
, formCollection["name"]
, formCollection["number"]
, formCollection["exp"]
, formCollection["cvv"]
);
来自Braintree的支持:"您可以在沙箱中创建客户以及信用卡,因为它被构建为准确地反映生产环境的样子。"
有人也有过这样的经历吗?我指的是Braintree对这个问题的支持,但如果有人在SO上看到这个并知道解决方案或变通方法,我会松一口气。
我在Braintree工作。看起来我们已经给了你问题的答案,但我也会在这里回答任何将来有同样问题的人。
在这种情况下,问题是:
optionsRequest.VerificationMerchantAccountId = _braintreeGateway.MerchantId;
您的商户ID标识您的支付网关账户,而您的商户账户ID标识您要用于验证的银行账户。我们支持中心的一篇文章解释了两者的区别:
MerchantAccountId
使用Braintree,您可以拥有多个商户所有帐户都通过同一网关帐户进行处理。这意味着你可以有多个地点,多个企业,多种货币等所有设置和处理在一个单一的帐户。这使得跟踪所有处理过程变得容易通过统一的报告和访问,甚至可以为您节省资金。
您可以在您的网关中找到所有商家帐户的id请按照以下步骤处理:
登录您的帐号
将鼠标悬停在您的帐户名称上点击"处理"
滚动到页面底部
其中AuthorizationException
为HTTP状态码403 Forbidden。这意味着服务器正在拒绝您的请求,因为您没有访问资源的权限(即使您可能已通过身份验证)。
由于您指定的ID(因为它根本不是商家帐户ID)的用户没有可用的商家帐户,因此您获得AuthorizationException
。
如果,通常情况下,你的商家只有一个商家帐户,或者你想使用默认帐户,这是没有必要指定一个VerificationMerchantAccountId
。