Vue+SpringBoot前后端分离项目实战:个人网上银行

本文主要是介绍Vue+SpringBoot前后端分离项目实战:个人网上银行,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、语言和环境

A、实现语言

Java

B、环境要求

JDK 1.8、IDEA、 Maven3及以上版本、 MySQL 5.7、

Vue脚手架2.0+ElementUI

二、功能要求

在IDEA中使用Maven构建项目,使用Spring Boot + MyBatis-Plus(或JPA)
+Vue脚手架-ElementUI实现个人网上银行,以MySQL 5.7作为后台数据库。功能包括登录、退出、转账、查询交易记录,具体要求如下:
打开个人网上银行首页,显示登录页面。如图-1:

输入卡号和密码,点击“登录网上银行”按钮进行登录。要求进行表单验证,卡号、密码必填,且卡号为16位数字、密码为6位数字,输入有误需要提示。
通过表单验证后提交表单,服务器根据用户所填处理登录请求。可能导致登录失败的业务条件有:卡号不正确、密码不正确、账户已冻结。如出现上述问题,须返回登录页并对用户进行提示。
登录成功后,进入个人网上银行主界面,界面显示当前登录的卡号。如图-2:
注:
查询余额和修改密码功能不要求实现

cb79f0b409812f59ff68ec93d73ec1ce.png点击“退出登录”超链接执行退出操作,要求使用confirm对用户操作进行确认,如图-3。用户点击“确定”按钮,销毁回话并跳转到登录页面。

038bf17b21826003e12dc010a32d2786.png点击“转账”超链接,进入转账页面。如图-4:

fd7b30849b8951f681ed2e609f55c316.png

用户点击“转账”按钮后,进行JavaScript验证,账号和金额均为必填项,账号只能是16位数字,金额必须是数字且最多只能有两位小数。用户填写错误需要提示。
通过JavaScript验证后,提交数据到服务器执行转账功能,可能导致转账失败的业务条件有:转入账户不存在、转入账户被冻结、转出账户余额不足。发生上述情况须在转账页面进行提示。
否则分别修改两个账户的余额,并在交易记录表transaction_record中分别为转出账户添加一条取款记录,为转入账户添加一条存款记录,交易时间均为当前系统时间。全部执行成功,提交事务,否则回滚事务。并在页面提示用户操作成功或操作失败。如图-5:

点击“查询交易记录”进入查询交易记录页面。如图-6:

547f7e28632a337c5938319ca1f52e7e.png

用户点击“查询”按钮,进行JavaScript验证。两个日期均为必填项,格式为“年-月-日”。用户填写错误需要提示。
通过JavaScript验证后,提交数据到服务器执行查询,查询结果按交易时间升序排列,列表隔行变色,并分页展示。在切换页码时,指定的日期范围应保持不变。如图-7:dd79eb6168b719946ce50faa0c55d1bd.png

 如果指定时间范围内没有交易记录,提示效果如图-8:4556228687cbfb4dff6b815d8d3d2ac3.png

三、   数据库设计

数据库表名称及要求:

表名

account

中文表名称

账户信息表

主键

id

序号

字段名称

字段说明

类型

属性

备注

1

id

账户id

长整数

主键

使用自动增长赋值

2

cardno

卡号

字符串

非空,唯一

16位数字构成的卡号

3

password

密码

字符串

非空

6位数字的密码

4

balance

账户余额

浮点数

非空

5

status

账户状态

整数

非空

1为正常,0为冻结

表名

transaction_record

中文表名称

交易记录表

主键

id

序号

字段名称

字段说明

类型

属性

备注

1

id

记录id

长整数

主键

使用自动增长赋值

2

cardno

卡号

字符串

非空

对应account表cardno字段

3

transactionDate

交易日期

时间戳

非空

取系统时间

4

amount

交易金额

浮点数

非空

5

balance

账户余额

浮点数

非空

交易完成时的账户余额

6

transactionType

交易类型

字符串

非空

存款、取款、消费

7

remark

备注

字符串

数据库部分

/*Navicat Premium Data TransferSource Server         : 本机MySQL57Source Server Type    : MySQLSource Server Version : 50726Source Host           : localhost:3306Source Schema         : bankdbTarget Server Type    : MySQLTarget Server Version : 50726File Encoding         : 65001Date: 06/01/2022 22:46:59
*/create data if not exists bankdb;use bankdb;SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;-- ----------------------------
-- Table structure for account
-- ----------------------------
DROP TABLE IF EXISTS `account`;
CREATE TABLE `account`  (`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '账户id',`cardno` varchar(16) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '卡号',`password` varchar(6) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '密码',`balance` decimal(10, 2) NOT NULL COMMENT '账户余额',`status` int(11) NOT NULL COMMENT '账户状态,1为正常,0为冻结',PRIMARY KEY (`id`) USING BTREE,UNIQUE INDEX `cardno`(`cardno`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 3 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;-- ----------------------------
-- Records of account
-- ----------------------------
INSERT INTO `account` VALUES (1, '6451225451452114', '123456', 7000.00, 1);
INSERT INTO `account` VALUES (2, '6451225451452115', '654321', 67000.00, 1);-- ----------------------------
-- Table structure for transaction_record
-- ----------------------------
DROP TABLE IF EXISTS `transaction_record`;
CREATE TABLE `transaction_record`  (`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '记录id',`cardno` varchar(16) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '卡号',`transactionDate` timestamp(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '交易日期,取系统时间',`amount` decimal(10, 2) NOT NULL COMMENT '交易金额',`balance` decimal(10, 2) NOT NULL COMMENT '交易完成时的账户余额',`transactionType` varchar(16) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '交易类型,存款、取款、消费',`remark` varchar(2000) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '备注',PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 7 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;-- ----------------------------
-- Records of transaction_record
-- ----------------------------
INSERT INTO `transaction_record` VALUES (1, '6451225451452114', '2021-12-18 10:04:53', 100.00, 8000.00, '消费', '买了一条裤子');
INSERT INTO `transaction_record` VALUES (2, '6451225451452115', '2021-12-18 10:05:20', 800.00, 65100.00, '取款', NULL);
INSERT INTO `transaction_record` VALUES (3, '6451225451452114', '2021-12-18 10:05:44', 300.00, 6000.00, '存款', NULL);
INSERT INTO `transaction_record` VALUES (4, '6451225451452115', '2021-12-18 10:06:02', 300.00, 68000.00, '存款', NULL);
INSERT INTO `transaction_record` VALUES (5, '6451225451452114', '2021-12-18 12:06:06', 1000.00, 7000.00, '取款', '转账给6451225451452115');
INSERT INTO `transaction_record` VALUES (6, '6451225451452115', '2021-12-18 12:06:06', 1000.00, 67000.00, '存款', '6451225451452114转入');SET FOREIGN_KEY_CHECKS = 1;

这篇关于Vue+SpringBoot前后端分离项目实战:个人网上银行的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/741356

相关文章

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr