Mengendalikan Vue Router (mod sejarah) dan ubah hala luaran Webpack
P粉681400307
P粉681400307 2023-08-28 12:13:17
0
1
646
<p>SO Komuniti,</p> <p>Saya cuba menambah pengesahan luaran pada aplikasi Vue 2 sedia ada. Masalah yang saya hadapi ialah apabila IdP luaran mengubah hala semula ke aplikasi Vue dengan laluan <code>/redirect</code>, Penghala Vue nampaknya tidak menghormati laluan dan laluan yang dikemas kini ke komponen yang betul . Dalam erti kata lain, Penghala Vue akan menghala ke komponen <kod>/</kod> </p> <p>Vue Router menetapkan <kod>mod: 'sejarah'</kod> dan set Webpack <kod>historyApiFallback: benar,</kod>. </p> <h1>Tingkah laku semasa: </h1> <ol> <li>Pengguna menavigasi ke <kod>https://localhost:8080/</code> dan komponen <kod>Log masuk</code> </li> <li>Pengguna memasukkan ID mereka dan diubah hala ke IdP luaran. </li> <li>Selepas pengesahan berjaya, IdP kembali ke URL ubah hala yang ditentukan: <kod>https://localhost:8080/redirect</code></li> <li>Disebabkan mod sejarah, Webpack menghantar penyemak imbas ke <code>/</code>, yang mengembalikan komponen <code>Log</code> </li> <li>Dalam komponen <kod>Log masuk</kod>, penghala <kod>dipasang()</kod> .push({ laluan: '/redirect' });</code></li> <li>Vue Router pergi ke laluan <code>/</code> dan bukannya <code>/redirect</code></li> </ol> <h2>技术细节:</h2> <p>Vue - 2.5.15</p><p> 路由器视图 - 3.0.0</p><p> Webpack - 4.17.1</p><p> Webpack 开发服务器 - 3.1.4</p> <h2><code>webpack.dev.js</code></h2> <pre class="brush:php;toolbar:false;">devServer: { historyApiFallback: benar,</pre> <h2><code>router.js</code></h2> <pre class="brush:php;toolbar:false;">const router = new VueRouter({ mod: 'sejarah', laluan: [ ... { laluan: '/redirect', komponen: Ubah hala, }, { laluan: '/', ubah hala: () => { }, ... router.beforeEach((kepada, dari, seterusnya) => { pengguna const = store.state.user.authorizedUser const toPath = to.path if (toPath === '/redirect') kembali });</pre> <h2><code>App.vue</code></h2> <pre class="brush:php;toolbar:false;">Vue baharu({ el: '#login', render: h => h(Log Masuk), kedai, })</pre> <h2><kod>登录.vue</code></h2> <pre class="brush:php;toolbar:false;">mounted() { if (window.location.pathname === '/redirect') router.push({ path: '/redirect' }); }</pre> <p>请告诉我是否需要提供任何其他细节或代码。提前感谢您的帮助。</p>
P粉681400307
P粉681400307

membalas semua(1)
P粉208469050

Jadi, masalahnya nampaknya dalam komponen Login 在路由器启动之前充当交通警察的角色。我不得不编辑 Login 组件以手动挂载 Redirect peringkat atasan.

Saya tidak mengesyorkan persediaan ini.

Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan