Met deze bibliotheek kunt u Google-authenticatie naadloos integreren in uw Next.js-toepassing, zodat u deze niet helemaal opnieuw hoeft te ontwikkelen.
Het integreren van een veilig authenticatiesysteem is een cruciale ontwikkelingsstap die niet alleen een veilige omgeving voor gebruikers biedt, maar ook vertrouwen in uw product wekt. Dit systeem zorgt ervoor dat hun gegevens worden beschermd en dat alleen geautoriseerde personen toegang hebben tot de applicatie.
Het vanaf de basis opbouwen van een veilige authenticatie kan een tijdrovend proces zijn dat een grondige aanpak vereist begrip van authenticatieprotocollen en -processen, vooral bij het omgaan met verschillende authenticatie aanbieders.
Met NextAuth kunt u uw focus verleggen naar het bouwen van de kernfuncties. Lees verder om te leren hoe u Google social login in uw applicatie kunt integreren met behulp van NextAuth.
Hoe werkt NextAuth
VolgendeAuth.js is een open-source authenticatiebibliotheek die het proces van toevoegen vereenvoudigt
authenticatie en authorisatie functionaliteit voor Next.js-applicaties en het aanpassen van authenticatieworkflows. Het biedt een scala aan functies, zoals e-mail, authenticatie zonder wachtwoord en ondersteuning voor verschillende authenticatieproviders zoals Google, GitHub en meer.Op een hoog niveau fungeert NextAuth als een middleware, die het authenticatieproces tussen uw applicatie en de provider vergemakkelijkt. Onder de motorkap, wanneer een gebruiker probeert in te loggen, wordt hij doorgestuurd naar de inlogpagina van Google. Na succesvolle authenticatie retourneert Google een payload die de gegevens van de gebruiker bevat, zoals hun naam en e-mailadres. Deze gegevens worden gebruikt om toegang tot de applicatie en zijn bronnen te autoriseren.
Met behulp van de payload-gegevens maakt NextAuth een sessie voor elke geverifieerde gebruiker en slaat het sessietoken op in een beveiligde HTTP-only cookie. Het sessietoken wordt gebruikt om de identiteit van de gebruiker te verifiëren en de authenticatiestatus te behouden. Dit proces geldt ook voor andere providers met kleine variaties in de implementatie.
Registreer uw Next.js-toepassing in de Google Developer Console
NextAuth biedt ondersteuning voor de Google-authenticatieservice. Om ervoor te zorgen dat uw applicatie communiceert met Google API's en gebruikers in staat stelt zich te authenticeren hun Google-inloggegevens, moet u uw app registreren op de Google-ontwikkelaarsconsole en verkrijg een klant identificatie En Cliënt geheim.
Navigeer hiervoor naar Google-ontwikkelaarsconsole. Log vervolgens in met uw Google-account om toegang te krijgen tot de console. Nadat u bent ingelogd, maakt u een nieuw project aan.
Selecteer op de overzichtspagina van het project de API's en services tabblad uit de lijst met services in het linkermenuvenster en ten slotte de Referenties keuze.
Klik op de Credentials maken knop om uw klant-ID en klantgeheim te genereren. Geef vervolgens het type toepassing op uit de gegeven opties en geef vervolgens een naam op voor uw toepassing.
Geef daarna de thuisroute-URL van uw app op en geef ten slotte de geautoriseerde omleidings-URI voor uw toepassing op. Voor dit geval zou het moeten zijn http://localhost: 3000/api/auth/callback/google zoals gespecificeerd door de instellingen van de Google-provider van NextAuth.
Na succesvolle registratie zal Google u voorzien van een Client ID en Client Secret voor gebruik in uw app.
Stel de NextJS-toepassing in
Om aan de slag te gaan, maakt u lokaal een Next.js-project:
npx create-next-app next-auth-app
Nadat de installatie is voltooid, navigeert u naar de nieuw gemaakte projectmap en voert u deze opdracht uit om de ontwikkelingsserver te laten draaien.
npm run dev
Open uw browser en navigeer naar http://localhost: 3000. Dit zou het verwachte resultaat moeten zijn.
U kunt de code van dit project vinden in de bijbehorende GitHub-opslagplaats.
Het .env-bestand instellen
Maak in de hoofdmap van uw project een nieuw bestand en geef het een naam .env om uw klant-ID, geheim en de basis-URL te bewaren.
NEXT_PUBLIC_GOOGLE_CLIENT_ID= 'klant identificatie'
NEXT_PUBLIC_GOOGLE_CLIENT_SECRET= 'geheim'
NEXT_PUBLIC_NEXTAUTH_URL= ' http://localhost: 3000'
De NextAUTH-URL wordt gebruikt om de basis-URL van uw toepassing op te geven, die wordt gebruikt voor het omleiden van gebruikers nadat de authenticatie is voltooid.
Integreer NextAuth in uw Next.js-toepassing
Installeer eerst de bibliotheek van NextAuth in uw project.
npm install next-auth
Vervolgens in de /pages map, maak een nieuwe map aan en geef deze een naam api. Wijzig de map in de api map en maak een andere map met de naam autoriseren. Voeg in de auth-map een nieuw bestand toe en geef het een naam [...nextauth].js en voeg de volgende regels code toe.
importeren VolgendeAuth van"next-auth/next";
importeren GoogleProvider van"next-auth/providers/google";
exporterenstandaard VolgendeAuth({
aanbieders:[
GoogleProvider({
client-ID: proces.env. NEXT_PUBLIC_GOOGLE_CLIENT_ID,
clientSecret: proces.env. NEXT_PUBLIC_GOOGLE_CLIENT_SECRET,
}),
]
});
Deze code configureert Google als authenticatieprovider. De NextAuth-functie definieert het Google-providerconfiguratieobject dat twee eigenschappen opneemt: een client-ID en een clientgeheim dat de provider initialiseert.
Open vervolgens de pagina's/_app.js bestand en breng de volgende wijzigingen aan in de code.
importeren'../styles/globals.css'
importeren { SessieProvider } van"volgende-authenticatie/reageren"
functieMijnApp({ Component, pageProps: { session, ...pageProps } }) {
opbrengst (
</SessionProvider>
)
}
exporterenstandaard MijnApp
NextAuth's SessieProvider component biedt beheerfunctionaliteit voor authenticatiestatus aan de Next.js-app. Het duurt een sessie prop die de authenticatiesessiegegevens bevat die zijn geretourneerd door de API van Google, inclusief gebruikersgegevens zoals hun ID, e-mailadres en toegangstoken.
Door het inpakken van de MijnApp component met de SessionProvider component wordt het authenticatiesessieobject met gebruikersgegevens beschikbaar gesteld in de hele applicatie, waardoor de applicatie kan blijven bestaan en pagina's kan weergeven op basis van hun authenticatiestatus.
Configureer het bestand index.js
Open de pagina's/index.js bestand, verwijder de standaardcode en voeg de onderstaande code toe om een inlogknop te maken die gebruikers naar een inlogpagina leidt.
importeren Hoofd van'volgende/hoofd'
importeren stijlen van'../styles/Home.module.css'
importeren { gebruikRouter } van'volgende/router';exporterenstandaardfunctieThuis() {
const router = gebruikRouter();
opbrengst (
Create Next App</title>
"description" content="Gegenereerd door create next app" />
"icon" href="/favicon.ico" />
</Head>
Welkom bij " https://nextjs.org">Next.js!</a>
</h1>
Ga aan de slag door in te loggen{' ' }
met uw Google-account</code>
</div>
)
}
Deze code gebruikt de Next.js useRouter hook om routering binnen de applicatie af te handelen door een routerobject te definiëren. Wanneer op de inlogknop wordt geklikt, roept de handlerfunctie de methode router.push aan om om te leiden de gebruiker naar de inlogpagina.
Maak een inlogverificatie aan Pagina
Maak in de directory pages een nieuw bestand Login.js en voeg vervolgens de volgende regels code toe.
importeren { useSession, signIn, signOut } van "next-auth/react"
importeren { useRouter } van 'next /router';
importeer stijlen uit '../styles/Login.module.css'exporteren standaard functie < span>Inloggen() {
const { data: sessie } = useSession()
const router = useRouter();
if (sessie) {
return (
"title">Volgende app maken</h1>
Ondertekend < span>in als {session.user.email}
</h2>