Casdoor serves both the web UI and the login requests from application users.
Casdoor follows a front-end and back-end separate architecture, developed by Golang. It supports high concurrency, provides a web-based UI for management, and supports localization in 10+ languages.
Casdoor supports third-party application login, such as GitHub, Google, QQ, and WeChat, and it supports extending third-party login with plugins.
Casdoor supports authorization management based on Casbin. It supports ACL, RBAC, ABAC, and RESTful access control models.
Casdoor provides phone verification code, email verification code, and password retrieval functions.
Casdoor supports auditing and recording of accessing logs.
Casdoor integrates with Alibaba Cloud, Tencent Cloud, and Qiniu Cloud image CDN cloud storage.
Casdoor allows customization of registration, login, and password retrieval pages.
Casdoor supports integration with existing systems by database synchronization, enabling smooth transition to Casdoor.
Casdoor supports mainstream databases such as MySQL, PostgreSQL, and SQL Server, and it supports the extension of new databases with plugins.
How it works
Step 0 (Pre-knowledge)
- Casdoor follows the authorization process built upon the OAuth 2.0 protocol. It is highly recommended to have a brief understanding of how OAuth 2.0 works. You can refer to this introduction to OAuth 2.0.
Step 1 (Authorization Request)
Your Application (which could be a website or any other application) should compose a URL in the following format:
endpoint with your Casdoor's host URL and
xxx with your own information.
How to fill out the
client_id: you can find this under each individual Application
redirect_uri: you should set this to your own Application's callback URL. Casdoor will use this information to send the response back after authorization.
state: you should fill this out with your Application name.
The Application will prompt the user: "Hey, I need some resources and I need your permission to access these resources. Can you go to this URL and enter your username and password for me?"
With the correctly composed URL, your Application will make the user launch a request to this URL, and the
Authorization Request is completed.
Step 2 (Authorization Grant)
This step is straightforward: the user is redirected to the URL composed in Step 1, and the user will see the login page from Casdoor. By entering the correct username and credentials into the login page, Casdoor now knows the identity of the user and is about to send two pieces of information back to the callback URL set in Step 1:
The user opens the URL and provides the credentials to Casdoor. Casdoor will say: "Looking good ~ this is the user who is authorizing the Application to get the
state. I know this user in my database, and I will send the
state back to the Application using the callback URL (
With these two pieces of information sent back to your Application, the authorization is granted to the app, and the
Authorization Grant is completed.
Casdoor also provides third-party logins. In this case, instead of seeing the credential entry page, you will see a list of third-party providers. You can log in to your app using these providers, with Casdoor acting as a middle layer (middleware).
Step 3 (Authorization Grant)
In this step, your Application already has the code from Step 2, and it will speak to Casdoor: "Hey, the user agreed to give me the
code. Can you verify this
code and give me the
Step 4 (Access Token)
Casdoor responds to your Application: "You know what, this
code seems legit. You must be the right Application. Here's the
access_token for you." With this
code, Casdoor confirms that it is an authorized Application (authorized by the correct user in Step 2) trying to obtain the
access_token (which will be used later to access more resources).
Step 5 (Access Token)
In this step, your Application says: "Nice! I just got the fresh-and-tasty
access_token. Now I can use it to access something more valuable from the
Your Application then turns to the
Resource Server and says: "Hey buddy, can you check out this
access_token? I received it from Casdoor. Do you want to verify if this is the correct token you issued to Casdoor?"
Step 6 (Protected Resource)
Resource Server responds to your Application: "Not bad. It seems just like the one I issued to Casdoor, and Casdoor says whoever holds this
access_token can access these
Protected Resources. So go ahead and take it!"
And that's basically how Casdoor works with your Application.
Casdoor can act as both an
Authorization Server and a
Resource Server. In other words, Casdoor authorizes your Application to access resources, usually the currently logged-in user's information, from Casdoor's database.
Here is an online demo deployed by Casbin.
Global admin login:
Casbin-OA is one of the Casbin web apps. It uses Casdoor for authentication.
Casnode is the official forum developed by the Casbin community.
It uses Casdoor as the authentication platform and manages members.
Casdoor consists of two parts:
|Backend||RESTful API backend for Casdoor||Golang + Beego + SQL||https://github.com/casdoor/casdoor|