maven实现登录修改删除转账

时间: 2024-05-13 15:14:11 浏览: 7
Maven 是一个项目管理工具,它可以帮助我们自动化构建、测试和部署 Java 项目。而实现登录、修改、删除和转账等功能需要编写 Java 代码和操作数据库。 下面是一个使用 Maven 实现登录、修改、删除和转账功能的示例项目: 1. 创建 Maven 项目 首先,我们需要创建一个 Maven 项目。可以使用 Eclipse 或者 IntelliJ IDEA 等 Java IDE 工具创建 Maven 项目。 2. 添加依赖 我们需要添加如下依赖到 pom.xml 文件中: ``` <dependencies> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.23</version> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>4.0.1</version> </dependency> </dependencies> ``` 其中,mysql-connector-java 是操作 MySQL 数据库的 JDBC 驱动,javax.servlet-api 是操作 Servlet 的 API。 3. 编写代码 接下来,我们需要编写 Java 代码实现登录、修改、删除和转账等功能。下面是示例代码: ``` // 登录 public boolean login(String username, String password) { Connection conn = null; PreparedStatement stmt = null; ResultSet rs = null; try { conn = getConnection(); String sql = "select * from user where username=? and password=?"; stmt = conn.prepareStatement(sql); stmt.setString(1, username); stmt.setString(2, password); rs = stmt.executeQuery(); return rs.next(); } catch (SQLException e) { e.printStackTrace(); } finally { close(conn, stmt, rs); } return false; } // 修改密码 public boolean changePassword(String username, String oldPassword, String newPassword) { Connection conn = null; PreparedStatement stmt = null; try { conn = getConnection(); String sql = "update user set password=? where username=? and password=?"; stmt = conn.prepareStatement(sql); stmt.setString(1, newPassword); stmt.setString(2, username); stmt.setString(3, oldPassword); int rows = stmt.executeUpdate(); return rows > 0; } catch (SQLException e) { e.printStackTrace(); } finally { close(conn, stmt, null); } return false; } // 删除用户 public boolean deleteUser(String username) { Connection conn = null; PreparedStatement stmt = null; try { conn = getConnection(); String sql = "delete from user where username=?"; stmt = conn.prepareStatement(sql); stmt.setString(1, username); int rows = stmt.executeUpdate(); return rows > 0; } catch (SQLException e) { e.printStackTrace(); } finally { close(conn, stmt, null); } return false; } // 转账 public boolean transfer(String fromAccount, String toAccount, double amount) { Connection conn = null; PreparedStatement stmt = null; try { conn = getConnection(); conn.setAutoCommit(false); String sql1 = "update account set balance=balance-? where account=?"; stmt = conn.prepareStatement(sql1); stmt.setDouble(1, amount); stmt.setString(2, fromAccount); int rows1 = stmt.executeUpdate(); if (rows1 <= 0) { conn.rollback(); return false; } String sql2 = "update account set balance=balance+? where account=?"; stmt = conn.prepareStatement(sql2); stmt.setDouble(1, amount); stmt.setString(2, toAccount); int rows2 = stmt.executeUpdate(); if (rows2 <= 0) { conn.rollback(); return false; } conn.commit(); return true; } catch (SQLException e) { try { conn.rollback(); } catch (SQLException ex) { ex.printStackTrace(); } e.printStackTrace(); } finally { close(conn, stmt, null); } return false; } // 获取数据库连接 private Connection getConnection() throws SQLException { String url = "jdbc:mysql://localhost:3306/test?useSSL=false&serverTimezone=UTC"; String username = "root"; String password = "root"; return DriverManager.getConnection(url, username, password); } // 关闭资源 private void close(Connection conn, Statement stmt, ResultSet rs) { try { if (rs != null) rs.close(); if (stmt != null) stmt.close(); if (conn != null) conn.close(); } catch (SQLException e) { e.printStackTrace(); } } ``` 这段代码定义了一个 UserDao 类,其中包含了 login、changePassword、deleteUser 和 transfer 四个方法,分别用于实现登录、修改密码、删除用户和转账功能。getConnection 方法用于获取数据库连接,close 方法用于关闭资源。 4. 编写 Servlet 最后,我们需要编写 Servlet,将前端请求与 Java 代码联系起来。下面是示例代码: ``` @WebServlet("/login") public class LoginServlet extends HttpServlet { private UserDao userDao = new UserDao(); protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String username = request.getParameter("username"); String password = request.getParameter("password"); boolean result = userDao.login(username, password); if (result) { response.sendRedirect("index.jsp"); } else { response.sendRedirect("login.jsp"); } } } @WebServlet("/changePassword") public class ChangePasswordServlet extends HttpServlet { private UserDao userDao = new UserDao(); protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String username = request.getParameter("username"); String oldPassword = request.getParameter("oldPassword"); String newPassword = request.getParameter("newPassword"); boolean result = userDao.changePassword(username, oldPassword, newPassword); if (result) { response.sendRedirect("index.jsp"); } else { response.sendRedirect("changePassword.jsp"); } } } @WebServlet("/deleteUser") public class DeleteUserServlet extends HttpServlet { private UserDao userDao = new UserDao(); protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String username = request.getParameter("username"); boolean result = userDao.deleteUser(username); if (result) { response.sendRedirect("index.jsp"); } else { response.sendRedirect("deleteUser.jsp"); } } } @WebServlet("/transfer") public class TransferServlet extends HttpServlet { private UserDao userDao = new UserDao(); protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String fromAccount = request.getParameter("fromAccount"); String toAccount = request.getParameter("toAccount"); double amount = Double.parseDouble(request.getParameter("amount")); boolean result = userDao.transfer(fromAccount, toAccount, amount); if (result) { response.sendRedirect("index.jsp"); } else { response.sendRedirect("transfer.jsp"); } } } ``` 这段代码定义了四个 Servlet,分别对应登录、修改密码、删除用户和转账四个功能。每个 Servlet 通过 UserDao 类中的方法实现相应的功能。 5. 编译打包 最后,我们需要使用 Maven 编译打包项目。在项目根目录下执行以下命令: ``` mvn clean package ``` 执行完成后,会在 target 目录下生成一个 war 包。将这个 war 包部署到 Tomcat 等 Java Web 服务器上即可使用。

