The Simplest Guide To OAuth 2.0

For the past three years, I’ve repeated to explain OAuth 2.0 to those who don’t have a technical background, mainly to investors as a co-founder of Authlete, Inc. (Tech In Asia: “API security startup Authlete raises $1.2m in seed funding”). As a result, I found a way to explain OAuth 2.0 in an easily understandable manner. This article introduces the steps.

1. There are data of a user.

Image for post

2. There is a server which manages the user’s data. The server is called “Resource Server”.

Image for post

3. There is a “Client Application” which wants to use the user’s data.

Image for post

4. Let’s prepare a gate to pass the user’s data through. The gate is called “API”.

Image for post

5. The client application requests the user’s data.

Image for post

6. The resource server returns the user’s data.

Image for post

7. What if there is a malicious client application?

Image for post

8. Even if the client application that requests the user’s data is a malicious one, …

Image for post

9. … the resource server returns the user’s data.

Image for post

10. Even a malicious application can get the user’s data.

Image for post

11. We need a mechanism to protect the user’s data.

Image for post

12. In the best practice, an “Access Token” is given to the client application in advance. An access token represents that the said client application has been given permissions to access the user’s data.

Image for post

13. The client application presents the access token when it requests the user’s data.

Image for post

14. The resource server extracts the access token that is included in the request, …

Image for post

15. … and confirms that the access token denotes that the client application has permissions to access the user’s data.

Image for post

16. After the confirmation, the resource server returns the user’s data.

Image for post

17. To make this mechanism work, an access token must be given to the client application in advance.

Image for post

18. Consequently, we need someone who issues access tokens.

Image for post

19. Someone who issues access tokens …

Image for post

20. … is called “Authorization Server”.

Image for post

21. The relationship between a client application and an authorization server is as follows.

Image for post

22. An authorization server generates an access token …

Image for post

23. … and issues the access token to a client application.

Image for post

24. Let’s review what we’ve learned so far. Characters are an “Authorization Server”, a “Client Application” and a “Resource Server”.

Image for post

25. The authorization server generates an access token …

Image for post

26. … and issues the access token to the client application.

Image for post

27. The client application requests the user’s data with the access token.

Image for post

28. The resource server extracts the access token from the request, …

Image for post

29. … confirms that the access token has permissions to access the user’s data …

Image for post

30. … and returns the user’s data to the client application.

Image for post

31. In the flow above, the first step is access token generation by an authorization server. However, in a real flow, the user is asked before an access token is issued.

Image for post

32. First, the client application requests an access token.

Image for post

33. Then, the authorization server asks the user whether to grant the requested permissions to the client application.

Image for post

34. If the user allows the authorization server to issue an access token to the client application, …

Image for post

35. … the authorization server generates an access token …

Image for post

36. … and issues the access token to the client application.

Image for post

37. By the way, pay attention to the part encircled by the yellow ellipse.

Image for post

38. The part represents an access token request and a response to the request.

Image for post

39. And, it is “OAuth 2.0” that has standardized the part. Details of OAuth 2.0 are described in the technical document, RFC 6749 (The OAuth 2.0 Authorization Framework).

Image for post

Next To Read

Diagrams And Movies Of All The OAuth 2.0 Flows

18