Subscriptions using React
This sample shows how to build a custom subscriptions form to take a payment using the Subscriptions API, Stripe Elements and React.
Features
This sample consists of a client in React and a server piece available in 7
common languages.
The client is implemented using create-react-app to provide the boilerplate
for React. Stripe Elements is integrated using
react-stripe-js, which is the
official React library provided by Stripe.
How to run locally
To run this sample locally you need to start both a local dev server for the front-end and another server for the back-end.
You will need a Stripe account with its own set of API keys.
Follow the steps below to run locally.
1. Clone and configure the sample
The Stripe CLI is the fastest way to clone and configure a sample to run locally.
Using the Stripe CLI
If you haven't already installed the CLI, follow the installation steps in the project README. The CLI is useful for cloning samples and locally testing webhooks and Stripe integrations.
In your terminal shell, run the Stripe CLI command to clone the sample:
stripe samples create subscription-use-cases
The CLI will walk you through picking your integration type, server and client languages, and configuring your .env config file with your Stripe API keys.
Installing and cloning manually
If you do not want to use the Stripe CLI, you can manually clone and configure the sample yourself:
git clone https://github.com/stripe-samples/subscription-use-cases
Copy the .env.example file into a file named .env in the folder of the server you want to use. For example:
cp .env.example server/node/.env
You will need a Stripe account in order to run the demo. Once you set up your account, go to the Stripe developer dashboard to find your API keys.
STRIPE_PUBLISHABLE_KEY=<replace-with-your-publishable-key>
STRIPE_SECRET_KEY=<replace-with-your-secret-key>
Run react frontend client
Copy the .env.example file into a file named .env in the folder of the server you want to use. For example:
cp .env.example client/react/.env
Running the API server
- Go to
/server - Pick the language you are most comfortable in and follow the instructions in the directory on how to run.
Running the React client
- Go to
/client - Run
npm install - Run
npm startand your default browser should now open with the front-end being served fromhttp://localhost:3000/.
Using the sample app
When running both servers, you are now ready to use the app running in http://localhost:3000.
- Enter your email address
- Select your price
- Enter your card details
- 🎉
FAQ
Q: Why did you pick these frameworks?
A: We chose the most minimal framework to convey the key Stripe calls and concepts you need to understand. These demos are meant as an educational tool that helps you roadmap how to integrate Stripe within your own system independent of the framework.
Get support
If you found a bug or want to suggest a new [feature/use case/sample], please file an issue.
If you have questions, comments, or need help with code, we're here to help:
- on Discord
- on Twitter at @StripeDev
- on Stack Overflow at the stripe-payments tag
- by email