Lesson 45/101

Tutorials Next.js Tutorial

Protected Routes — Complete Guide

Protected Routes — Complete Guide: free step-by-step lesson with examples, common mistakes, and interview tips — part of Next.js Tutorial on Toolliyo Academy.

On this page

Next.js Tutorial (LearnHub) · Lesson 44 of 100

Protected Routes

Beginner ✓Intermediate ✓AdvancedProfessional

Advanced · 3 — Production skills · ~18 min read · Module 5: SEO & Deploy

Introduction

This is advanced material: Protected Routes. It is what teams use on live products. Read the example carefully and try changing one line at a time to see what happens. Protected routes only render for signed-in users with the right role. In App Router you check the session in middleware, layouts, or Server Components. Paid LearnHub lessons and instructor analytics must not appear to guests or students without enrollment.

An app on your laptop is not finished until students can open it on the internet.

When will you use this?

Use when you are ready to put LearnHub online for users or employers to try.

  • Publishing means pushing LearnHub to Vercel, Docker, or Azure so students can access it online.
  • CI/CD runs npm test and npm run build automatically on every git push.

Real-world: Flipkart-style catalog

The E-commerce team building Flipkart-style catalog uses Protected Routes to apply Protected Routes when building search, filters, and fast product listing pages. shoppers never see the TypeScript files — they just get a fast, reliable search, filters, and fast product listing pages.

Production-style code

// app/dashboard/layout.tsx
import { redirect } from 'next/navigation';
import { getServerSession } from 'next-auth';
import { authOptions } from '@/lib/auth';

export default async function DashboardLayout({
  children
}: { children: React.ReactNode }) {
  const session = await getServerSession(authOptions);
  if (!session) redirect('/login');
  return <section className="dashboard-shell">{children}</section>;
}

What happens in production: In Flipkart-style catalog, getting Protected Routes right means shoppers trust the search, filters, and fast product listing pages every day.

Lesson example (start here)

Copy this smaller example first. Once it works, compare it with the real-world code above.

// app/dashboard/layout.tsx
import { redirect } from 'next/navigation';
import { getServerSession } from 'next-auth';
import { authOptions } from '@/lib/auth';

export default async function DashboardLayout({
  children
}: { children: React.ReactNode }) {
  const session = await getServerSession(authOptions);
  if (!session) redirect('/login');
  return <section className="dashboard-shell">{children}</section>;
}

Line-by-line walkthrough