相关推荐

最新推荐

recommend-type

IntelliJ IDEA使用maven实现tomcat的热部署

主要介绍了IntelliJ IDEA使用maven实现tomcat的热部署,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
recommend-type

一键清除maven仓库中下载失败的jar包的实现方法

主要介绍了一键清除maven仓库中下载失败的jar包的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

SSM项目频繁打成war包部署,使用tomcat和maven实现热部署配置

主要介绍了SSM项目频繁打成war包部署操作频繁?使用tomcat和maven实现热部署配置,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
recommend-type

jenkins基本介绍与maven项目的实现

易于配置-所有配置都是通过其提供的web界面实现。 集成RSS/E-mail通过RSS发布构建结果或当构建完成时通过e-mail通知。 生成JUnit/TestNG测试报告。 分布式构建支持Jenkins能够让多台计算机一起构建/测试。 文件识别:...
recommend-type

jenkins实现maven项目自动部署到tomcat

使​用​j​e​n​k​i​n​s​来​帮​助​我​们​进​行​m​a​v​e​n​项​目​的​自​动​编​译​,​打​包​,​然​后​发​布​到​t​o​m​c​a​t​等​w​e​b​服​务​器​的​功​能​。...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

用Spring boot和vue写一个登录注册界面

好的,这是一个比较常见的技术问题,我可以为您提供一些参考资料和思路。首先,您可以使用Spring Boot作为后端框架来处理用户认证和注册的逻辑,比如使用Spring Security实现用户登录认证。同时,您还需要设计相应的数据模型和数据库表结构来存储用户信息。在前端方面,您可以使用Vue.js作为框架来构建登录注册页面,使用Axios来发起API请求并和后端进行交互。当然,在实现过程中,还需要考虑一些具体细节,比如数据校验、安全性和用户体验等方面。希望这些信息能够帮助到您。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。