Vueプロジェクトで権限制御とログイン認証を行う方法
Vue プロジェクトで権限制御とログイン検証を実行する方法には、特定のコード例が必要です。
Vue プロジェクトでは、権限制御とログイン検証は非常に重要な機能です。適切な権限制御とログイン検証により、ユーザーは権限のあるページのみにアクセスできるようになり、ユーザー データのセキュリティが保護されます。この記事では、Vue プロジェクトで権限制御とログイン検証を実装する方法と、具体的なコード例を詳しく紹介します。
ステップ 1: ルーティングと状態管理を導入する
まず、Vue が提供するルーティングと状態管理を使用して、権限制御とログイン検証を実装する必要があります。 Vue Router を使用してページのルーティングを管理し、Vuex を使用してユーザーのステータスを管理できます。
プロジェクトのエントリ ファイル main.js
:
import Vue from 'vue' import VueRouter from 'vue-router' import Vuex from 'vuex' import routes from './router/index.js' // 引入路由配置文件 import store from './store/index.js' // 引入Vuex配置文件 Vue.use(VueRouter) Vue.use(Vuex) const router = new VueRouter({ routes }) new Vue({ router, store, render: h => h(App) }).$mount('#app')
で Vue Router と Vuex を導入して構成します ##router
フォルダーに # を作成します ##ルーティング情報の構成に使用されるindex.js ファイル:
import Vue from 'vue' import Router from 'vue-router' import Home from '@/views/Home.vue' import Login from '@/views/Login.vue' import Admin from '@/views/Admin.vue' import Dashboard from '@/views/Dashboard.vue' import Users from '@/views/Users.vue' import NotFound from '@/views/NotFound.vue' Vue.use(Router) export default new Router({ mode: 'history', routes: [ { path: '/', name: 'home', component: Home }, { path: '/login', name: 'login', component: Login }, { path: '/admin', name: 'admin', component: Admin, children: [ { path: '', name: 'dashboard', component: Dashboard }, { path: 'users', name: 'users', component: Users } ] }, { path: '*', name: 'notfound', component: NotFound } ] })
index.js ファイルを
store フォルダーに作成します。 :
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) export default new Vuex.Store({ state: { user: null, isLoggedIn: false }, mutations: { SET_USER(state, user) { state.user = user }, SET_LOGGED_IN(state, value) { state.isLoggedIn = value } }, actions: { login({ commit }, user) { // 在这里进行登录验证的逻辑 // 成功后设置用户信息和登录状态 commit('SET_USER', user) commit('SET_LOGGED_IN', true) }, logout({ commit }) { // 退出登录,清除用户信息和登录状态 commit('SET_USER', null) commit('SET_LOGGED_IN', false) } } })
Login.vue コンポーネントに追加できます。
<template> <div class="login"> <form @submit.prevent="submit"> <input type="text" v-model="username" placeholder="请输入用户名"> <input type="password" v-model="password" placeholder="请输入密码"> <button type="submit">登录</button> </form> </div> </template> <script> export default { data() { return { username: '', password: '' } }, methods: { submit() { // 在这里调用登录接口进行验证 // 异步返回结果后触发登录操作 this.$store.dispatch('login', { username: this.username, password: this.password }).then(() => { // 登录成功后跳转到首页或其他页面 this.$router.push('/') }).catch(() => { // 登录失败逻辑处理 }) } } } </script>
Admin.vue コンポーネントでは、
created フック関数でログイン検証と権限制御ロジックを実行できます。
<template> <div class="admin"> <h1 id="管理员页面">管理员页面</h1> <!-- 其他内容... --> </div> </template> <script> export default { created() { if (!this.$store.state.isLoggedIn) { // 未登录状态,跳转到登录页面 this.$router.push('/login') } else { // 已登录状态,进行权限控制 if (!this.$store.state.user.isAdmin) { // 非管理员用户,无权限访问 this.$router.push('/404') } } } } </script>
created フック関数でユーザーのログイン状態と権限を判定し、判定結果に基づいて対応するジャンプ操作を実行します。
以上がVueプロジェクトで権限制御とログイン認証を行う方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











json.parse()stringにオブジェクトを使用することは、最も安全で効率的です。文字列がJSON仕様に準拠していることを確認し、一般的なエラーを回避します。 Try ... CATCHを使用して例外を処理して、コードの堅牢性を向上させます。セキュリティリスクがあるeval()メソッドの使用は避けてください。巨大なJSONの弦の場合、パフォーマンスを最適化するために、チャンクされた解析または非同期解析を考慮することができます。

VUE.JSは、中小規模のプロジェクトや迅速な反復に適していますが、Reactは大規模で複雑なアプリケーションに適しています。 1)Vue.jsは使いやすく、チームが不十分な状況やプロジェクトスケールが小さい状況に適しています。 2)Reactにはより豊富なエコシステムがあり、高性能で複雑な機能的ニーズを持つプロジェクトに適しています。

vue.jsでBootstrapを使用すると、5つのステップに分かれています。ブートストラップをインストールします。 main.jsにブートストラップをインポートしますブートストラップコンポーネントをテンプレートで直接使用します。オプション:カスタムスタイル。オプション:プラグインを使用します。

Vue.jsは、特にJavaScriptファンデーションを持つ開発者にとって、学ぶのは難しくありません。 1)その進歩的な設計とレスポンシブシステムは、開発プロセスを簡素化します。 2)コンポーネントベースの開発により、コード管理がより効率的になります。 3)使用例は、基本的および高度な使用法を示しています。 4)一般的なエラーは、vuedevtoolsを介してデバッグできます。 5)V-IF/V-Showや重要な属性を使用するなど、パフォーマンスの最適化とベストプラクティスは、アプリケーションの効率を向上させることができます。

Vue.jsは、主にフロントエンド開発に使用されます。 1)ユーザーインターフェイスとシングルページアプリケーションの構築に焦点を当てた軽量で柔軟なJavaScriptフレームワークです。 2)Vue.jsのコアはその応答性データシステムであり、データが変更されるとビューは自動的に更新されます。 3)コンポーネントの開発をサポートし、UIを独立した再利用可能なコンポーネントに分割できます。

HTMLテンプレートのボタンをメソッドにバインドすることにより、VUEボタンに関数を追加できます。 VUEインスタンスでメソッドを定義し、関数ロジックを書き込みます。

Vue.jsの監視オプションにより、開発者は特定のデータの変更をリッスンできます。データが変更されたら、Watchはコールバック関数をトリガーして更新ビューまたはその他のタスクを実行します。その構成オプションには、すぐにコールバックを実行するかどうかを指定する即時と、オブジェクトまたは配列の変更を再帰的に聴くかどうかを指定するDEEPが含まれます。

VUEマルチページ開発は、VUE.JSフレームワークを使用してアプリケーションを構築する方法です。アプリケーションは別々のページに分割されます。コードメンテナンス:アプリケーションを複数のページに分割すると、コードの管理とメンテナンスが容易になります。モジュール性:各ページは、簡単に再利用および交換するための別のモジュールとして使用できます。簡単なルーティング:ページ間のナビゲーションは、単純なルーティング構成を介して管理できます。 SEOの最適化:各ページには独自のURLがあり、SEOに役立ちます。
