做为后端程序员,想写一个数据展现的系统,主要用于数据查询、数据展现,固然也有登陆功能了,有没有比较快的方式呢,于此,Vue-Admin-Pro便产生了,基于iView-Admin,进行简化,为后端程序员量身打造的极简后端管理系统。javascript
项目地址:vue-admin-pro前端
系列文章1:[后端管理系统开发(一):登陆篇]()vue
系列文章2:后端管理系统开发(二):路由篇java
系列文章3:[后端管理系统开发(三):数据表格篇]()(敬请期待)ios
系列文章4:[后端管理系统开发(四):数据请求篇]()(敬请期待)git
系列文章5:[后端管理系统开发(五):表单篇]()(敬请期待)程序员
系列文章6:[后端管理系统开发(六):图标篇]()github
项目进入正题,开始搭建项目。web
第一步:使用 Git
拉取 vue-admin-pro 的代码,地址:git@github.com:fengwenyi/vue-admin-pro.git
spring
第二步:修改工程名,好比咱们将工程名改成vue-admin-pro-simple
第三步:使用 WebStorm
打开
第四步:修改配置,配置地址:/src/config/index.js
第五步:运行 npm install
第六步:运行 npm run dev
运行效果:
这里有一个问题,由于标题过长,大于预留的宽度,咱们去修改一下登陆样式:/src/view/Login/Login.less
,将宽度改为 390px
.container { ... .content { width: 390px; } }
修改以后的效果:
于此,算是搞定了项目搭建。首先咱们无论什么权限,来实现最基础的登陆功能。因此,下面咱们聊聊咱们的登陆。
前端登陆的API代码:
/** * 登陆 * @param account * @param password */ export const login = (account, password) => { const data = { account, password } return axios.request({ url: 'auth/login', method: 'post', dataType: 'json', headers: { 'Content-Type': 'application/json; charset=UTF-8' }, data: data }) }
咱们注意如下几点:
account
、password
于此,咱们可写本身的后端的登陆接口,或者适当修改。
能够参见 vue-admin-pro-api
示例:
package com.fengwenyi.vueadminproapi.controller; import com.fengwenyi.vueadminproapi.entity.Login; import net.iutil.ApiResult; import net.iutil.javalib.util.IdUtils; import org.springframework.http.MediaType; import org.springframework.util.StringUtils; import org.springframework.web.bind.annotation.*; import java.util.HashMap; import java.util.Map; /** * 认证 * @author Erwin Feng * @since 2019-06-08 10:21 */ @RestController @RequestMapping(value = "/auth", consumes = MediaType.APPLICATION_JSON_UTF8_VALUE, produces = MediaType.APPLICATION_JSON_UTF8_VALUE) public class AuthController { // 登陆示例 @PostMapping("/login") public ApiResult login(@RequestBody Login login) { String account = login.getAccount(); String password = login.getPassword(); if (StringUtils.isEmpty(account)) return ApiResult.error().setMsg("帐号不能为空"); if (StringUtils.isEmpty(password)) return ApiResult.error().setMsg("密码不能为空"); if (!account.equals("admin")) return ApiResult.error().setMsg("帐号不存在"); if (!password.equals("admin@1234")) return ApiResult.error().setMsg("密码不正确"); String uid = IdUtils.getIdByUUID(); String token = IdUtils.getIdByUUID(); // 可指定有效期 // 可自定义策略保存uid、token // write code Map<String, String> map = new HashMap<>(); map.put("token", uid + "_" + token); return ApiResult.success(map); } // 登出示例 @GetMapping("/logout") public ApiResult logout(@RequestHeader String token) { // 清空token // write code // return return ApiResult.success(); } }
登陆成功,进入首页
这里有一个问题,由于标题太长了,这里采起的策略是,将标题超出的部分隐藏。
路径: /components/main
class:maxAdminName
我这里将字体调小
.main{ .logo-con{ ... .maxAdminName { font-size: 17px; ... } } }
看一下效果: