不使用格子条纹的每条付款方式都会获取银行的帐号和路由号码

时间:2018-09-11 11:46:38

标签: stripe-payments

我正在尝试使用不带第三方的ACH条纹度假来手动获取帐号,路由号,账户持有人姓名和帐号类型stripe.js / v3创建银行令牌,我使用此令牌创建客户,然后创建所有费用已经完成,但是当我们使用带区号的testng帐户num和reuting编号进行测试时,这会给我致命错误:“此帐户无法创建付款”

this is my onclick button function that create abnk token
function test1(){
  
   var one_coach = $('input.checkbox-coaches').is(':checked');
                if(one_coach == false){
                  alert('Please Choose at least one coach');
                  return false;
                }
                  var one_athlete = $('input.checkbox-athletes').is(':checked');
            if(one_athlete == false){
              alert('Please Choose at least one athlete');
              return false;
            }
       
                   //create single-use token to charge the use
 var stripe = Stripe('pk_test_UM0qUCRVFnrem3uAIGtWcPiJ');
                   //create single-use token to charge the use
stripe.createToken('bank_account', {
 country: 'US',
  currency: 'usd',
  routing_number: $('#routing_number').val(),
  account_number: $('#account_number').val(),
  account_holder_name: $('#account_holder_name').val(),
  account_holder_type: $('#account_holder_type').val(),
}).then(function(result) {

 //console.log(result);
 if (result.error) {
                //enable the submit button
              
                $('#payBtn').removeAttr("disabled");
                //display the errors on the form
                // $('#payment-errors').attr('hidden', 'false');
                $('#payment-errors').addClass('alert alert-danger');
                $("#payment-errors").html(result.error.message);
            } else {
                var form$ = $("#order_form");
                //get token id
                 var token_ach = result.token.id;
                 var bank_account_id=result.token.bank_account.id;

                 //alert(token_ach);
                //insert the token into the form
                form$.append("<input type='hidden' id='bank_account' name='bank_account' value='" + bank_account_id + "' />");
              form$.append("<input type='hidden' id='stripeToken' name='stripeToken' value='" + token_ach + "' />");
                //submit form to the server
               //  form$.get(0).submit();
       
               function ach(){
  var charges = $( "#service_charges" ).text(); 
  var formdata=$('#order_form').serialize()+ '&charges=' + charges;
   
      
  $('#ach_button').attr('disabled','disabled').attr('value','Ordering...'); 
  
  $.ajax({
    type : 'POST',
    url :   'register/ach',
    data : formdata,
    beforeSend: function() {
              $("#loader").show();
           },
    success:
      function(data){
        
        $('#results').removeClass('hide');
        
        var result = JSON.parse(data);
          

        if(result.error == 100)
        {
           $("#loader").hide();
          $('#alert_msg').addClass('alert-error');
          $('#results h4').text('On snap!');
          $('#results p').text(result.msg);
          $('#place_order').removeClass('disabled').attr('value','Place Order').removeAttr('disabled');
          
        }

        else
        {
          $("#loader").hide();
          $('#alert_msg').removeClass('alert-error').addClass('alert-success');
          $('#results h4').text('Congratulations!');
          $('#results p').html(result.msg + '<br/>An email confirmation has been sent to you. You can visit the <a href="/account">My Account</a> area to view your invoice.');
 
 return false;
        }
        
         return false;
         
      }
  });


}

                 
               // $('#stripeToken').val(token);
            }
});
               // var token = $('#stripeToken').val();
               // alert(token); return;
               //  //submit from callback
               //   process_order(token);
             
}



