Book description
Create powerful applications to interact with popular service providers such as Facebook, Google, Twitter, and more by leveraging the OAuth 2.0 Authorization Framework
About This Book
- Learn how to use the OAuth 2.0 protocol to interact with the world's most popular service providers, such as Facebook, Google, Instagram, Slack, Box, and more
- Master the finer details of this complex protocol to maximize the potential of your application while maintaining the utmost of security
- Step through the construction of a real-world working application that logs you in with your Facebook account to create a compelling infographic about the most important person in the world—you!
Who This Book Is For
If you are an application developer, software architect, security engineer, or even a casual programmer looking to leverage the power of OAuth, Mastering OAuth 2.0 is for you. Covering basic topics such as registering your application and choosing an appropriate workflow, to advanced topics such as security considerations and extensions to the specification, this book has something for everyone. A basic knowledge of programming and OAuth is recommended.
What You Will Learn
- Discover the power and prevalence of OAuth 2.0 and use it to improve your application's capabilities
- Step through the process of creating a real-world application that interacts with Facebook using OAuth 2.0
- Examine the various workflows described by the specification, looking at what they are and when to use them
- Learn about the many security considerations involved with creating an application that interacts with other service providers
- Develop your debugging skills with dedicated pages for tooling and troubleshooting
- Build your own rich, powerful applications by leveraging world-class technologies from companies around the world
In Detail
OAuth 2.0 is a powerful authentication and authorization framework that has been adopted as a standard in the technical community. Proper use of this protocol will enable your application to interact with the world's most popular service providers, allowing you to leverage their world-class technologies in your own application. Want to log your user in to your application with their Facebook account? Want to display an interactive Google Map in your application? How about posting an update to your user's LinkedIn feed? This is all achievable through the power of OAuth.
With a focus on practicality and security, this book takes a detailed and hands-on approach to explaining the protocol, highlighting important pieces of information along the way.
At the beginning, you will learn what OAuth is, how it works at a high level, and the steps involved in creating an application. After obtaining an overview of OAuth, you will move on to the second part of the book where you will learn the need for and importance of registering your application and types of supported workflows. You will discover more about the access token, how you can use it with your application, and how to refresh it after expiration.
By the end of the book, you will know how to make your application architecture robust. You will explore the security considerations and effective methods to debug your applications using appropriate tools. You will also have a look at special considerations to integrate with OAuth service providers via native mobile applications. In addition, you will also come across support resources for OAuth and credentials grant.
Style and approach
With a focus on practicality and security, Mastering OAuth 2.0 takes a top-down approach at exploring the protocol. Discussed first at a high level, examining the importance and overall structure of the protocol, the book then dives into each subject, adding more depth as we proceed. This all culminates in an example application that will be built, step by step, using the valuable and practical knowledge you have gained.
Publisher resources
Table of contents
-
Mastering OAuth 2.0
- Table of Contents
- Mastering OAuth 2.0
- Credits
- About the Author
- About the Reviewers
- www.PacktPub.com
- Preface
- 1. Why Should I Care About OAuth 2.0?
- 2. A Bird's Eye View of OAuth 2.0
- 3. Four Easy Steps
- 4. Register Your Application
- 5. Get an Access Token with the Client-Side Flow
- 6. Get an Access Token with the Server-Side Flow
- 7. Use Your Access Token
- 8. Refresh Your Access Token
-
9. Security Considerations
- What's at stake?
-
Security best practices
- Use TLS!
- Request minimal scopes
- When using the implicit grant flow, request read-only permissions
- Keep credentials and tokens out of reach of users
- Use the authorization code grant flow whenever possible
- Use the refresh token whenever possible
- Use native browsers instead of embedded browsers
- Do not use third-party scripts in the redirection endpoint
- Rotate your client credentials
- Common attacks
- Summary
- 10. What About Mobile?
- 11. Tooling and Troubleshooting
- 12. Extensions to OAuth 2.0
- A. Resource Owner Password Credentials Grant
- B. Client Credentials Grant
-
C. Reference Specifications
- The OAuth 2 Authorization Framework
- The OAuth 2 Authorization Framework: Bearer Token Usage
- OAuth 2.0 Token Revocation
- OAuth 2.0 Thread Model and Security Considerations
- Assertion Framework for OAuth 2.0 Client Authentication and Authorization Grants
- Security Assertion Markup Language (SAML) 2.0 Profile for OAuth 2.0 Client Authentication and Authorization Grants
- JSON Web Token (JWT)
- JSON Web Token (JWT) Profile for OAuth 2.0 Client Authentication and Authorization Grants
- OpenID Connect Core 1.0
- HTTP Authentication: Basic and Digest Access Authentication
- Index
Product information
- Title: Mastering OAuth 2.0
- Author(s):
- Release date: December 2015
- Publisher(s): Packt Publishing
- ISBN: 9781784395407
You might also like
book
Getting Started with OAuth 2.0
Whether you develop web applications or mobile apps, the OAuth 2.0 protocol will save a lot …
book
OAuth 2.0 Cookbook
Efficiently integrate OAuth 2.0 to protect your mobile, desktop, Cloud applications and APIs using Spring Security …
book
Advanced API Security: OAuth 2.0 and Beyond
Prepare for the next wave of challenges in enterprise security. Learn to better protect, monitor, and …
book
OAuth 2 in Action
OAuth 2 in Action teaches you the practical use and deployment of this HTTP-based protocol from …