SpringBoot2+Vue2实战(十八)修改密码

一、修改密码:

Header.vue

<el-dropdown-item style="font-size: 14px; padding: 5px 0"><router-link to="/password" style="text-decoration: none">修改密码</router-link></el-dropdown-item>

router/index.js

//拼装动态路由const manageRoute = {path: '/',name: 'Manage',component: () => import('../views/Manage.vue'),redirect: "/home",children: [{path: '/person',name: '个人信息',component: () => import('../views/Person.vue'),},{path: '/password',name: '修改密码',component: () => import('../views/Password.vue'),},]}

Password.vue

<template><el-card style="width: 500px"><el-form label-width="120px" size="small" :model="form" :rules="rules" ref="pass"><el-form-item label="原密码" prop="password"><el-input v-model="form.password" autocomplate="off" show-password></el-input></el-form-item><el-form-item label="新密码" prop="newPassword"><el-input v-model="form.newPassword" autocomplate="off" show-password></el-input></el-form-item><el-form-item label="新密码" prop="confirmPassword"><el-input v-model="form.confirmPassword" autocomplate="off" show-password></el-input></el-form-item><el-form-item><el-button type="primary" @click="save">确认</el-button></el-form-item></el-form></el-card>
</template><script>
export default {name: "Password",data(){return{form:{},//username,password,newPassword,confirmNewPassword这四个属性user:localStorage.getItem("user")?JSON.parse(localStorage.getItem("user")):{},rules:{password:[{required:true,message:'请输入原密码',trigger:'blur'},{min:3,message: '长度不少于3位',trigger: 'blur'}],newPassword:[{required:true,message:'请输入新密码',trigger:'blur'},{min:3,message: '长度不少于3位',trigger: 'blur'}],confirmPassword:[{required:true,message:'请输入密码',trigger:'blur'},{min:3,message: '长度不少于3位',trigger: 'blur'}],}}},created() {this.form.username = this.user.username},methods:{save(){this.$refs.pass.validate((valid) =>{//如果合法if (valid){if (this.form.newPassword !== this.form.confirmPassword){this.$message.error("2次新输入密码不相同")return false}this.request.post("/user/password",this.form).then(res =>{if (res.code ==='200'){this.$message.success("修改成功")this.$store.commit("logout")}else {this.$message.error(res.msg)}})}})},}
}
</script><style></style>

UserController

@PostMapping("/password")//   /user/passwordpublic Result password(@RequestBody UserPasswordDto userPasswordDto){userService.updatePassword(userPasswordDto);return Result.success();}

UserService

void updatePassword(UserPasswordDto userPasswordDto);

UserServiceImpl

@Overridepublic void updatePassword(UserPasswordDto userPasswordDto) {int update = userMapper.updatePassword(userPasswordDto);if (update < 1) {throw new ServiceException(Constants.CODE_600, "密码错误");}}

UserMapper

@Update("update sys_user set password = #{newPassword} where username = #{username} and password = #{password}")int updatePassword(UserPasswordDto userPasswordDto);

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/22277.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Kafka 深度剖析

1、应用场景 1.1 kafka场景 Kafka最初是由LinkedIn公司采用Scala语言开发&#xff0c;基于ZooKeeper&#xff0c;现在已经捐献给了Apache基金会。目前Kafka已经定位为一个分布式流式处理平台&#xff0c;它以 高吞吐、可持久化、可水平扩展、支持流处理等多种特性而被广泛应用…

牛客HJ99 - 自守数【暴力 + 换位取模】

原题传送门 原题描述 首先我们来看一下原题是怎么描述的&#xff0c;题面很简单&#xff0c;输入n&#xff0c;然后让我们去统计从1 ~ n之间的自守数有几个&#xff0c;那什么是【自守数】呢&#xff0c;上面也说到了&#xff0c;即一个数在平方之后该数的尾数等于该数自身的自…

ES6新特性基础总结

目录 简介 node.js安装 babel转码器 let命令 const命令 解构对象 字符串扩展 新增方法&#xff1a; 数组扩展 扩展运算符 伪数组 对象扩展 属性的简介表示法 属性名表达式 对象的扩展运算符 函数扩展 箭头函数 使用注意 Set数据结构 基本用法 size属性 特有方法 P…

用于分析脉冲类信号的二阶瞬态提取变换研究(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

RabbitMQ知识掌握 【进阶篇】

一、如何保证消息的可靠性 &#x1f349; 1.保证消息的可靠性投递 &#x1f95d; 在生产环境中由于一些不明原因&#xff0c;导致 rabbitmq 重启&#xff0c;在 RabbitMQ 重启期间生产者消息投递失败&#xff0c;导致消息丢失&#xff0c;需要手动处理和恢复。于是&#xff0…

微软亚洲研究院推出AI编译器界“工业重金属四部曲”

编者按&#xff1a;编译器在传统计算科学中一直是一个重要的研究课题。在人工智能技术快速发展和广泛应用的今天&#xff0c;人工智能模型需要部署在多样化的计算机硬件架构上。同时&#xff0c;训练和部署大型人工智能模型时又对硬件性能有着更高的要求&#xff0c;有时还需根…

7.10蓝桥杯刷题

public class _求阶乘和 {public static void main(String[] args) {// 根据已有的知识 可以知道的是&#xff0c;现在要求s的末尾九位数字&#xff0c;已知的是39之后的阶乘他的后九位都是0;//所以不需要计算到2023的阶乘//一个数求出来的阶乘想要末尾有0//数中必须要有2和5&a…

高压放大器到底有什么作用

高压放大器是一种重要的电子元器件&#xff0c;其作用是将信号放大到更高的电压水平&#xff0c;以便供给需要高电压的负载使用。高压放大器被广泛应用于通讯设备、医疗仪器、仿真模拟、气体激光、光学器件等领域。下面安泰电子将详细介绍高压放大器的作用以及其在各领域中的应…

VUE2基础-Vue实例

Vue 实例 创建一个 Vue 实例 每个 Vue 应用都是通过用 Vue 函数创建一个新的 Vue 实例开始的&#xff1a; var vm new Vue({// 选项 }) 虽然没有完全遵循 MVVM 模型&#xff0c;但是 Vue 的设计也受到了它的启发。因此在文档中经常会使用 vm (ViewModel 的缩写) 这个变量名…

抖音seo矩阵系统源码搭建技术+二开开源代码定制部署

抖音SEO源码是指将抖音平台上的视频资源进行筛选、排序等操作&#xff0c;进而提升其在搜索排名中的权重&#xff0c;从而让更多的用户能够发现并观看到这些视频资源。而抖音SEO矩阵系统源码则是指通过建立一个分析系统&#xff0c;分析抖音中的用户、视频、标签等数据&#xf…

Spring 核心与设计思想

文章目录 1.Spring 是什么&#xff1f;2.什么是容器3.什么是IoC3.1 传统程序开发3.2 IoC程序开发3.3 IoC再理解 4.认识DI 1.Spring 是什么&#xff1f; Spring框架是一个轻量级的企业开发的一站式解决方案&#xff0c;可以基于Spring解决Java EE 开发中的所有问题。 ⽤⼀句大白…

Cortex-M3与Aurix的堆栈

1. TC397是一个基于ARM Cortex-M3内核的微控制器芯片&#xff0c;其堆栈是由系统初始化代码初始化的。在ARM Cortex-M3架构中&#xff0c;堆栈通常由两个寄存器来管理&#xff1a;主堆栈指针&#xff08;MSP&#xff09;和进程堆栈指针&#xff08;PSP&#xff09;。 1.1 MSP是…