快速开发Vue解决方案

​ Vue开发需要node 环境,其实上在开发过程中会遇到一些你想不到的问题比如 npm工具版本node 环境不匹配(你把其他项目导入自己的环境)

vueelementadmin(是一个官方提供的现成的项目) 是一个后台前端解决方案,它基于 vueelementui 实现。它使用最新前端技术栈,内置i18n 国际化解决方案动态路由权限验证,提炼了典型的业务模型,提供了丰富的功能组件,它可以帮助你快速搭建企业级后台产品原型

vueelementadmin 定位后台集成方案,不太适合当基础模板来进行二次开发,因为本项目集成了很多你可能用不到的功能,会造成不少的代码冗余。

官方还提供了一套基础模板 vueadmintemplate我们基于它进行二次开发,想要什么功能或者组件就去
vueelementadmin 那里复制过来。

一、克隆项目二次开发

1.1 下载安装 git 工具

下载安装 Git ,傻瓜式安装即。下载地址 https://gitscm.com/download

在这里插入图片描述

1.2 克隆 vueelementadmin

(也可以通过直接解压 vueelementadmin项目压缩包然后进行二次开发)

​ 克隆 vueelementadmin 项目安装依赖

git clone https://github.com/PanJiaChen/vueelementadmin.git

git clone https://gitee.com/panjiachen/vueelementadmin.git

解决下载满的问题这里设置下载地址

npm config set registry https://registry.npm.taobao.org

依赖下载解决办法npm installregistry=https://registry.npm.taobao.org

在这里插入图片描述

我们vueelementadmin 当做后台集成方案然后vueadmintemplate 的基础上进行二次开发,想要什么功能或者组件就去 vueelement-admin 那里复制过来,所以我们在克隆vue-admintemplate 到本。

1.3 克隆 vue-admin-template

​ (也可以通过直接解压 vue-element-admin项目压缩包,然后进行二次开发)

​ 克隆 vue-admin-template 项目与安装依赖

git clone https://github.com/PanJiaChen/vue-admin-template.git

git clone https://gitee.com/panjiachen/vue-admin-template.git

浏览器访问 http://localhost:952

在这里插入图片描述

1.4 目录结构

​ 本项目已经生成了一个完整的开发框架,提供了涵盖中后台开发的各类功能和坑位,下面是整个项目的目录结构

在这里插入图片描述

二、Vue快速开发模板基本调整

​ 在原有的项目的基础上我们要对项目做一些基本的调整 ,比如修改 logo 之类的操作等。

2.1 项目重命名

重命名项目名字需要搭配package.json 文件中去修改

在这里插入图片描述

​ 如果项目中有 package-lock.json 文件则和上面的修改方式一样。

2.2 ElementUI 中文版

​ vue 的脚手架使用的 EelementUI 组件是英文版本,所以很多提示都是英文的。

在这里插入图片描述

修改element-ui中文后的展示效果

在这里插入图片描述

2.3 Eslint 语法规范检查

​ ESLint 是一个用来按照规则给出报告的代码检测工具,使用它可以避免低级错误统一代码风格,也保证了代码的可读性。

​ 如果不想使用则可以修改 vue.config.js 文件,如下:

在这里插入图片描述

2.4 更改头部 title 和 Logo

​ 在src / sttings.js 中修改页面title固定头部显示logo

在这里插入图片描述

2.5 修改项目端口号

​ vue项目也有自己端口号,修改方式需要在 vue.config.js文件中修改

在这里插入图片描述

2.6 替换logo图标

​ 找到 src / layout / index.vue 文件 和 src / layout /components /Sidebar /Logo.vue 文件进行修改。

这里 我们自己先选定好需要替换logo图片保存到 src /assets —— 公用的静态资源 文件中,后续直接引用即可

在这里插入图片描述

修改后效果展示

在这里插入图片描述

2.7 替换面包屑

​ 面包屑就是指的组件在导航页面前显示的小图标我们可以通过修改路由配置文件中进行修改配置 src / router /index.js 文件中,找到对应组件的配置信息模快即可进行修改。

在这里插入图片描述

