A Step-by-Step Guide to Implementing Google SSO
data:image/s3,"s3://crabby-images/b7c9d/b7c9db98789e992bb8def2e6e6b29b28373f42a3" alt="Google Login"
How to Create a Project on Google Cloud Console?
1 – Open the Google Cloud Console:
https://console.cloud.google.com/
2 – Create Project
data:image/s3,"s3://crabby-images/a6454/a64546217c27a1b7582515c34894d4faacb9d14d" alt=""
3 – Select the Project:
Here I am selecting the Google SSO project as shown below:data:image/s3,"s3://crabby-images/8e2e1/8e2e1cd944eeedb0c83fa3a72a52a0f0d89f05e3" alt=""
4 – Click on “APIs & Services”:
data:image/s3,"s3://crabby-images/536aa/536aac2eaa1620d47ec8570bd261667897d2ac09" alt=""
The following screen appears:
data:image/s3,"s3://crabby-images/6f0bd/6f0bdcb92201f0c6114cfd9733d4fdb5258e9b19" alt=""
data:image/s3,"s3://crabby-images/20876/2087623e16e7659b5eeae588b12b31da0c78c5c7" alt=""
5 – Click on Create Credentials:
Select the “OAuth client ID” from the List. The following screen appears:
data:image/s3,"s3://crabby-images/76b70/76b704f9cb1e668c77511a7035a7d30bc608c9be" alt=""
Select the “OAuth client ID” from the List. The following screen appears:
data:image/s3,"s3://crabby-images/2eb31/2eb31c14b8c6af73efa595886180a478886ef835" alt=""
Now click on the “CONFIGURE CONSENT SCREEN”.
data:image/s3,"s3://crabby-images/6ddd8/6ddd892de6223a4d4aac3448f79dc4b41cb393f8" alt=""
Now Select the option “External” and Click on the “Create” button.
data:image/s3,"s3://crabby-images/b3d37/b3d375107f733e13d420db8f113c5caf98f36302" alt=""
Fill the required fields as shown above and click on the “SAVE AND CONTINUE” button.
data:image/s3,"s3://crabby-images/73a61/73a61d673345da6116f429726d298b394fac9b72" alt=""
No need to change anything here, just click the button “SAVE AND CONTINUE”
data:image/s3,"s3://crabby-images/554a2/554a22cfbdd33299329ad58de41adb78addd3814" alt=""
Again Click on button “SAVE AND CONTINUE”
data:image/s3,"s3://crabby-images/221a2/221a22bdc7b8d538627772aedaf2368b67e38716" alt=""
Now click on the “BACK TO DASHBOARD” button. The following screen will appear where we will again click on “CREATE CREDENTIALS” Link.
data:image/s3,"s3://crabby-images/77418/77418d2d02fe7bcc43086cab1cab6b14c85f2a8f" alt=""
Now select the “Web application” option from the below dropdown:
data:image/s3,"s3://crabby-images/9a2ed/9a2ed40676fbdb144118b1b67672a02ac118899e" alt=""
Here we can set the Name for Application in the below form:
data:image/s3,"s3://crabby-images/dab6c/dab6c4c5fa000bf0e2b7644223eaa88b7a4317b2" alt=""
This screen will appear once we click on the “CREATE” button in the above screen:
data:image/s3,"s3://crabby-images/740a2/740a283249fe9a128b5466770e1dbf9c9c1c2658" alt=""
Here we can get the “Client ID” and “Client Secret” to put into the “config.php” file. Now we have to Edit the “OAUTH 2.0 Client IDs”:
data:image/s3,"s3://crabby-images/89029/89029a32d5fa8f166cb80a3982f53239ac208952" alt=""
In the above screen You need to add the Redirect URI. In my case the redirect URI is:
http://localhost:8888/google_login/callback.php
Click on the “SAVE” button. And it all sets on the Google Cloud Console.
What to set into the Config.php File:
data:image/s3,"s3://crabby-images/51e1f/51e1fcb2110c4b621366d403f167361ab4c1e81d" alt=""
In the above screenshot I have shown the config.php file in which we need to configure the Google Cloud Console Credentials and the database configurations.
Flow of the Application:
1. Login Page (login.php)
The login page handles user authentication through Google OAuth. It initiates the login process and processes the OAuth callback to retrieve user information.
Google_Client Configuration: Sets up the Google API client with the client ID, client secret, and redirect URI.
data:image/s3,"s3://crabby-images/3f2f3/3f2f33d44caaf44cc0e3851064a3537d3db31406" alt=""
Key Points in Callback.php
- Database Interaction: Checks if the user exists in the database and updates or inserts their information accordingly.
- Session Management: Stores user information in PHP sessions.
2. Dashboard Page (dashboard.php)
The dashboard page displays a welcome message along with the user’s profile picture. It ensures that only authenticated users can access the page.
- Session Verification: Checks if the user is logged in by verifying the session.
- User Information Display: Displays the user’s name and profile picture.
Logout Link: Provides a link to the logout page.
data:image/s3,"s3://crabby-images/23a51/23a51500fd78981d0f716a8c214c57d914e911f7" alt=""
data:image/s3,"s3://crabby-images/de626/de626f47f9070003b0172ce733c9f2d29abb3107" alt=""
data:image/s3,"s3://crabby-images/b148f/b148fe072d4e7abe1273c9b67e27b1f03ce90364" alt=""
3. Logout Page (logout.php)
Purpose
The logout page handles user logout by destroying the session and redirecting to the login page.
Key Points
- Session Destruction: Ends the user session.
Redirection: Redirects the user back to the login page after logout.
Database Setup
The database named google_login contains a single table users with the following structure:
Configuration
- Database Name: google_login
- Table Name: users
- Fields:
- id: Auto-incremented primary key
- google_id: Google user ID
- name: User’s name
- email: User’s email
- profile_pic: URL of the user’s profile picture
data:image/s3,"s3://crabby-images/20daf/20daf4e74248064434a37fc928bb3c09813e5775" alt=""
Prerequisites
- Google API Client Library: Install using Composer
- composer require google/apiclient:^2.0
- Google API Credentials: Obtain from Google Developer Console.
- Web Server: Ensure a web server (e.g., Apache, Nginx) is running locally.
Database: Set up a MySQL database with the appropriate schema.
Leave a Reply
You must be logged in to post a comment.
Leave a Comment