创建文件,如上图

创建好文件后去router.index.js配置路由

import { createRouter, createWebHistory } from 'vue-router';

// 定义路由
const routes = [
{
path: '/',
name: 'ControlCenter',
component: () => import('../views/ControlView.vue'), },
{
path: '/register',
name: 'register',
component: () => import('../components/UserSign/Register.vue'),
},
{
path: '/login',
name: 'login',
component: () => import('../components/UserSign/Login.vue'),
}, // 其他路由...
]; // 创建路由实例
const router = createRouter({
history: createWebHistory(),
routes,
}); export default router;

先去写注册吧。

页面无非就是一个表单,输入账号,输入密码,输入昵称啥的,还有个按钮用来提交

界面设计请查阅AntDesignVue文档,利用它们的UI组件进行设计,我主要讲一下业务代码怎么写。

编写接口文件

在apis文件夹下创建UserApi.js,里面用来放关于用户操作的各种接口

多用户查询

根据id查询

更新

删除

登录

新增

好,我把UserApi.js这个文件完整代码贴出来参考

import { get, post, put, deleteRequest } from "./api.js";

export function user_get_list(){
return get("/users")
}
export function user_get_by_id(){
return get(`/users/${userId}`)
}
export function user_update(data){
return put("/users",data)
}
export function user_delete_by_id(){
return deleteRequest(`/users/${userId}`)
}
export function user_login(userAccount,userPassword){
return post("/users/login",{
"userAccount":userAccount,
"userPassword":userPassword
})
}
export function user_add(data){
return post("/users",data)
}

注册

注册页面自己设计,例如我的表单数据是存放在formState中的,

const formState = reactive({
userNickname: '',
userAccount:'',
userPassword: '',
remember: true,
});

注意,这些参数的名字要和后端POJO中的名字一致哦,不然匹配不上,就自动获取不了。

引入新增用户的api

import {user_add} from "../../apis/UserApi.js";

编写请求

//点击登录按钮执行onFinish这个函数
const onFinish = values => {
console.log("values",values)
//调用user_add()这个接口,then里面的res表示返回结果 user_add(values).then((res)=>{
let code = res["code"]
let msg=res["msg"]
//
notification.open({
message: '通知',
description:msg,
icon: () =>
h(SmileOutlined, {
style: 'color: #108ee9',
}),
});
//如果注册成功就跳转到登录界面
if(code===1){
router.push("/login")
}
})
};

是不是太太太简单了。

那么,我们继续完成登录吧

登录

登录页面同样自己设计(利用AntDesignVue)

登录成功,我们要做什么呢?

登陆成功意味着账号密码正确,但是这个号的状态可能是处于冻结状态对吧,因此我们要判断一下账号是否处于冻结状态(当然这个事情交给后端做会更好,我们现在就现在前端判断吧)

要是没问题的话,那是不是该把登录信息保存到缓存。

现在我们一般保存到localStorage中

关于localStorage,推荐看看我的这篇笔记:

【前端】【H5 API】Web存储 Web Storage

保存这个数据我使用base64编码,有个细节问题要注意,请看我这篇博客

【前端】2024年 前端Base64编码的中文处理问题

保存好后,就可以跳转到主页或者其他你想跳转的页面了

我们将用户数据保存在本地的目的是:

0.判断用户有没有登录

1.访问各个页面时判断用户有没有权限访问这个页面

2.需要用户数据时方便提取

3.发送操作请求时能知道是哪个用户在操作

……

我们在保存的时候肯定都是会保存一个时间的,因为用户登录过一次后不可能永远就处于登录状态。

我们记录了登录时间,就可以知道他是什么时候登录的,什么时候提示他过期,需要重新登录。

关于数据传输param和body的问题

在我的这个例子中,登录接口是以post的方式接收param参数

而我们在api.js里面配置的post请求函数是 以post方式发送body参数

显然对不上,那么就算我们填写了数据,后端也接受不到数据

这时候,我们需要在编写一个以post的方式发送param参数的方法

如下

// 统一的post请求方法
// 统一的post请求方法,发送数据在请求体中
export function post(url, data = {}) {
return axiosInstance.post(url, data);
} // 统一的post请求方法,发送数据在查询参数中
export function postWithParams(url, params = {}) {
return axiosInstance.post(url, null, { params });
}
export function user_login(userAccount,userPassword){
return postWithParams("/users/login",{
"userAccount":userAccount,
"userPassword":userPassword
})
}

ok,问题解决