CodeWhat it means
// app/dashboard/layout.tsxComment — notes for humans; the compiler ignores it.
import { redirect } from 'next/navigation';Imports navigation hooks — useRouter, usePathname, useSearchParams in Client Components.
import { getServerSession } from 'next-auth';Imports a module so you can use its exports in this file.
import { authOptions } from '@/lib/auth';Imports a module so you can use its exports in this file.
export default async function DashboardLayout({Default export — the main page or component this file provides to Next.js.
childrenPart of the Protected Routes example — read it together with the lines before and after.
}: { children: React.ReactNode }) {Closes a block started by { above.
const session = await getServerSession(authOptions);Part of the Protected Routes example — read it together with the lines before and after.
if (!session) redirect('/login');Part of the Protected Routes example — read it together with the lines before and after.
return <section className="dashboard-shell">{children}</section>;Returns JSX — what the user sees in the browser.
}Closes a block started by { above.

How it works (big picture)

  • Layout runs on the server before children render.
  • No session means immediate redirect — the dashboard HTML never leaks to guests.

Do this on your computer

  1. Add auth check to dashboard layout.
  2. Visit /dashboard logged out — confirm redirect.
  3. Log in and confirm access.
  4. Add role check for /instructor routes.
  5. Read the real-world section and name which part of LearnHub uses this topic.
  6. Run the example locally with npm run dev and confirm the same behavior.
  7. Change one value in the example (route, text, or course id) and predict what will happen before you save.

Experiments — try changing this

  • Change a string or route in the example and save — watch the browser update.
  • Break the code on purpose (remove a bracket), read the error overlay, then fix it.
  • Change the API URL or course id and see how the page data changes.
  • Use npm run dev while editing Protected Routes — the page hot-reloads on save.

Remember

Protect on the server first. Use middleware for broad path rules. Use layout session checks for nested dashboard areas.

Common questions

Middleware vs layout auth?

Middleware runs early for redirects; layout checks are fine for section-specific rules.

How long should I spend on Protected Routes?

Until you can explain it in your own words and run the example without looking at the answer. Beginners often need 30–60 minutes per new concept; setup lessons may take one afternoon.

What if I get stuck on Protected Routes?

Re-read the line-by-line walkthrough, check the terminal and browser overlay for errors, and compare your code character-by-character with the example. Search the exact error text — someone else had it too.

Where is Protected Routes used in real jobs?

See the real-world section above — the same pattern appears in LMS, e-commerce, SaaS, and dashboards. Interviewers ask you to explain it using one concrete example.

Next.js Tutorial
Course syllabus
Start Here Next.js Complete Beginner's Guide
Module 1: Next.js Foundations Introduction to Next.js — Complete Guide Installing Next.js — Complete Guide Understanding Project Structure — Complete Guide App Router Basics — Complete Guide Pages and Layouts — Complete Guide React Components in Next.js — Complete Guide Client Components — Complete Guide Server Components — Complete Guide Routing Fundamentals — Complete Guide Dynamic Routing — Complete Guide
Module 2: Layouts & Styling Nested Layouts — Complete Guide Navigation and Linking — Complete Guide Static Assets — Complete Guide CSS Modules — Complete Guide Tailwind CSS in Next.js — Complete Guide Data Fetching — Complete Guide Server Actions — Complete Guide Forms in Next.js — Complete Guide Form Validation — Complete Guide Authentication Basics — Complete Guide
Module 3: Data & Forms Middleware — Complete Guide API Route Handlers — Complete Guide Database Integration — Complete Guide File Upload — Complete Guide Image Optimization — Complete Guide Metadata and SEO — Complete Guide Performance Optimization — Complete Guide Deployment — Complete Guide E-Commerce App Project — Complete Guide SaaS Dashboard Project — Complete Guide
Module 4: Auth & APIs SSR vs SSG vs ISR — Complete Guide Streaming and Suspense — Complete Guide Loading and Error UI — Complete Guide Route Groups — Complete Guide Parallel Routes — Complete Guide Intercepting Routes — Complete Guide Edge Runtime — Complete Guide Caching in Next.js — Complete Guide Revalidating Data — Complete Guide TanStack Query in Next.js — Complete Guide
Module 5: SEO & Deploy NextAuth.js — Complete Guide Clerk Authentication — Complete Guide OAuth and Social Login — Complete Guide Protected Routes — Complete Guide Prisma ORM — Complete Guide MongoDB with Next.js — Complete Guide PostgreSQL with Next.js — Complete Guide Environment Variables — Complete Guide Unit Testing — Complete Guide Integration Testing — Complete Guide
Module 6: Advanced Routing Playwright E2E — Complete Guide CI/CD for Next.js — Complete Guide Internationalization — Complete Guide Accessibility — Complete Guide XSS and CSRF Protection — Complete Guide Security Headers — Complete Guide Rate Limiting — Complete Guide Structured Data — Complete Guide Sitemap and Robots — Complete Guide Zustand State — Complete Guide
Module 7: Auth & Database Redux Toolkit in Next.js — Complete Guide React Context Patterns — Complete Guide Monorepo with Turborepo — Complete Guide Docker for Next.js — Complete Guide Vercel Deployment — Complete Guide AWS Amplify — Complete Guide Azure Static Web Apps — Complete Guide Micro Frontends — Complete Guide Remix vs Next.js — Complete Guide Web Vitals Tuning — Complete Guide
Module 8: Quality & Security Font Optimization — Complete Guide Bundle Analysis — Complete Guide Blog Application Project — Complete Guide Student Portal Project — Complete Guide Job Portal Project — Complete Guide Hospital Portal Project — Complete Guide Food Delivery Frontend Project — Complete Guide Banking Dashboard Project — Complete Guide LMS Course Player Project — Complete Guide CRM Admin Project — Complete Guide
Module 9: Cloud & Scale Real-Time Chat Project — LearnHub Project Multi-Tenant SaaS Project — LearnHub Project Inventory Dashboard Project — LearnHub Project Travel Booking Project — LearnHub Project News Portal Project — LearnHub Project Portfolio Site Project — LearnHub Project Enterprise Architecture — LearnHub Project Clean Folder Structure — LearnHub Project API Design Patterns — LearnHub Project Error Handling Patterns — LearnHub Project
Module 10: Portfolio Projects Logging and Monitoring — LearnHub Project Stripe Payments — LearnHub Project Analytics and Observability — LearnHub Project Storybook with Next.js — LearnHub Project GraphQL with Next.js — LearnHub Project Content Security Policy — LearnHub Project Partial Prerendering — LearnHub Project Server Actions Security — LearnHub Project Production Checklist — LearnHub Project Next.js Career Roadmap — LearnHub Project
Toolliyo Assistant
Ask about tutorials, ebooks, training, pricing, mentor services, and support. I use public site content only—not admin or internal tools.

care@toolliyo.com

Need callback? Share your details