带有与表单相同价格的条带计费

时间:2016-06-27 05:00:49

标签: php laravel stripe-payments laravel-cashier

因此,我希望向客户(非用户)收取与条带形式中显示的数量相同的金额

<form action="/charge" method="POST">
                 {!! csrf_field() !!}
                  <script
                    src="https://checkout.stripe.com/checkout.js" class="stripe-button"
                    data-key="pk_test_key"
                    data-amount="{{ $note->price*100 }}"
                    data-name="Hello World"
                    data-description="{{$note->title}}"
                    data-image="/img/documentation/checkout/marketplace.png"
                    data-locale="auto"
                    data-currency="aud">
                  </script>
                </form>

在表格中显示的价格是相关票据型号* 100中列出的价格。我希望客户实际收到此值,它会根据票据而变化。

这是我的服务器账单

public function charge()
{
    // Set your secret key: remember to change this to your live secret key in production
    // See your keys here https://dashboard.stripe.com/account/apikeys
    \Stripe\Stripe::setApiKey("sk_test_key");

    // Get the credit card details submitted by the form
    $token = $_POST['stripeToken'];

    // Create the charge on Stripe's servers - this will charge the user's card
    try {
      $charge = \Stripe\Charge::create(array(
        "amount" => 100, // amount in cents, again
        "currency" => "aud",
        "source" => $token,
        "description" => "Example charge"
        ));
    } catch(\Stripe\Error\Card $e) {
      // The card has been declined
    }

    return 'payment succesful';
}

我需要将“金额”设置为等于音符值。

否则,付款将在我的收银台测试帐户上进行,而且大部分内容都需要正常运行。

但客户不是注册用户。

1 个答案:

答案 0 :(得分:2)

数量需要是你计算服务器端的东西,否则人们可以只修改DOM并传递他们想要的任何数量。

相反,将id存储在服务器端的缓存中,并将note作为依赖项传递给charge函数,然后比较2。

/**
 * Assuming name of "view" page
 */
public function checkout(Note $note) 
{
    /**
     * Always forget this on each page load, so we can switch seamlessly between Notes.
     */
    Illuminate\Support\Facades\Cache::forget('nid')->put('nid', $note->id);
}

不要忘记修改charge路由以包含对Note依赖项的新引用

route::post('charge/{note}', 'Controller@charge')->name('charge');

请务必更新您的表单以传递note

<form action="{{route('charge', $note)}}" method="POST">

旁注我喜欢命名路线,但这不是必需的。

然后,当您处理请求时,请比较$nid$note->id

public function charge(Illuminate\Http\Request $request, Note $note)
{
    $nid = Illuminate\Support\Facades\Cache::get('nid');

    // id's match, no sneaky stuff. safe to use $note->price now
    if ($nid === $note->id) {
        //now we can process our payment.
        // Set your secret key: remember to change this to your live secret key in production
        // See your keys here https://dashboard.stripe.com/account/apikeys
        \Stripe\Stripe::setApiKey("sk_test_key");

        // Get the credit card details submitted by the form
        $token = $request->get('stripeToken');

        // Create the charge on Stripe's servers - this will charge the user's card
        try {
            $charge = \Stripe\Charge::create(array(
                "amount" => number_format($note->price, 0, '', ''), // amount in cents, again
                "currency" => "aud",
                "source" => $token,
                "description" => "Example charge"
            ));
        } catch(\Stripe\Error\Card $e) {
            // The card has been declined
        }    
    }
}