2024年1月Java项目开发指南13:登录注册实现的更多相关文章

  1. 转:Java项目开发规范参考

    Java项目开发规范参考 - KevinLee的博客 - 博客频道 - CSDN.NEThttp://blog.csdn.net/u011383131/article/details/51227860 ...

  2. IDEA 学习笔记之 Java项目开发深入学习(2)

    Java项目开发深入学习(2): 查找变量被用到的地方 编译当前文件 增加变量watch 注意:我使用了keymap (eclipse模板),所以很多快捷键和eclipse一样. F5单步调试进入函数 ...

  3. IDEA 学习笔记之 Java项目开发深入学习(1)

    Java项目开发深入学习(1): 定义编译输出路径: 继承以上工程配置 重新定义新的项目编译路径 添加source目录:点击添加,再点击移除: 编译项目: 常用快捷键总结: Ctrl+Space 代码 ...

  4. IDEA 学习笔记之 Java项目开发

    Java项目开发: 新建模块: 添加JDK: 导入本地Jars: 从远程Maven仓库下载: 创建package: 新建类/接口/枚举等: 字体太小,改字体: Duplicate Scheme 修改编 ...

  5. 《Maven在Java项目开发中的应用》论文笔记(十七)

    标题:Maven在Java项目开发中的应用 一.基本信息 时间:2019 来源:山西农业大学 关键词:Maven:Java Web:仓库:开发人员:极限编程; 二.研究内容 1.Maven 基本原理概 ...

  6. 收藏基本Java项目开发的书

    一.Java项目开发全程实录 第1章 进销存管理系统(Swing+SQL Server2000实现) 第2章企业内部通信系统(Swing+JavaDB实现) 第3章 企业人事管理系统( Swing+H ...

  7. Java项目开发中实现分页的三种方式一篇包会

    前言   Java项目开发中经常要用到分页功能,现在普遍使用SpringBoot进行快速开发,而数据层主要整合SpringDataJPA和MyBatis两种框架,这两种框架都提供了相应的分页工具,使用 ...

  8. Android高效率编码-第三方SDK详解系列(二)——Bmob后端云开发,实现登录注册,更改资料,修改密码,邮箱验证,上传,下载,推送消息,缩略图加载等功能

    Android高效率编码-第三方SDK详解系列(二)--Bmob后端云开发,实现登录注册,更改资料,修改密码,邮箱验证,上传,下载,推送消息,缩略图加载等功能 我的本意是第二篇写Mob的shareSD ...

  9. Java项目开发

    项目开发整体构建: MVC+DAO设计模式 用面向对象的方式理解和使用数据库,一个数据库对应一个java项目 数据库--项目 表--类 字段--属性 表中的一条数据--类的一个对象 M:模型层 Jav ...

  10. Java项目接入sso单点登录

    最近在落地cat(java开发的一款开源监控系统)接入公司的内部项目,其中有项需求是接入公司的sso单点登录系统.研究了公司之前java项目接入sso系统,大部分是采用spring框架,然后依赖spr ...

随机推荐

  1. 论文解读《MASTERKEY: Automated Jailbreaking of Large Language Model Chatbots》

    导言 ​ 在参加东南大学网络安全学院夏令营的契机下,我第一次接触大模型安全领域.L老师是网络安全领域的一位大牛,在和L老师交流期间,被告知需要准备一次paper presentation介绍四大会中感 ...

  2. 「模拟赛」CSP-S 模拟 11(T2 超详细)

    比赛链接 A.玩水 (water) 签到.发现如果要找两条路径的话,能找到的充要条件是存在一个点的上方和左方的字母相同.(即使两条走过的点截然不同的路径也符合,这时终点会成为这个点). 即存在一个位置 ...

  3. VuePress安装

    linux 下预构建二进制文件安装 Nodejs Nodejs预购建二级制文件下载地址 安装 Nodejs 和 npm # 解压 tar xvf node-v20.15.1-linux-x64.tar ...

  4. 《使用Gin框架构建分布式应用》阅读笔记:p127-p142

    <用Gin框架构建分布式应用>学习第9天,p127-p142总结,总计16页. 一.技术总结 1.Authentication方式汇总 (1)API keys API keys 认证方式示 ...

  5. Java新特性--方法引用

    常见方法引用 方法引用可以让你重复使用现有的方法定义,并像Lambda一样传递它们. 方法引用可以看做是仅仅调用特定方法的Lambda表达式的一种便捷写法.类似于Lambda表达式,方法引用不能独立存 ...

  6. Java高并发,ArrayList、HashSet、HashMap不安全的集合类

    首先是我们的ArrayList: 这次我们讲解的是集合的不安全,首先我们都知道ArrayList吧! List<String> list=new ArrayList<>(); ...

  7. 饿了么Element UI之Upload组件图片上传【原创】

    图片文件换汤不换药,只要注意前端的写法即可 1.饿了么组件可以利用 http-request 的属性对上传进行自定义 :http-request="uploadFile" 2.设置 ...

  8. 在vue中引入外部的css文件

    在vue中引入外部的css文件在项目的src文件下,新建一个style文件夹,存放css文件. 1. 全局引入将外部的css文件放到style文件下,引入外部文件只需在main.js文件中 impor ...

  9. 关于Java后台处理前端用户传来数据过大,超过数据库字段设置长度导致的异常问题处理

    在DTO bean对象上使用javax验证(如最小值,最大值等,请参阅here).

  10. 基于Java+SpringBoot+Mysql实现的快递柜寄取快递系统功能实现一

    一.前言介绍: 1.1 项目摘要 随着电子商务的迅猛发展和城市化进程的加快,快递业务量呈现出爆炸式增长的趋势.传统的快递寄取方式,如人工配送和定点领取,已经无法满足现代社会的快速.便捷需求.这些问题不 ...