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

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template