Rumah >hujung hadapan web >tutorial js >Log masuk/daftar dengan firebase Vue JS #STEP (log masuk)
Mari kita cipta laluan log masuk projek, mari fokus pada struktur ini di bawah.
. ├── src │ └── router │ └── index.js
Dalam fail index.js kami akan menambah yang berikut:
import { createRouter, createWebHistory } from 'vue-router' import { getAuth, onAuthStateChanged } from 'firebase/auth' import Login from '@/module/login/view/login.vue' import Register from '@/module/register/view/register.vue' import Home from '@/module/home/view/home.vue' const router = createRouter({ history: createWebHistory(), routes: [ { path: '/', name: 'home', component: Home, meta: { requiresAuth: true } }, { path: '/login', name: 'Login', component: Login }, { path: '/cadastro', name: 'Register', component: Register } ] }) const getCurrentUser = () => { return new Promise((resolve, reject) => { const removeListener = onAuthStateChanged( getAuth(), (user) => { removeListener() resolve(user) }, reject ) }) } router.beforeEach(async (to, from, next) => { const currentUser = await getCurrentUser() if (to.matched.some((record) => record.meta.requiresAuth)) { if (currentUser) { next() } else { alert("Você não tem acesso a essa página, por favor, autentique-e!") next('/login') } } else if ( currentUser && (to.path === '/login' || to.path === '/cadastro' ) { next('/') } else { next() } }) export default router
Perhatikan bahawa sekarang, fail laluan kami lebih penuh, kami menambahkan import firebase/auth supaya kami boleh membuat pengesahan supaya pengguna tidak boleh mengakses skrin tanpa disahkan.
Ringkasnya, bahagian di bawah penghala const ini menyemak pengesahan pengguna sebelum setiap navigasi pada laluan yang dilindungi. Fungsi getCurrentUser menggunakan kaedah onAuthStateChanged untuk memantau pengesahan dan mengembalikan janji dengan pengguna yang disahkan. Dalam router.beforeEach, ia menyemak sama ada laluan memerlukan pengesahan (ditunjukkan oleh meta.requiresAuth). Jika laluan dilindungi dan pengguna disahkan, ia membenarkan akses (next()). Jika pengguna tidak disahkan, ia memaparkan amaran dan mengubah hala ke /log masuk. Jika pengguna sudah disahkan dan cuba mengakses /login atau /cadastro, ia mengubah hala mereka ke halaman utama (/), selain itu, kami menambah laluan ke Laman Utama dan satu lagi ke /log masuk.
Mengenai Laman Utama, saya tidak akan mencipta fail, saya hanya meletakkannya di sana supaya anda boleh melihat cara ia berfungsi untuk menyemak sama ada pengguna boleh mempunyai akses atau tidak.
Sekarang, mari kita teruskan untuk mencipta komponen pendaftaran sebenar kita, fungsinya dan panggilannya, jadi mari kita fokus pada struktur ini.
. ├── src │ └── module │ └── login | └── component | └── formlogin.vue | └── controller | └── loginController.js | └── view | └── login.vue
fail formLogin.vue.
<template> <div class="d-flex justify-center align-center fill-height"> <v-card class="mx-auto px-6 py-8" max-width="400" min-width="300"> <v-form :disabled="controller.loading.value" :readonly="controller.loading.value"> <h1 class="text-center mb-3">Entrar</h1> <v-text-field class="mb-2" label="E-mail" variant="underlined" clearable :rules="[controller.regras.required, controller.regras.validEmail]" v-model="controller.email.value" ></v-text-field> <v-text-field label="Senha" placeholder="Informe sua senha" variant="underlined" clearable @click:append-inner="controller.showPassword.value = !controller.showPassword.value" :append-inner-icon="controller.showPassword.value ? 'mdi-eye' : 'mdi-eye-off'" :type="controller.showPassword.value ? 'text' : 'password'" :rules="[ controller.regras.required, (v) => (v && v.length >= 6) || 'A senha deve ter no mínimo 6 caracteres' ]" v-model="controller.password.value" ></v-text-field> <p v-if="controller.errMsg.value" class="text-red text-center"> {{ controller.errMsg.value }} </p> <br /> <v-btn color="#5865f2" size="large" type="submit" variant="elevated" block :loading="controller.loading.value" :disabled=" !controller.password.value || controller.password.value.length < 6 || controller.loading.value " @click="controller.login" > Entrar </v-btn> <br /> <v-divider class="mx-10"></v-divider> <div class="d-flex justify-center mt-3"> <button @click="controller.signInWithGoogle"> <v-avatar :image="logoGoogle"></v-avatar> </button> </div> <p class="text-center mt-5"> Ainda não possui uma conta? <a href="/cadastro">Cadastre-se</a> </p> </v-form> </v-card> </div> </template> <script setup> import logoGoogle from '../../../assets/images/imagem_logo_google.png' const { controller } = defineProps({ controller: { type: Object, required: true } }) </script>
fail loginController.js.
import { ref } from 'vue' import { getAuth, signInWithEmailAndPassword, GoogleAuthProvider, signInWithPopup, } from 'firebase/auth' import { useRouter } from 'vue-router' const loginController = () => { const email = ref('') const password = ref('') const errMsg = ref('') const loading = ref(false) const showPassword = ref(false) const regras = { required: (v) => !!v || 'Obrigatório', validEmail: (v) => { if (v.length > 0) { const pattern = /^(([^<>()[\]\.,;:\s@"]+(\.[^<>()[\]\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/ return pattern.test(v) || 'E-mail inválido' } return true }, const router = useRouter() const auth = getAuth() // Essa função é responsável por realizar o login com o firebase apenas informando o e-mail e senha const login = async () => { try { loading.value = true errMsg.value = '' await signInWithEmailAndPassword(auth, email.value, password.value) router.push('/') } catch (error) { // Note que aqui, temos um switch/case com os possíveis erros que o firebase retorna, essa variável `errMsg` está lá no `formLogin.vue` para que o usuário possa ver o erro que está retornando switch (error.code) { case 'auth/invalid-email': errMsg.value = 'E-mail inválido!' break case 'auth/user-not-found': errMsg.value = 'Usuário não encontrado!' break case 'auth/wrong-password': errMsg.value = 'Senha incorreta!' break default: errMsg.value = 'E-mail ou senha incorretos!' break } } finally { loading.value = false } } // Essa função é responsável por realizar o login com o firebase utilizando o provedor Google const signInWithGoogle = async () => { try { loading.value = true const provider = new GoogleAuthProvider() await signInWithPopup(auth, provider) router.push('/') } catch (error) { alert(error) } finally { loading.value = false } } return { email, password, errMsg, loading, showPassword, regras, login, signInWithGoogle } } export { loginController }
Fail Log masuk.vue.
<template> <form-login :controller="controller" /> </template> <script setup> import { loginController } from '../controller/loginController' import FormLogin from '../component/formLogin.vue' const controller = loginController() </script>
Dan dengan itu, kami menyelesaikan skrin pendaftaran dan log masuk kami, dalam siaran ini kami menambah laluan ke /login, kami menambah pengesahan pada router/index.js supaya pengguna hanya boleh mengakses halaman utama jika ia disahkan dan kami mencipta komponen log masuk , pada penghujung semua, mengakses /log masuk anda akan melihat skrin yang serupa dengan skrin di bawah:
Saya mengucapkan terima kasih kerana membaca posting saya sehingga akhir, saya harap ini membantu ramai orang yang menghadapi kesukaran untuk membuatnya berfungsi atau yang mula berkembang. Sebarang masalah yang anda hadapi, jangan teragak-agak untuk mengulas dan bila-bila masa saya boleh saya akan menganalisis masalah anda dan cuba membantu anda.
Atas ialah kandungan terperinci Log masuk/daftar dengan firebase Vue JS #STEP (log masuk). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!