这里icon 图标选择,也可以通过 element-ui 官方组件中的图标去选择一个,进行替换即可

在这里插入图片描述

替换后的效果图

在这里插入图片描述

三、Vue-admin-element登录流程分析

​ Vue-admin-element 的登陆是非常复杂的,所以暂时你只需要知道登陆的流程就行,不用去追究每一行代码。

通过下面几个文件的分析观察,整理Vue-admin-element 二次开发模板登录流程。

3.1 store仓库中心

store —— 全局状态管理 vuex 数据存储中心数据包括了 data函数),里面数据可以项目的所有组件共享

在这里插入图片描述

3.2 观察 src/main.js 文件

​ main.js —— 入口文件 加载组件、初始化vue实例等。 main.js 文件中导入store 模快。在这里插入图片描述

3.3 登录组件代码

views —— 所有的自定义组件

一步:观察在 src / views / login / index.vue 自定义组件下的login文件夹中的 index.vue 自定义组件中的核心代码。

在这里插入图片描述

3.4 store仓库中的user.js

​ 第二步找到 store / modules / user.js 的核心代码。该user.js 文件中定义了两种类型方法,分别是定义mutations{}定义方法actions{} 中定义的方法

​ 其中 mutations 中定义了 四个方法分别是 RESET_STATE、SET_TOKEN、SET_NAME、SET_AVATAR。

在这里插入图片描述

actions 中定义的方法logingetInfo、logoutresetToken 在这里插入图片描述

注:store数据仓库中心,里面定义的两类方法,一类定义在 actions 中(这里方法通过$store.dispatch(‘user/login’,参数)方式出发),一类定义在 mutations 中(这里的方法通过 commit(‘SET_TOKEN’, data.token) 方式进行触发)。

3.5 src/utils/auth.js 文件

​ 在src/store/modules /user.js 文件中也引入了 src/utils/auth.js 文件中的三个方法。

import { getToken, setToken, removeToken } from '@/utils/auth'

​ 这里来观察一下 该文件下的这几个方法,都是对token操作方法。

import Cookies from 'js-cookie'

//这里存储到浏览器 和 在浏览器中取tokenkey都是一样的
const TokenKey = 'vue_admin_template_token'

export function getToken() {  
  return Cookies.get(TokenKey)
}

export function setToken(token) {//user.js中的登录方法中存储token到浏览器时调用的方法
  return Cookies.set(TokenKey, token)
}

export function removeToken() {
  return Cookies.remove(TokenKey)
}

3.6 src/api/user.js 文件

​ 在src/store/modules /user.js 文件中也引入了 src/api/user.js 文件 中的 login、getInfo、loginOut 三个方法。

在这里插入图片描述

3.7 src/utils/request.js 文件

​ 在上面的 user.js 文件中引入了 我们的该文件,来进行axios 异步请求发送,下面来看一下我们 request.js 文件中的详细内容

在这里插入图片描述

通过上面几个文件的分析,可以大致的看出来整个登录过程中,所涉及的相关文件内容

在这里插入图片描述

四、结合后端实现登录

4.1 后端Controller层代码

​ 这里需要注意,我们的请求路径请求接口参数命名必须都要与前端相对

package cn.example.springbootproject.tempTestVue;

import org.springframework.web.bind.annotation.*;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @Description: 测试Vue登录实现控制层
 * @ClassName: VueLoginController
 */
@RestController
@CrossOrigin
@RequestMapping("vue-admin-template/user")
public class VueLoginController {
    /**
    * 这里就不在调用Service层代码去数据库查询,这里简单的写死数据进行调用测试
    * */
    @PostMapping("login")
    public Object login(@RequestBody  Map<String,Object> data){
        System.out.println("访问login");
        System.out.println("username = " + data.get("username"));
        System.out.println("password = " + data.get("password"));
        String userId = "2013";
        if (userId==null) {
            return "fail";
        }
        HashMap<String, String> map = new HashMap<>();
        map.put("token",userId);
        return map;
    }

