Online Payment Solutions

Learn about Square online payment solutions, explore online payment use cases, and identify the APIs and SDKs that best suit your development goals and application's requirements.

Link to section

Overview

Customizable payment solutions - These solutions allow for extensive customization of the checkout flow but require a higher implementation effort. They provide you with the flexibility to embed Square payments directly into your own custom payment flow.

  • Web Payments SDK - A JavaScript browser-client SDK that allows you to integrate various secure payment methods into your application and provides the flexibility to create a fully customizable checkout flow.
  • In-App Payments SDK - Same as the Web Payments SDK, but for native mobile applications built on Android, iOS, Flutter, or React Native.

Use these APIs to manage various aspects of the payment process:

  • Payments API - Creates payments with secure tokens and manages the payment lifecycle.
  • Cards API - Saves a card on file and retrieves it as a payment source when the buyer makes purchases.

Square-hosted payment solutions - These solutions allow for minimal customization of the checkout flow but require a lower implementation effort. They offer a secure checkout experience that's entirely hosted and branded by Square.

  • Checkout API - An out-of-the-box checkout solution that allows you to generate a link to a Square-hosted payment page that can be shared across any online channel. The page is equipped with prebuilt elements such as tipping, custom fields, and integrations with other Square products.
  • Subscriptions API - Integrate Square Subscriptions into your application and allow sellers to offer automatic fixed recurring billing for their products and services.
  • Invoices API - Integrate Square Invoices into your application and allow sellers to issue formal payment requests to specific customers.
Link to section

Compare payment models and use cases

Square online payment solutions support the following payment models:

  • One-time payments - Square sellers accept one-time payments as either an eCommerce business or as a business that provides services or products billable with invoice payments.
  • Recurring payments - Square sellers accept recurring payments when a buyer authorizes them to automatically charge their account at regular intervals for products or services.

When building applications that process one-time or recurring payments, there are various Square APIs and SDKs you can use. Selecting the correct ones requires evaluating multiple factors to ensure they align with your needs as well as those of your sellers. Criteria to consider include the following:

  • Checkout flow - Decide whether to integrate Square payments into your own custom checkout flow for greater flexibility and customization or opt for a Square-hosted and branded checkout experience for easier implementation.
  • Application and seller requirements - Evaluate factors such as your application type, payment methods to support, and seller regional availability.

Link to section

Checkout flow

Invoices APICheckout APIWeb Payments SDKIn-App Payments SDK
Checkout flow customizationLowLowHighHigh
Embed Square payments into a custom payment flow
Square-branded and hosted checkout flow
Generate shareable Square payment links
Square manages orders and payment requests
CustomerA specific customerAny customer with the linkAny customer visiting the website or appAny customer visiting the app
Additional products neededOrders API, Customers API, and Cards APINonePayments APIPayments API
Link to section

Application, security, and payment method support

Invoices APICheckout APIWeb Payments SDKIn-App Payments SDK
Web application support
Mobile application support
(Native mobile apps only)
Device supportAny device (phone, tablet, laptop, desktop)Any device (phone, tablet, laptop, desktop)Any device (phone, tablet, laptop, desktop)Mobile iOS and Android phones and tablets
Payment interfaceWeb browserWeb browserWeb browserMobile app's native interface
Flutter and React Native plug-in support
Square handles PCI compliance, chargebacks, and disputed payments
Supported payment methods
  • Card payments
  • Apple Pay
  • Google Pay
  • Square gift cards
  • ACH Bank Transfer
  • Afterpay payments
  • Cash App payments
  • Card payments
  • Apple Pay
  • Google Pay
  • Afterpay payment
  • Cash App payments
  • Card payments
  • Apple Pay
  • Google Pay
  • Square gift cards
  • ACH Bank Transfer
  • Afterpay payments
  • Cash App payments
  • Card payments
  • Apple Pay
  • Google Pay
  • Square gift cards
Supported regions United States, Canada, United Kingdom, Australia, Ireland, Spain, France, and Japan
Link to section

