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);

行收到Braintree.Exceptions.AuthorizationException
            Result<CreditCard> result = paymentBL.StoreCustomer(
                systemHost.Customer.CustomerId
                , formCollection["name"]
                , formCollection["number"]
                , formCollection["exp"]
                , formCollection["cvv"]
            );

来自Braintree的支持:"您可以在沙箱中创建客户以及信用卡,因为它被构建为准确地反映生产环境的样子。"

有人也有过这样的经历吗?我指的是Braintree对这个问题的支持,但如果有人在SO上看到这个并知道解决方案或变通方法,我会松一口气。

Braintree API在CreateCard上抛出Braintree. exceptions . authoriza

我在Braintree工作。看起来我们已经给了你问题的答案,但我也会在这里回答任何将来有同样问题的人。

在这种情况下,问题是:

optionsRequest.VerificationMerchantAccountId = _braintreeGateway.MerchantId;

您的商户ID标识您的支付网关账户,而您的商户账户ID标识您要用于验证的银行账户。我们支持中心的一篇文章解释了两者的区别:

MerchantAccountId

使用Braintree,您可以拥有多个商户所有帐户都通过同一网关帐户进行处理。这意味着你可以有多个地点,多个企业,多种货币等所有设置和处理在一个单一的帐户。这使得跟踪所有处理过程变得容易通过统一的报告和访问,甚至可以为您节省资金。

您可以在您的网关中找到所有商家帐户的id请按照以下步骤处理:

  • 登录您的帐号

  • 将鼠标悬停在您的帐户名称上点击"处理"

  • 滚动到页面底部

其中AuthorizationException为HTTP状态码403 Forbidden。这意味着服务器正在拒绝您的请求,因为您没有访问资源的权限(即使您可能已通过身份验证)。

由于您指定的ID(因为它根本不是商家帐户ID)的用户没有可用的商家帐户,因此您获得AuthorizationException

如果,通常情况下,你的商家只有一个商家帐户,或者你想使用默认帐户,这是没有必要指定一个VerificationMerchantAccountId