JAVA实验3:Java-MySQL实现银行转账系统

2024-03-30 04:32

本文主要是介绍JAVA实验3:Java-MySQL实现银行转账系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

运行结果

实验中解决了用户登录时SQL注入问题,提高了系统的安全性
并且关闭了事务自动提交,开启了事务回滚功能,保证了用户资金的安全性
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

PowerDesigner16.5建模

在这里插入图片描述

数据库源码

drop table if exists userlogin;/*==============================================================*/
/* Table: userlogin                                             */
/*==============================================================*/
create table userlogin
(username             varchar(20) not null,password             varchar(20),primary key (username)
);drop table if exists userstate;/*==============================================================*/
/* Table: userstate                                             */
/*==============================================================*/
create table userstate
(username             varchar(20) not null,money                bigint,primary key (username)
);insert into userlogin(username,password) values('zrs','333');
insert into userlogin(username,password) values('llf','222');
insert into userstate(username,money) values('zrs',20000);
insert into userstate(username,money) values('llf',0);

使用的java模块

在这里插入图片描述

java源码

Bank主函数入口:

package Bank;import Mysql.Mysql;
import InitUI.InitUI;
import TransfroUI.*;
import UserLogin.UserLogin;
import java.sql.*;
import java.util.Map;public class Bank {public static void main(String[] args){Connection conn = null;PreparedStatement pstmt = null;ResultSet rs = null;try{conn = Mysql.connection("bank");Map<String,String> map = InitUI.initUI();String uname = map.get("username");String pwd = map.get("password");UserLogin.userLogin(uname,pwd,conn);conn.setAutoCommit(false);transfor(uname,conn);conn.commit();}catch(SQLException e){if(conn != null){try{conn.rollback();System.out.println("事务回滚");}catch(Exception a){a.printStackTrace();;}}e.printStackTrace();}catch(Exception e){e.printStackTrace();}finally{Mysql.close(conn,pstmt,rs);}}private static void transfor(String uname,Connection conn) throws SQLException{Map<String,String> trans = TransforUI.transforUI();String tname = trans.get("transforname");String money = trans.get("money");String[] sql = {"update userstate set money = money+? where username = ?;","update userstate set money = money-? where username = ?","select money from userstate where username = ?"};PreparedStatement pstmt_0 = conn.prepareStatement(sql[0]);PreparedStatement pstmt_1 = conn.prepareStatement(sql[1]);PreparedStatement pstmt_2 = conn.prepareStatement(sql[2]);pstmt_0.setString(1,money);pstmt_0.setString(2,tname);pstmt_1.setString(1,money);pstmt_1.setString(2,uname);pstmt_2.setString(1,uname);int count = pstmt_0.executeUpdate();count += pstmt_1.executeUpdate();ResultSet rs = pstmt_2.executeQuery();rs.next();if(count==2 && rs.getInt("money")>=0){System.out.println("转账成功");}else{System.out.println("余额不足");throw new SQLException();}}
}

Mysql封装源码:

package Mysql;import java.sql.*;public class Mysql{private Mysql(){}//注册驱动static{try{Class.forName("com.mysql.cj.jdbc.Driver");}catch(Exception e){e.printStackTrace();}}//连接数据库public static Connection connection(String database_name) throws Exception{return DriverManager.getConnection("jdbc:mysql://localhost:3306/"+database_name,"root","feifei123");}//释放资源public static void close(Connection conn, PreparedStatement pstmt){if(pstmt != null){try{pstmt.close();}catch(SQLException e){e.printStackTrace();}}if(conn != null){try{conn.close();}catch(SQLException e){e.printStackTrace();}}}//重载释放资源方法public static void close(Connection conn,PreparedStatement pstmt,ResultSet rs){if(rs != null){try{rs.close();}catch(SQLException e){e.printStackTrace();}}if(pstmt != null){try{pstmt.close();}catch(SQLException e){e.printStackTrace();}}if(conn != null){try{conn.close();}catch(SQLException e){e.printStackTrace();}}}
}

用户输入模块源码:

package InitUI;import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;public class InitUI {private InitUI(){}public static Map<String, String> initUI() {Map<String,String> map = new HashMap();Scanner s = new Scanner(System.in);System.out.println("请输入用户名:");String username = s.next();System.out.println("请输入密码:");String password = s.next();map.put("username",username);map.put("password",password);return map;}
}

用户登录检测源码:

package UserLogin;import java.sql.*;
import java.sql.SQLException;
import java.util.Map;
import java.util.ResourceBundle;public class UserLogin {private UserLogin(){}public static void userLogin(String username, String password,Connection conn) throws Exception{String sql = "select * from userlogin where username = ? and password = ?;";PreparedStatement pstmt = conn.prepareStatement(sql);pstmt.setString(1,username);pstmt.setString(2,password);ResultSet rs = pstmt.executeQuery();boolean flag = rs.next()==true?true:false;if(flag){System.out.println(username+"欢迎回来");}else{System.out.println("登录失败,请重新登录");Map<String,String> map =InitUI.InitUI.initUI();String uname = map.get("username");String pwd = map.get("password");userLogin(uname,pwd,conn);}}
}

用户转账检测源码:

package TransfroUI;import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;public class TransforUI {private TransforUI(){}public static Map<String, String> transforUI() {Map<String,String> map = new HashMap();Scanner s = new Scanner(System.in);System.out.println("请输入要转账的用户名:");String username = s.next();System.out.println("请输入要转账的金额:");String password = s.next();map.put("transforname",username);map.put("money",password);return map;}
}

这篇关于JAVA实验3:Java-MySQL实现银行转账系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

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

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

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u

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

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

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

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

浅谈mysql的not exists走不走索引

《浅谈mysql的notexists走不走索引》在MySQL中,​NOTEXISTS子句是否使用索引取决于子查询中关联字段是否建立了合适的索引,下面就来介绍一下mysql的notexists走不走索... 在mysql中,​NOT EXISTS子句是否使用索引取决于子查询中关联字段是否建立了合适的索引。以下

浅析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

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件