https://github.com/bezkoder/react-redux-jwt-auth
React Redux: Token Authentication example with JWT, React Router, Axios, Thunk Middleware
https://github.com/bezkoder/react-redux-jwt-auth
authentication authorization axios jwt-authentication react react-jwt react-redux reactjs redux
Last synced: 19 days ago
JSON representation
React Redux: Token Authentication example with JWT, React Router, Axios, Thunk Middleware
- Host: GitHub
- URL: https://github.com/bezkoder/react-redux-jwt-auth
- Owner: bezkoder
- Created: 2020-09-01T04:06:36.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-01-19T10:39:21.000Z (over 2 years ago)
- Last Synced: 2025-03-28T10:47:34.729Z (about 1 month ago)
- Topics: authentication, authorization, axios, jwt-authentication, react, react-jwt, react-redux, reactjs, redux
- Language: JavaScript
- Homepage:
- Size: 381 KB
- Stars: 133
- Watchers: 2
- Forks: 65
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
## React Redux JWT Authentication & Authorization example
Build a React Redux Token Authentication example with JWT, LocalStorage, React Router, Axios and Bootstrap:
- JWT Authentication Flow for User Signup & User Login
- Project Structure for React Redux JWT Authentication, LocalStorage, Router, Axios
- Working with Redux Actions, Reducers, Store for Application state
- Creating React Components with Form Validation
- React Components for accessing protected Resources (Authorization)
- Dynamic Navigation Bar in React App## User Registration and User Login Flow
For JWT Authentication, we’re gonna call 2 endpoints:- POST `api/auth/signup` for User Registration
- POST `api/auth/signin` for User LoginThe following flow shows you an overview of Requests and Responses that React Client will make or receive. This React Client must add a JWT to HTTP Header before sending request to protected resources.

For more detail, please visit:
> [React Redux JWT Authentication & Authorization example](https://bezkoder.com/react-redux-jwt-auth/)> [React - How to Logout when Token is expired](https://www.bezkoder.com/react-logout-token-expired/)
> [React Hooks + Redux: JWT Authentication & Authorization example](https://bezkoder.com/react-hooks-redux-login-registration-example/)
> [React JWT Authentication & Authorization (without Redux) example](https://bezkoder.com/react-jwt-auth/)
This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app).
### Set port
.env
```
PORT=8081
```## Note:
Open `src/services/auth-header.js` and modify `return` statement for appropriate back-end (found in the tutorial).```js
export default function authHeader() {
const user = JSON.parse(localStorage.getItem('user'));if (user && user.accessToken) {
// return { Authorization: 'Bearer ' + user.accessToken }; // for Spring Boot back-end
return { 'x-access-token': user.accessToken }; // for Node.js Express back-end
} else {
return {};
}
}
```## Project setup
In the project directory, you can run:
```
npm install
# or
yarn install
```or
### Compiles and hot-reloads for development
```
npm start
# or
yarn start
```Open [http://localhost:8081](http://localhost:8081) to view it in the browser.
The page will reload if you make edits.
## Related Posts
> [In-depth Introduction to JWT-JSON Web Token](https://bezkoder.com/jwt-json-web-token/)> [React.js CRUD example to consume Web API](https://bezkoder.com/react-crud-web-api/)
> [React Redux CRUD App example with Rest API](https://bezkoder.com/react-redux-crud-example/)
> [React Pagination example](https://bezkoder.com/react-pagination-material-ui/)
> [React File Upload with Axios and Progress Bar to Rest API](https://bezkoder.com/react-file-upload-axios/)
Fullstack (JWT Authentication & Authorization example):
> [React + Spring Boot](https://bezkoder.com/spring-boot-react-jwt-auth/)> [React + Node.js Express](https://bezkoder.com/react-express-authentication-jwt/)
Fullstack CRUD with Node.js Express:
> [React.js + Node.js Express + MySQL](https://bezkoder.com/react-node-express-mysql/)> [React.js + Node.js Express + PostgreSQL](https://bezkoder.com/react-node-express-postgresql/)
> [React.js + Node.js Express + MongoDB](https://bezkoder.com/react-node-express-mongodb-mern-stack/)
Fullstack CRUD with Spring Boot:
> [React.js + Spring Boot + MySQL](https://bezkoder.com/react-spring-boot-crud/)> [React.js + Spring Boot + PostgreSQL](https://bezkoder.com/spring-boot-react-postgresql/)
> [React.js + Spring Boot + MongoDB](https://bezkoder.com/react-spring-boot-mongodb/)
Fullstack CRUD with Django:
> [React.js + Django Rest Framework](https://bezkoder.com/django-react-axios-rest-framework/)Integration (run back-end & front-end on same server/port)
> [How to integrate React.js with Spring Boot](https://bezkoder.com/integrate-reactjs-spring-boot/)> [Integrate React with Node.js Express on same Server/Port](https://bezkoder.com/integrate-react-express-same-server-port/)
Serverless:
> [React Firebase CRUD App with Realtime Database](https://bezkoder.com/react-firebase-crud/)> [React Firestore CRUD App example | Firebase Cloud Firestore](https://bezkoder.com/react-firestore-crud/)