    @GetMapping("info")
    public Object getInfo(@RequestParam String token){
        System.out.println("访问info  token="+token);
        HashMap<Object, Object> map = new HashMap<>();
        map.put("username","张三");
        map.put("password","123456");
        map.put("name","二狗子");
        map.put("id","2013");
        map.put("phone","133144");
        map.put("avatar","xxxxx头像!");
        map.put("address","地址位置");
        return map;
    }

    @GetMapping("list")
    public Object userList(){
        System.out.println("访问list");
        HashMap<String, Object> map = new HashMap<>();
        List<Map> list = new ArrayList<>();
        for (int i=0;i<5;i++){
            Map aclUser = new HashMap<>();
            aclUser.put("userName","张三-"+i);
            aclUser.put("password","123456");
            aclUser.put("nickName","二狗子-"+i);
            aclUser.put("gmtCreate","");
            aclUser.put("gmtModified","");
            list.add(aclUser);
        }
        map.put("items",list);
        return map;
    }

    @PostMapping("/logout")
    public Object loginout(){
        System.out.println("退出登录!!!");
        return null;
    }
}

4.2 调整前端访问路径

// create an axios instance
const service = axios.create({
  //指定了我们要访问的后端的路径(比如说 htppt://localhost:8080
  baseURL: process.env.VUE_APP_BASE_API, // url = base url + request url
  // withCredentials: true, // send cookies when cross-domain requests
  timeout: 5000 // request timeout
})

​ 在该配置项中的 VUE_APP_BASE_API 指定了我们的访问路径该数据是通过配置文件获取 .env.production生成环境) 或者是 **.env.development(开发环境) ** ,具体根据那个文件中获取的,的根据自己项目的实际部署环境来确定。

​ 同时 我们将下方的 response interceptor响应拦截器部分内容全部注释,暂时不使用到响应拦截器相关操作注释时,不要注释多了,末尾export default service 是需要保留的。

# just a flag
ENV = 'development'

# base api
# VUE_APP_BASE_API = '/dev-api'
VUE_APP_BASE_API = 'http://localhost:8888'

​ 这里的路径根据自己后端路径进行调整更改

​ **注:**需要主页我们的请求参数一定要与后端接收参数对应,以及前端接收参数,一点要与响应参数响应参数相匹配,下面两个文件中就需要与后端相应参数对应

  • src/store/modules/user.js 文件中注意的点

在这里插入图片描述

  • src/api/user.js 文件需要注意的点

在这里插入图片描述

4.3 测试结果

​ 调整好后端代码之后,第一次登录可以观察到如下结果

在这里插入图片描述

​ 可以观察到前端保存了我们的token信息

在这里插入图片描述

​ 在浏览器端存在token信息时候,我们重写访问登录页面首页时,前端会直接通过获取到的token信息,进行调用后端的 getInfo() 方法来获取用户信息,从而跳过了登录操作

​ 当token不存在时(这里我们可以人为的删除存储在浏览器端的该token数据),在进行其他操作时,会跳转到登录界面,这里就相当于我们的用户登录过期了,就需要重新进行认证操作

在这里插入图片描述

五、项目部署上线操作

5.1 后端项目部署

  1. 后端项目打包jar文件

在这里插入图片描述

  1. 打包好的jar文件上传服务器

    注意这里,我用的是Linux环境,前提是我们的Linux环境已经安装了JDK1.8。

    • 启动项目:

    nohup javajar vue-admin-0.0.1-SNAPSHOT.jar -&amp;

    或者

    nohup javajar 项目名称.jarserver.port=项目端口号 do_iptable.jar >/dev/null 2>&amp;1&

    firewallcmdadd-port=项目端口号/tcppermanent
    firewallcmdreload

    在这里插入图片描述

    ps -ef|grep java查看进程执行情况。

    在这里插入图片描述

5.2 前端代码部署

  1. 将前端vue项目打包上传

    在这里插入图片描述

    ​ vue 项目—>npm run build:prod—>dist–>上传linux

5.3 配置 nginx 访问

​ 这里需要自己提前先将 niginx 服务部署到我们的服务器中,这里就不单独讲解 nginx 服务部署流程了。

原文地址:https://blog.csdn.net/LiuCJ_20000/article/details/134664819

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_27308.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注