2016-04-06 6 views
0

私はかなりWeb開発の新人で、VBとWinFormsでほとんど仕事をしています。私はクライアントのための小さな電子商取引サイトを構築し、Braintreeを使ってトランザクションを処理することに決めました。しかし、私はクライアントのBraintree UIドロップインフォームにクライアントトークンを生成するのに問題があります。彼らが推奨するデフォルトのハンドラを作成しました。方法:Braintree .NET sdkからクライアントにクライアントトークンハンドラーを補間する

public class ClientTokenHandler : IHttpHandler 
{ 
    public string pubClientToken; 
    public void ProcessRequest(HttpContext context) 
    { 
     var gateway = new BraintreeGateway 
     { 
      Environment = Braintree.Environment.SANDBOX, 
      MerchantId = "MerchantID", 
      PublicKey = "Public_Key", 
      PrivateKey = "Private_Key" 
     }; 
     pubClientToken = gateway.ClientToken.generate(); 
     HttpContext.Current.Response.Write(pubClientToken); 
    } 

    public bool IsReusable 
    { 
     get 
     { 
      return false; 
     } 
    } 
} 

私はクライアントトークンを取得するには、クライアントからのハンドラを呼び出すときに、私はトークンが生成されていることを確認することができるように、私は、ハンドラの先頭にブレークポイントを設定します。しかし、ブレークポイントは決してヒットせず、ドロップインUIはロードされません(私はそれが有効なトークンを持っていないと仮定します)。ここでは、ハンドラへのAJAX呼び出しのコードを示します。

<div class="container"> 
    <form id="checkout" method="post" action="/checkout"> 
    <div id="payment-form"></div> 
    <input type="submit" value="Pay $10"> 
    </form> 

    <script src="https://js.braintreegateway.com/js/braintree-2.22.2.min.js"></script> 

    <script> 
     var clientToken; 
     function CallHandler() { 
      $.ajax({ 
       url: "ClientTokenHandler.ashx.cs", 
       type: "GET", 
       contentType: "application/json; charset=utf-8", 
       success: OnComplete, 
       error: OnFail 
      }); 
      return result; 

      function OnComplete(result) { 
       clientToken = data; 
      } 
      function OnFail(result) { 
       alert('Request failed'); 

      } 
     } 

    // We generated a client token for you so you can test out this code 
    // immediately. In a production-ready integration, you will need to 
     // generate a client token on your server (see section below). 
     //var clientToken = "eyJ2ZXJzaW9uIjoyLCJhdXRob3JpemF0aW9uRmluZ2VycHJpbnQiOiJjOWU2ZDgwNDI3YWEyMjQ5YjMwMmQzNjdjZTJhOTljODNiMWNjYTljOGNlMjcwMzBlZDIxYmM2NjYxZDhjMzBlfGNyZWF0ZWRfYXQ9MjAxNi0wNC0wNlQxNjo0OToxOS45NDEyNTQ3MzcrMDAwMFx1MDAyNm1lcmNoYW50X2lkPTM0OHBrOWNnZjNiZ3l3MmJcdTAwMjZwdWJsaWNfa2V5PTJuMjQ3ZHY4OWJxOXZtcHIiLCJjb25maWdVcmwiOiJodHRwczovL2FwaS5zYW5kYm94LmJyYWludHJlZWdhdGV3YXkuY29tOjQ0My9tZXJjaGFudHMvMzQ4cGs5Y2dmM2JneXcyYi9jbGllbnRfYXBpL3YxL2NvbmZpZ3VyYXRpb24iLCJjaGFsbGVuZ2VzIjpbXSwiZW52aXJvbm1lbnQiOiJzYW5kYm94IiwiY2xpZW50QXBpVXJsIjoiaHR0cHM6Ly9hcGkuc2FuZGJveC5icmFpbnRyZWVnYXRld2F5LmNvbTo0NDMvbWVyY2hhbnRzLzM0OHBrOWNnZjNiZ3l3MmIvY2xpZW50X2FwaSIsImFzc2V0c1VybCI6Imh0dHBzOi8vYXNzZXRzLmJyYWludHJlZWdhdGV3YXkuY29tIiwiYXV0aFVybCI6Imh0dHBzOi8vYXV0aC52ZW5tby5zYW5kYm94LmJyYWludHJlZWdhdGV3YXkuY29tIiwiYW5hbHl0aWNzIjp7InVybCI6Imh0dHBzOi8vY2xpZW50LWFuYWx5dGljcy5zYW5kYm94LmJyYWludHJlZWdhdGV3YXkuY29tLzM0OHBrOWNnZjNiZ3l3MmIifSwidGhyZWVEU2VjdXJlRW5hYmxlZCI6dHJ1ZSwicGF5cGFsRW5hYmxlZCI6dHJ1ZSwicGF5cGFsIjp7ImRpc3BsYXlOYW1lIjoiQWNtZSBXaWRnZXRzLCBMdGQuIChTYW5kYm94KSIsImNsaWVudElkIjpudWxsLCJwcml2YWN5VXJsIjoiaHR0cDovL2V4YW1wbGUuY29tL3BwIiwidXNlckFncmVlbWVudFVybCI6Imh0dHA6Ly9leGFtcGxlLmNvbS90b3MiLCJiYXNlVXJsIjoiaHR0cHM6Ly9hc3NldHMuYnJhaW50cmVlZ2F0ZXdheS5jb20iLCJhc3NldHNVcmwiOiJodHRwczovL2NoZWNrb3V0LnBheXBhbC5jb20iLCJkaXJlY3RCYXNlVXJsIjpudWxsLCJhbGxvd0h0dHAiOnRydWUsImVudmlyb25tZW50Tm9OZXR3b3JrIjp0cnVlLCJlbnZpcm9ubWVudCI6Im9mZmxpbmUiLCJ1bnZldHRlZE1lcmNoYW50IjpmYWxzZSwiYnJhaW50cmVlQ2xpZW50SWQiOiJtYXN0ZXJjbGllbnQzIiwiYmlsbGluZ0FncmVlbWVudHNFbmFibGVkIjp0cnVlLCJtZXJjaGFudEFjY291bnRJZCI6ImFjbWV3aWRnZXRzbHRkc2FuZGJveCIsImN1cnJlbmN5SXNvQ29kZSI6IlVTRCJ9LCJjb2luYmFzZUVuYWJsZWQiOmZhbHNlLCJtZXJjaGFudElkIjoiMzQ4cGs5Y2dmM2JneXcyYiIsInZlbm1vIjoib2ZmIn0="; 


    braintree.setup(clientToken, "dropin", { 
    container: "payment-form" 
    }); 
    </script> 
</div> 

誰かがどのようにしてやったかの例はありますか?これは私の最初の投稿です、あまりにも多くの石を投げてはいけません。 ;)TIA!

+0

私は

関連する問題