stripe-express doc logo
Launch Stripe Express

Woocommerce Stripe Checkout Page Integration

How to redirect to stripe checkout page in woocommerce.


woocommerce stripe checkout redirection

Important Update: Enhanced Payment Features Now Available !

We've moved all payment functionality to our dedicated plugin that offers a comprehensive suite of payment features, including:

  • One-time payments (stripe hosted checkout redirection)
  • Subscription payments
  • Secure credit card field
  • Mutiple payment methods field
  • Express Checkout
  • PayPal
  • And much more

Get the plugin at WordPress.org for free: Stripe Payment For WooCommerce

Prerequisites

  • A premium license

Why need to redirect to Stripe hosted checkout page during checkout?

  • Trust - More trustworthy to customers when being redirected to stripe own checkout page than giving their credit card details.
  • Security - Stripe Checkout is PCI compliant out of the box and manages sensitive card data securely via Stripe Elements. This removes the PCI burden from your servers.
  • Conversion - Stripe Checkout is designed to convert with best practices for checkout flow, reducing friction and cart abandonment.
  • Global Support - Works worldwide with built-in support for local payment methods, currencies and languages.

Stripe setup

First of all, we need to set up the stripe API keys in Stripe Express -> Settings Tab woocommerce stripe elements activate

You don't need to create an Element that our plugin mainly uses because Woocommerce has its own workflow, and it's challenging to leverage our built-in elements.

Woocommerce setup

  1. Make sure the woocommerce addon for stripe express is installed.
  2. Go to Woocommerce -> Settings -> Payments setting and enable Stripe Express payment method.
woocommerce stripe redirect activate
  1. Configurate the payment elements settings, such as Supported Payment Methods.
woocommerce stripe redirect settings

Payment methods

Normally, we supported all 40+ payment methods Stripe provided, however, you need to ensure the selected payment methods are activated and available in Stripe dashboard and also, Payment methods are unavailable when they don’t support the currency or terms of the current payment.

Automatic collect This is the default value which means Stripe will find out the best suitable payment methods from your supported payment methods to display.

If you don't auto collect payment methods, you can select the supported payment methods based on the currency.

Webhook

Webhooks are used by Stripe to communicate with your site. It provides information such as the status of the payment, and is used to update the order based on certain events from Stripe’s side of things.

In the settings, you’ll find a webhook endpoint URL ready for you to copy and paste into your Stripe dashboard:

woocommerce stripe elements themes

Next, in your Stripe Dashboard go to Developers » Webhooks and select Add endpoint (with “Test mode” enabled or disabled, depending on which mode is being configured). Paste the webhook endpoint URL you copied earlier into the Endpoint URL field, and select the following * events (at minimum):

  • charge.succeeded
  • charge.failed
  • charge.captured
  • charge.dispute.created
  • charge.dispute.closed
  • charge.refunded
  • payment_intent.succeeded
  • paymentintent.paymentfailed
  • paymentintent.amountcapturable_updated
  • paymentintent.requiresaction

Enable Webhook signatures (Optional)

Generating a signature for the webhook can greatly protect your endpoint from being abused by external parties.

  1. In your Stripe dashboard, go to the webhook settings and click the Signing secret button to generate a signature.

Generate signature: generate signature
generate signature

Test

Once everything above done, we can test the checkout page with your woocommerce site. It would be similar like this: checkout-preview