Term definitions

  • Checkout flow customization:
    • Low customization - Minimal control of the checkout flow, but with less implementation effort because you're leveraging a Square-hosted and branded checkout flow.
    • High customization - Extensive control of the checkout flow, but with a higher implementation effort because you're building your own checkout flow instead of leveraging Square's prebuilt offerings.
  • Square-branded and hosted checkout flow - Involves Square managing the entire checkout process. You can integrate the checkout flow into a payment workflow with low effort, which enables buyers to get redirected to an Square-hosted and branded online checkout page. Square handles the user interface of the checkout flow and the payment processing for you.
  • Square-managed orders and payment requests - As the backend provider, Square takes care of processing orders and payments and delivering payment requests to the appropriate service provider.
Link to section

Applicable solutions for one-time payments

  • Square-hosted payment solutions: Checkout API and Invoices API
  • Customizable payment solutions: Web Payments SDK, In-App Payments SDK, and Payments API
Link to section

Integrations

For one-time eCommerce payments:

  • If you want to embed Square payments into a custom checkout flow and offer a more tailored brand experience, use the Web Payments SDK or In-App Payments SDK to securely tokenize credit card payments. You can then pair either solution with the Payments API to process the payments.
  • If you don't have a custom checkout flow, but still want to offer a comprehensive checkout experience with minimal effort, use the Checkout API. This API allows you to generate a URL to a prebuilt Square-branded payment page fully hosted by Square.

For one-time invoice payments:

  • For the simplest way to offer invoicing functionality with minimal effort, use the Invoices API to create and manage Square invoices and let Square handle the payment processing.

    Note

    To retrieve itemization details, use the Orders API and Customers API.

  • If you already have your own custom invoicing system and application logic, you can use the Web Payments SDK or In-App Payments SDK for payments acceptance and the Payments API to manage the payments.

Link to section

Use cases for one-time payments

  • A booking application uses the Checkout API to generate a payment link URL accessible from their booking pages, which redirects to a Square-hosted checkout page to help sellers collect a payment.
  • An online form-builder application uses the Web Payments SDK to let sellers accept payments directly within their forms.
  • A platform for building custom-branded mobile applications uses the In-App Payments SDK to let sellers take payments on orders placed with the application.
  • An SMS texting application uses the Invoices API to let sellers request a payment by sending a Square invoice link from their application, along with an invoice receipt as a payment confirmation.
Link to section

Explore payment processing experiences

From minimal to extensive complexity and coding, learn how each API or client SDK performs a payment processing experience suitable for your application with the following examples.

Did you know?

You can take your exploration even further in API Explorer with a given API endpoint's request example and do more testing (click Try in API Explorer in the code block).

The following examples demonstrate how Square APIs create requests to generate invoices, subscriptions, and payments to be processed.

Link to section

Invoice request

The following CreateInvoice request example demonstrates creating a new draft invoice that's delivered by email for an associated customer and order. Note that the invoice object contains the order_id and customer_id that are associated with the invoice order and customer, respectively.

Create invoice

With the invoice_id and version taken from the invoice response object, you can call PublishInvoice to publish and send the invoice to the customer.

Publish invoice

Link to section

Subscription request

The following CreateSubscription request example enrolls a customer into a subscription:

Create subscription

Link to section

Payment request

The following CreatePayment request example directs Square to charge $20 to the payment token specified as the source_id:

Create payment

The following examples demonstrate how the quick checkout form requires minimal configuration with the Checkout API, while the card payment form and the mobile client payment form allow more payment acceptance customization with the Web Payments SDK and In-App Payments SDK, respectively.

Link to section

Quick checkout form

The following CreatePaymentLink request example creates a quick pay checkout page for the auto detailing order. The Square-hosted checkout page is configured with the Google Pay method and shows a total amount for the order.

Create payment link

Link to section

Card payment form

The following example demonstrates how the Web Payments SDK renders a card payment form on a checkout page:

Link to section

Mobile client payment form

The following sample mobile applications, built with the In-App Payments SDK, demonstrate how to set up a quickstart application and test a payment. For complete instructions, see Download, Configure, and Run the Client Sample .

Link to section

Android

For the complete In-App Payments SDK quickstart sample Android application code, visit GitHub.

<meta-data android:name="sqip.SQUARE_APPLICATION_ID" android:value="sandbox-sq0idb-e409t8jgered34534rligh"/>
Link to section

iOS

For the complete In-App Payments SDK quickstart sample iOS application code, visit GitHub.

An Xcode screenshot that depicts the bundle identifier setting to be updated for setting up the In-App Payments SDK quickstart sample app