How do you integrate a payment gateway into a static site
data:image/s3,"s3://crabby-images/87167/871676a5573318f634680d22c2f862845977fe19" alt=""
-sidebar-toc>
The past was when static websites typically featured description and images of products which prompted users to purchase through email or by calling. Nowadays, customers anticipate a more dynamic shopping experience that includes robust ecommerce features. It streamlines the buying process, encouraging users to complete transactions via your website instead of looking at alternatives.
Getting started
Before diving into the steps of integrating a payment processor and checkout on your static site, let's establish the groundwork for a seamless and effective implementation.
- Sign up for a PayPal account by selecting an account for business, since it's better for this type of tutorial. This kind of account is required to test the buttons you integrate. After signing up, add the details of your company and connect to a bank account. Once you have verified your account, you can gain API credentials via the PayPal Developer portal for use in the future.
- Set up a Account with Stripe and enter your business as well as banking information. Stripe offers quick account activation, which is advantageous to this type of task. After your account has been activated, you can immediately access the Dashboard of Stripe. Here you will find your API key, a crucial part that you will need in the following steps.
Check out the static website sample
This tutorial makes use of a previously-existing static website that demonstrates the integration of PayPal and Stripe checkout capabilities. Despite its static content it is a replica of an online flower shop.
After deploying your site on your home page. Hit the ORDER INQUIRY button.
data:image/s3,"s3://crabby-images/42297/422972aa4241821aad72b0ef3b1514b56de2fb7f" alt="A flower shop web page with an image of a bouquet, an order inquiry button, and links to pages and the shopping cart"
Choose a product that is available on the Flowers Catalog page -- for example, the Turkish Rose.
data:image/s3,"s3://crabby-images/f64c5/f64c5d98bb530fcf518b3b728cbee3d49db139b6" alt="The catalog of flowers, with various bouquets, their sizes, and prices, each with a shopping cart icon to add it to the cart"
This action takes you to the information about the product page. There, payment buttons to PayPal and Stripe are implemented.
data:image/s3,"s3://crabby-images/397d6/397d686ffcdce5313aaeb73c6300f38c925e6a8f" alt="Options for ordering the Turkish Rose. There are size and color options, choice of delivery by courier or pick up, and the price"
How can you incorporate PayPal checkout into your static site
Incorporating an PayPal checkout to your site gives customers an encrypting and secure payment method and streamlines transactions, increasing the user experience. This feature can greatly improve your site's functionality and customer satisfaction.
Here's how you can integrate PayPal checkout in your site's design:
- Log into the PayPal Developer Dashboard.
- In the dashboard, go into the Apps & Credentials area. Switch on the Sandbox feature on after which select Create App.
- In the form, give your app a name (e.g. Gateway Demo). Click to select Merchant Click and type Create App .
data:image/s3,"s3://crabby-images/35eb0/35eb0ad8442b6087b2c769b34180d2957cf1fb69" alt="The Create App form on PayPal with a field for the app name, radio buttons to choose the type as merchant or platform, a field for the sandbox account"
- Copy the Client ID from the API credentials A section to come back later and make a PayPal check-out button.
data:image/s3,"s3://crabby-images/d638f/d638fbd936abbfdba19812af7ab9a108f7507ed2" alt="Credentials on PayPal for the Gateway Demo app. The API credentials section has the app name, client ID, and secret key. The sandbox account info has the URL, region, email, and password"
- Then scroll down to look over other configurations. These default settings are sufficient for this tutorial. Simply click Keep the changes .
data:image/s3,"s3://crabby-images/854e6/854e66e62d5a6a3412039ca7e9d400bf6e423b58" alt="PayPal's app features with checkboxes under Accept payments for Vault, Native Checkout SDK, Subscriptions, Invoicing, and PayPal Here. Checkbox options under Other features include Payouts, Customer disputes, Log in with PayPal, and Transaction search"
- Next, integrate PayPal checkout in your website's static. Make a button for checkout using PayPal's alternative payment alternative payment method (APM) the JavaScript SDK . It lets you integrate various payment methods on a static website without the need to set up an application backend. Include the below JavaScript code to your product.html File just prior to closing
tag. Replace YOUR_CLIENT_ID
with your using your PayPal using your PayPal. It is also possible to update your PayPal Client ID. USD
currency with the currency that your PayPal account accepts.
paypal.Buttons(
createOrder: function(data, actions)
// Set up the transaction
return actions.order.create(
purchase_units: [
amount:
value: '1.00'
]
);
,
onApprove: function(data, actions)
// Capture the funds from the transaction
return actions.order.capture().then(function(details)
// Show a success message to the buyer
alert('Transaction completed by ' + details.payer.name.given_name);
);
).render('#paypal-button-container');
This paypal.Buttons
function defines two functions:
createOrder
configures the transaction details, such as the price of purchase (1.00 USD, in this instance)."onApprove"
-- Handles the transaction's approval, taking the money and showing successful message to the purchaser. In the example code we're using alert() function.alert()
function.
Finally, the render
function specifies that the PayPal button should render inside the existing
with the ID
paypal-button-container
.
You now have PayPal in your website's static pages.
How to integrate Stripe Checkout into your static website?
Stripe is an extensively used technology platform that offers payment processing solutions for businesses that are of any size. Here is how to add Stripe payment to your static website:
- Before implementing using the Stripe payment button you can manage products and prices via an API or Stripe dashboard . For the dashboard to be used, open it, select Test mode And click Product Catalogue .
data:image/s3,"s3://crabby-images/22e17/22e178b22a891ff02bb75fcf979911932d4cb9e6" alt="Product catalog page with options to list all, available, or archived products and a button to add a product."
- Click to + Add Product Press the button to start the Include a product form.
data:image/s3,"s3://crabby-images/64894/6489467ca3de8d222fea8420fc3ac50f1885e740" alt="Add a product options with fields for name and description, image details with the option to remove, a link for more options, buttons to choose recurring or one-off, a field for amount and drop-down box for currency, and a link for advanced pricing options"
- Fill in the information about your product's name and address into the following fields:
- Name: Turkish Rose
- Description It is an exquisite Turkish Rose
- Image: (Upload the sample imagesturkishrose.png file)
- Model of payment: One-off
- Amount: $1.00
- Currency: USD (or the currency you prefer)
- Click to add product.
- In the Catalogue of products page's list, select the Turkish Rose product.
data:image/s3,"s3://crabby-images/e0927/e09278b9bbd6784c2aa141a0347267a2f8f30270" alt="Product catalog listings including the Turkish Rose, its thumbnail image, price, currency, creation date and updated date"
- In the product Pricing In the section "Sections Click to open the section. Create payment link . Examine the options for products and verify the quantities
1
.
data:image/s3,"s3://crabby-images/888c2/888c2060742c029efb9f81874b4f57643f657c34" alt="Details of the Turkish Rose product including price, currency, updated date, name, description, and image, and the pricing options including the app ID and a button to create a payment link"
- Click Create link .
data:image/s3,"s3://crabby-images/24321/2432175a9ebf1b63e1aa240e9eee32da3db713b3" alt="Options to create a payment link. Includes the product, a field for quantity and checkbox to let customers adjust the quantity, a link to add another product, options to collect customer addresses, phone numbers, and custom fields, a menu for advanced options, and a preview of how the payment page will look for that product including Apple Pay details"
- on the Payment Link Page, click Buy button .
data:image/s3,"s3://crabby-images/3b413/3b413b11da1775aa7ff37955bda6b339c4d65023" alt="Payment link details including the product name and price and the option to copy the payment link, QR code, buy button, and others"
- Then the Buy button The panel will appear, and you'll be able to see the code that was generated for the check out button. Select the Button layout, turn on the Text of the button to change on, and click, then "Buy with Stripe" in the search box. Text for the Change button field. Then, click Copy code and save changes to copy the generated code to your computer's clipboard.
data:image/s3,"s3://crabby-images/c246f/c246f20fa11024eb2ecba324c4247d6ae8881a6d" alt="Buy button options with code visible on the left, and a preview on the right. Options include configuring it as a card or button, the language, a toggle to change button text, and a field to type the text"
- Paste the code copied in the sample code's product.html files prior to the closing
STRIPE BUTTON BEGIN
andSTRIP BUTTON END
comments), similar to PayPal.
async
src="https://js.stripe.com/v3/buy-button.js">
buy-button-id="BUY_BUTTON_ID"
publishable-key="PUBLISHABLE_KEY"
>
When you're done with implementing the PayPal and Stripe checkout buttons, deploy the static site code to your static site hosting environment.
Test the checkout process
Go to the static demo's product details page. Ensure the Stripe and PayPal buttons are visible. Stripe buttons display correctly.
data:image/s3,"s3://crabby-images/e426b/e426b758d43b28abe69ca78e68589b9f5e4e7750" alt="The sample site's checkout page shows image, name, price, and size, color, and delivery options, the user can click PayPal, Debit or Credit Card Powered by PayPal, or Buy with Stripe"
Click on the PayPal checkout button. The button should display a login dialog box where the customer authenticates through PayPal to make their purchase.
data:image/s3,"s3://crabby-images/ba51a/ba51aa16e0d18681880db79fed05e0f50b58937b" alt="Options to log into PayPal or create an account"
If you have login problems during this time this could be because you are testing using an account that is personal rather than a business one.
Alternatively, customers can choose the PayPal Credit Card as well as Credit Card button. Select that option to open the box. Enter some account details.
data:image/s3,"s3://crabby-images/dae87/dae8729d9c1882c044761e20c903187c957a2979" alt="Options to pay with a debit or credit card, including a country or region menu, a field for email, a phone type menu and field for the number, radio buttons to choose debit or credit, and a field for the card number"
PayPal should present your order and account details. Select Complete Purchase.
data:image/s3,"s3://crabby-images/b09ea/b09eaf08d6f6069253867ff32585bd2406927a70" alt="Payment details with cost, ship to address and a link to change, list of debit or credit cards to choose, a checkbox to make it the preferred method, a link to add a card, and a button to complete purchase"
When PayPal accepts the transaction PayPal's JavaScript code will display an alert advising you that the transaction is completed. This alert is for reasons of development and for debuggingnot to be used for production codes.
data:image/s3,"s3://crabby-images/a8cad/a8cad6af088019c60b437cc7ceed33a6cec3a292" alt="A popup notifies the user that the transaction completed"
To verify that transactions, log into your PayPal business dashboard. Select the Activity tab and then All Transactionsto show a detailed list of all the transactions that have occurred in recent time.
data:image/s3,"s3://crabby-images/f3abe/f3abe892a6e6a1960b83b1c10c63cff5f365e847" alt="Details of the transactions on PayPal including the date, type, name, payment, gross amount, fee, net amount, and a menu for actions like add tracking"
The flower website's product.html page, it is possible to check out the Stripe checkout flow by clicking the Buy using Stripe button. The action will open the Stripe dialog box that displays information about the item and payment options. These include Google Pay, Link, and credit card payments.
data:image/s3,"s3://crabby-images/e75b6/e75b68158bb36ad6893de5925f63bf73c800cff8" alt="Stripe shows the product information and options for Google Pay and Pay with link"
For demonstration purposes, choose Google Pay. An interface prompts for confirmation of your purchase with Google Pay with a card on your list, for example one you have saved Mastercard.
data:image/s3,"s3://crabby-images/b9978/b99786d167df110abcff891fb4fd8446c94eb72b" alt="Google Pay payment details including a dropdown menu to choose the card, the price, and a pay button"
Click Pay. If it is successful, Stripe presents the customer with a purchase confirmation.
data:image/s3,"s3://crabby-images/28ee4/28ee40dc76ce03702082039abe40afe006175162" alt="Purchase confirmation from stripe. On the left are the product information. On the right is a confirmation"
In your Stripe Dashboard, select in the Dashboard, click on the Payments tab. It shows the details of your transaction including the amount, currency, description of the transaction, date, and customer.
data:image/s3,"s3://crabby-images/63bcf/63bcf6e3769bb49b08b76a574b30681854d96cd3" alt="List of payments via stripe, including the amount, currency, success, description, customer, and date"
What can you do to fix the process of checkout
Below are a few troubleshooting tips to diagnose and solve the problems you encounter during test of checkout:
- Fix the payment gateway configuration.
- Make sure that the browser of the customer is compatible.
- Apply proper error handling.
- Check out the checkout procedure in multiple environments.
- Use logging and monitoring techniques.
Summary
Now you've integrated checkout buttons to PayPal and Stripe payment gateways into a flower sample shop that's hosted using . The same techniques can be used to add payment options to your other static websites, encouraging clients to buy your goods and increasing sales.
Transform your static site into a dynamic experience with payment gateways like PayPal and Stripe. What other payment gateway do you prefer or have used before? Let us know in the comments section below.
Jeremy Holcombe
Content & Marketing Editor , WordPress Web Developer, and Content Writer. Outside of all things WordPress I like the beach, golf, and watching movies. Additionally, I'm tall and have issues ;).