YoVDO

PHP User Authentication Course (How To)

Offered By: Treehouse

Tags

PHP Courses Web Development Courses User Authentication Courses Authorization Courses JSON Web Tokens Courses Cookies Courses Password Hashing Courses

Course Description

Overview

Learn how to implement a custom user authentication system that controls users access to web resources, using password hashing and JSON Web Tokens for security. The system lets users sign up, log in, and log out, limiting access to certain actions based on authorization.

What you'll learn

  • Authentication vs Authorization
  • Cookies vs. Session Storage
  • JSON Web Tokens (JWT)
  • Securing Passwords

Syllabus

What is Authentication

You may think that authentication is one of the easiest parts of your application, and yes, it can be. However, to do authentication correctly can be a very difficult thing. If you manage your passwords incorrectly, it opens you up to a huge security vulnerability that will cost you later on down the road. Learning about the basics is the first place to start.

Chevron 6 steps
  • Authentication vs Authorization

    2:11

  • Application Overview

    1:26

  • AuthN vs AuthZ

    3 questions

  • Cookies vs. Session Storage

    2:57

  • JSON Web Tokens

    1:54

  • Cookies vs Sessions

    5 questions

Building the Library

It is time to build the core of our application without any of the complexity of authentication or authorization. This stage is all about setting up the files we need for viewing our books and adding more to our list.

Chevron 10 steps
  • Building the Book List

    12:02

  • Adding Books

    3:38

  • HTTP Foundation

    4 questions

  • Modifying Books

    6:37

  • Edit Procedure

    2:44

  • Deleting Books

    1 objective

  • Book Rating System

    6:23

  • Accepting the Vote

    3:45

  • Refactoring

    1:46

  • HTTP Foundation

    1 objective

Adding Authentication to Your Application

We now have the core of our application built, however it is open to the world to use and edit/delete any book. We should set up some sort of authentication system to prevent this and allow a user to “own”!

Chevron 13 steps
  • Registration System

    6:08

  • Securing Passwords

    5:38

  • Login Systems

    4:53

  • Building a JWT

    4:52

  • Authentication Review

    5 questions

  • Working with Cookies

    4:24

  • Require Authentication

    5:22

  • Logging Out

    3:13

  • Flash Messages

    5:29

  • Cookies and Flash Messages

    3 questions

  • User Profile

    9:30

  • Reset Password

    4:42

  • Password Hashing

    1 objective

Setting up Authorization System

The last part of our project is a way to authorize a user to let them do things based on their role. We discussed in Stage 1 the difference between authentication, which we just finished, and authorization. We will now create the role of administrator who can manage users and edit and delete any book on the site.

Chevron 7 steps
  • Creating Helper Functions

    6:51

  • User Admin Panel

    11:03

  • Combine Functions

    1 objective

  • Adding Authorization Checks

    4:52

  • Update the Application

    6:46

  • Series Summary

    0:42

  • User Authorization Review

    10 questions


Related Courses

User Authentication & Authorization in Express
Codecademy
Software Security for Web Applications
Codio via Coursera
Fondant Techniques: The Sweet Treat Tower
Craftsy
Secrets of Gluten-Free Baking
Craftsy
Show-Stopping Make-Ahead Desserts
Craftsy