php code that get all data 
public function ach()
{
  $post = array_2_obj($this->input->post());
 if(!empty($post->stripeToken))
    {  

    $contact_id = $this->club->infusion_contact_id;

    $post->event = $this->events_model->get('events',array('id' => $post->event_id));
 
    $attending = $this->get_attending_details($post->event_id,$this->input->post('athletes'));
 //echo "<pre>";print_r($attending); 
    $teams = $this->get_team_comps($post->event_id,$attending);
 // echo "<pre>";print_r($teams);
     $this->session->unset_userdata("register_{$post->event_id}");
 

    /**
     * Check if Order has already been created by Session register_{event_id} Create Blank Order inside Infusionsoft
     */
 
    if(!isset($this->session->userdata["register_{$post->event_id}"])):
      $invoice_id = $this->infusion->create_order($contact_id,$post,$attending,$teams);
      $this->session->set_userdata("register_{$post->event_id}",$invoice_id);
    else :
      $invoice_id = $this->session->userdata["register_{$post->event_id}"];
    endif;
 


    /**
     * Charge Invoice
     */
    // $merchant_id = $this->db_model->get_setting_value('merchant_id');

   


    /**
     * Unset the Invoice Id
     */
    //$this->session->unset_userdata("register_{$post->event_id}");
//print_r($post); exit;
    //  echo "<pre>";print_r($_POST); 
      //get token, card and user info from the form
      $bank_a_token  = $post->stripeToken;
      $account_holder_name = $post->account_holder_name;
     // $email = $_POST['email'];
      $routing_number = $post->routing_number;
      $account_number =$post->account_number;
    //  $bank_account_id=$post->bank_account;
      //include Stripe PHP library
        require_once APPPATH."third_party/stripe/init.php";
      
      //set api key
      $stripe = array(
        "secret_key"      => "sk_test_HfRFUzMnvuq1rY1CfBZZUgKv",
        "publishable_key" => "pk_test_UM0qUCRVFnrem3uAIGtWcPiJ"
      );
      
      \Stripe\Stripe::setApiKey($stripe['secret_key']);
$create_customer=\Stripe\Customer::create(array(
  "source" => $bank_a_token,
  "description" => $account_holder_name
));
 //print_r($create_customer); exit;
  $customer_id=$create_customer->id;
  $source=$create_customer->default_source;


//get the existing bank account

$customer = \Stripe\Customer::retrieve($customer_id);
$bank_account = $customer->sources->retrieve($source);

// verify the account
$bank_account->verify(array('amounts' => array(32, 45)));
 //print_r($bank_account); exit;
       $label="";
         $price=0;
          $teamprice=0;
          $teamlable="";
      //item information
      foreach ($attending as $product) {
       
         $label.=$product->label.",";
      $price=($product->total)+$price;

      }

      if (!empty($teams)) {
       foreach ($teams as $tprice) {

   $teamlable.=$tprice->label.",";
         $teamprice=$tprice->team_price;
      }

      }

 $charges=$post->charges;
$new_price=$price+$teamprice+$charges;
      $itemName = $label;
      $itemNumber = $post->event->product_id;
      $itemPrice = $new_price*100;
      $currency = "usd";
      $orderID = $post->event->action_set_id;
     //print_r($customer);

     
 
    
  try {
  $charge = \Stripe\Charge::create(array(
  "amount" => $itemPrice,
  "currency" => $currency,
  "customer" => $customer_id // Previously stored, then retrieved
));
    
} catch(\Stripe\Error\Card $e) {
  // Since it's a decline, \Stripe\Error\Card will be caught
  $body = $e->getJsonBody();
  $err  = $body['error'];

  print('Status is:' . $e->getHttpStatus() . "\n");
  print('Type is:' . $err['type'] . "\n");
  print('Code is:' . $err['code'] . "\n");
  // param is '' in this case
  print('Param is:' . $err['param'] . "\n");
  print('Message is:' . $err['message'] . "\n");

} catch (\Stripe\Error\RateLimit $e) {
  // Too many requests made to the API too quickly
} catch (\Stripe\Error\InvalidRequest $e) {
  $msg = array('error' => 100,'msg' => "this account cannot create payment  ");
    echo json_encode($msg);
   exit;
  // Invalid parameters were supplied to Stripe's API
} catch (\Stripe\Error\Authentication $e) {
  // Authentication with Stripe's API failed
  // (maybe you changed API keys recently)
} catch (\Stripe\Error\ApiConnection $e) {
  // Network communication with Stripe failed
} catch (\Stripe\Error\Base $e) {
  // Display a very generic error to the user, and maybe send
  // yourself an email
} catch (Exception $e) {
  $msg = array('error' => 0,'msg' => "this account cannot create payment  ");
    echo json_encode($msg);
   exit;
  // Something else happened, completely unrelated to Stripe
}

      //retrieve charge details
      $chargeJson = $charge->jsonSerialize();
      //check whether the charge is successful
      
      if($chargeJson['amount_refunded'] == 0  && $chargeJson['paid'] == 1 && $chargeJson['captured'] == 1)
       {
        //order details 
       
        $amount = $chargeJson['amount'];
        $balance_transaction = $chargeJson['balance_transaction'];
        $currency = $chargeJson['currency'];
        $status = $chargeJson['status'];
        $date = date("Y-m-d H:i:s");
      
        
        //insert tansaction data into the database
        $data = new stdClass();
    $data->attending_details = $attending;
    $data->post = $post;
    $data->teams = $teams;
    $data->club = new stdClass();
    $data->club = $this->club;

    $data->bank = new stdClass();
    $data->bank->last4 = substr($post->account_number,-4);
    $data->bank->account_holder_type = $post->account_holder_type;
    $data->bank->account_number = $post->account_number;
    $data->bank->routing_number = $post->routing_number;
    // $data->card->stripeToken=$post->stripeToken;
 
    unset($data->post->account_number);
    unset($data->post->routing_number);



    /**
     * Add Coaches and Athlete Data so it does not get deleted
     */
    $data->coaches = array();
    foreach($data->post->coaches as $coach_id):
      if($coach_id > 0):
        $data->coaches[] = $this->coaches_model->get(array('id' => $coach_id));
      endif;
    endforeach;


    $data->athletes = array();
    foreach($data->post->athletes as $athlete_id):
      if($athlete_id > 0):
        $data->athletes[] = $this->athletes_model->get(array('id' => $athlete_id));
      endif;
    endforeach;
    //Insert Data into Database
    $order_data = $this->db_model->add_order($this->club->id,$invoice_id,$data->post->event_id,$data);
              $pdf_base64 = execute_curl(base_url() . 'invoice/base/' . $order_data->key,array(),TRUE);
 
    // if(strlen($pdf_base64) > 10 ):
    //   $file_name = $data->post->event->name . ' - ' . $data->club->club . ' Invoice.pdf';
    //   $this->infusion->uploadFile($file_name,$pdf_base64,$contact_id);
    // endif;
   
    // //Update Invoice Key and then send email
    // $this->infusion->updateCon($contact_id,array('_InvoiceKey' => $order_data->key));
    // $this->infusion->sendTemplate(array($contact_id),$this->db_model->get_setting_value('invoice_email_template'));
    // $this->infusion->sendTemplate(array($contact_id),$this->db_model->get_setting_value('admin_notification_email_template'));

    // $global_action_set = $this->db_model->get_setting_value('all_events_action_set_id');
    // if(isset($global_action_set) && $global_action_set > 0):
    //   $this->infusion->runAS($contact_id,$global_action_set);
    // endif;
}
        
   
         // $msg = array('error' => 0,'msg' => "You have successfully registered your club for " .  $data->post->event->name. ' Event');
 $msg = array('error' => 0,'msg' => "You have successfully registered your club for " . "$chargeforach->". ' Event');
    echo json_encode($msg);
   exit;
    }
      else
      {
       $msg = array('error' => 100,'msg' => "Invalid TOken");
    echo json_encode($msg);
    exit;
      }






}

1 个答案:

答案 0 :(得分:0)

您居住在美国吗? 目前根据文件。它仅支持美国的ACH收费

https://stripe.com/docs/ach