Lindungi halaman aplikasi Vue daripada akses oleh pengguna yang tidak log masuk
P粉598140294
2023-09-01 11:46:55
<p>Saya mula menggunakan supabase sebagai alternatif kepada firebase. Saya sedang melaksanakan sistem pengesahan mudah untuk aplikasi web vue saya dan saya menghadapi masalah dengan ubah hala.
Saya menggunakan penyelesaian pautan ajaib untuk log masuk pengguna ke https://supabase.com/docs/guides/auth/auth-magic-link tetapi saya tidak pasti bagaimana untuk menyediakan pengalihan log masuk dengan betul pada localhost semasa pembangunan juga Bagaimana untuk menghalang pengguna yang tidak log masuk daripada melihat paparan. </p>
<p>Saya telah melaksanakan penghala pinia dan vue Dalam halaman utama semasa, ini ialah kod yang saya gunakan untuk membenarkan pengguna log masuk: </p>
<pre class="brush:js;toolbar:false;">import { supabase } daripada '../supabase/supabase'
eksport lalai {
nama: 'HomeView',
data() {
kembali {
e-mel pengguna: null
}
},
dicipta() {
},
dipasang() {
//this.initGoogleAuth()
},
kaedah: {
initMagicLinkAuth() {
supabase.auth.signInWithOtp({
e-mel: this.userEmail,
pilihan: {
emailRedirectTo: '/about'
}
})
}
}
}
</pra>
<p>Dalam templat saya mempunyai medan input e-mel ringkas: </p>
<pre class="brush:html;toolbar:false;"><input type="email"class="form-control"E-mel"v-model="userEmail">
<div class="d-grid gap-2">
<button class="btn btn-primary" @click.prevent="initMagicLinkAuth()">Login</button>
</div>
</pra>
<p>Dalam penghala saya, saya mempunyai kod berikut: </p>
<pre class="brush:js;toolbar:false;">import { createRouter, createWebHistory } daripada 'vue-router'
import HomeView daripada '../views/HomeView.vue'
penghala const = createRouter({
sejarah: createWebHistory(import.meta.env.BASE_URL),
laluan: [
{
laluan: '/',
nama: 'rumah',
komponen:HomeView
},
{
laluan: '/about',
nama: 'tentang',
komponen: () => import('../views/AboutView.vue')
}
]
})
eksport penghala lalai
</pra>
<p>Bagaimana untuk menyediakan penghala vue dengan betul untuk menghalang pengguna yang tidak log masuk daripada menavigasi, dan bagaimana untuk menyediakan supabase dengan betul untuk pengalihan? </p>
Diambil daripada: https://blog.logrocket.com/ultimate-guide-authentication-vue-js-supabase/