建立java和sql的连接(为聊天窗口添加注册功能)

建立java和sql的连接(为聊天窗口添加注册功能)

1.1首先需要导入mysql的相关包,将下好的jar文件拖入在src中新建立的lib文件夹(directory)里面,然后将lib进行add as library就算导入成功了

2.1明确dao是什么

DAO(Data Access Object) 数据访问对象,就是写一个类,把访问数据库的代码封装起来,DAO在数据库与业务逻辑(Service)之间。

Dao是数据访问层,Dao的作用是封装对数据库的访问:增删改查,不涉及业务逻辑,只是达到按某个条件获得指定数据的要求。

不同类有不同的dao,我们需要创建一个regdao也就是注册dao,当用户输入进来账户和密码后进入封装起来的regdao,然后在regdao这个类里面经过代码的命令保存进sql

2.2连接代码部分

首先登录sql

DriverManager.registerDriver(new Driver());String url="jdbc:mysql://127.0.0.1:3306/ChatRoom_db?serverTimezone=Asia/Shanghai";String user="root"; //账户String psd="root"; //密码

然后建立于数据库的连接,然后根据mysql的语法用PreparedStatement将账号密码和注册时间保存进sql。当然这过程中会有异常,但是我们只用找到异常不用catch处理异常,我们要抛出到注册窗口的类中去来解决异常,因为一旦在regdao里面处理异常,那注册窗口类中就不会显示异常,也就不能做出相应的异常出现窗口来提示用户网络连接中断等问题。

connection = DriverManager.getConnection(url,user,psd);ps=connection.prepareStatement("insert into user (account,password,reg_time)value(?,?,?)");ps.setObject(1,account);ps.setObject(2,password);ps.setObject(3,new Date());//注册时间ps.executeUpdate();ps.close();connection.close();

这时候有产生一个问题,当这些代码运行时出现异常,ps和connection就关闭不了了,所以不论上述代码运行异常与否,close是一定要执行的,这时候我们想到可以用finally,把close放到finally最后执行。这时候Connection和PrepareStatement的声明就要在try的外面声明,这样子在finally中也能用到

完整代码如下:

public class Regdao {public  void saveUser(String account,String password) throws ClassNotFoundException, SQLException {DriverManager.registerDriver(new Driver());String url="jdbc:mysql://127.0.0.1:3306/ChatRoom_db?serverTimezone=Asia/Shanghai";String user="root"; //账户String psd="root"; //密码//在外面声明可以在finally里用到Connection connection=null;PreparedStatement ps=null;try{//建立与数据库的链接connection = DriverManager.getConnection(url,user,psd);ps=connection.prepareStatement("insert into user (account,password,reg_time)value(?,?,?)");ps.setObject(1,account);ps.setObject(2,password);ps.setObject(3,new Date());//注册时间ps.executeUpdate();}finally {if(ps!=null){ps.close();}if(connection!=null){connection.close();}}}
}
2.3注册窗口代码部分:

首先就是排版,这里不多赘述:

this.setTitle("欢迎注册");this.setSize(500,350);this.setLocationRelativeTo(null);//居中this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);//关闭窗口时退出程序this.setResizable(false);//禁止窗口拖拽JPanel jPanel=new JPanel();JLabel jLabel=new JLabel("欢迎注册");jLabel.setFont(new Font("横体", Font.BOLD,30));jPanel.add(jLabel);//欢迎登录//中间第一个空标签JLabel jLabel1=new JLabel();//欢迎登录下面空白部分jLabel1.setPreferredSize(new Dimension(500,50));//账号JLabel jLabelAccount=new JLabel("账号");//账号标签jLabelAccount.setPreferredSize(new Dimension(30,30));JTextField jTextaccount=new JTextField(15);//账号文本域//中间第二个空标签JLabel jLabel2=new JLabel();//欢迎登录下面空白部分jLabel2.setPreferredSize(new Dimension(500,20));//密码JLabel jLabelPassword=new JLabel("密码 ");//账号标签jLabelPassword.setPreferredSize(new Dimension(30,30));JPasswordField jPasswordField=new JPasswordField(15);//中间第二个空标签JLabel jLabel3=new JLabel();//欢迎登录下面空白部分jLabel3.setPreferredSize(new Dimension(500,20));//按钮JButton ButtonSign=new JButton("注册");jPanel.add(jLabel1);jPanel.add(jLabelAccount);jPanel.add(jTextaccount);jPanel.add(jLabel2);jPanel.add(jLabelPassword);jPanel.add(jPasswordField);jPanel.add(jLabel3);jPanel.add(ButtonSign);this.add(jPanel);this.setVisible(true);

然后是给注册按钮添加功能,当按完注册按钮后判断账号密码是不是输入的符合规定,然后如果符合的话建立与sql的连接也就是创建regdao对象,然后跳转到登录窗口

 //按钮ButtonSign.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent e) {String account = jTextaccount.getText();String password = new String(jPasswordField.getPassword());if(account.length()==0){JOptionPane.showMessageDialog(null,"账号不能为空!");return;}if(password.length()==0){JOptionPane.showMessageDialog(null,"密码不能为空!");return;}try{// 将数据保存到用户表 dao-->data access object java中的代码是分层的,按不同的功能进行划分Regdao regdao=new Regdao();regdao.saveUser(account,password);JOptionPane.showMessageDialog(null,"注册成功!");new LoginWindow();dispose();} catch (ClassNotFoundException | SQLException classNotFoundException) {classNotFoundException.printStackTrace();JOptionPane.showMessageDialog(null,"注册失败!");}}});

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

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

相关文章

SVN迁移至GitLab,并附带历史提交记录(二)

与《SVN迁移至GitLab,并附带历史提交记录》用的 git svn clone不同,本文使用svn2git来迁移项目代码。 一、准备工作 安装Git环境,配置本地git账户信息: git config --global user.name "XXX" git config --global us…

计算机丢失VCRUNTIME140_1.dll怎么办,6个不同方法教你解决问题

一、什么是vcruntime140_1.dll? vcruntime140_1.dll是Visual C Redistributable Packages的一部分,它是Microsoft Visual Studio开发环境中使用的运行时库文件。它包含了许多常用的函数和类,为开发者提供了丰富的功能支持。 二、vcruntime1…

大数据可视化Web框架——飞致云Dataease在Windows端的安装指南(多图说明版)V2.2最新版

DataEase开源代码在Windows系统开发环境搭建与调试指南_怎么部署dataease 2.0-CSDN博客https://blog.csdn.net/tllhc01/article/details/135220598?spm1001.2014.3001.5502参考这一篇,基于dataease2.2源码进行构建 需要先下载三个文件,且版本一一对应均…

C++多态性——(4)纯虚函数与抽象类

归纳编程学习的感悟, 记录奋斗路上的点滴, 希望能帮到一样刻苦的你! 如有不足欢迎指正! 共同学习交流! 🌎欢迎各位→点赞 👍 收藏⭐ 留言​📝 我们不能选择命运,但我们可…

基于注解的IOC配置

基于注解的IOC配置 学习基于注解的IOC配置&#xff0c;大家脑海里首先得有一个认知&#xff0c;即注解配置和xml配置要实现的功能都是一样的&#xff0c;都是要降低程序间的耦合。只是配置的形式不一样。 1.创建工程 pom.xml <?xml version"1.0" encoding&qu…

Vault实战(三)-Vault命令详解

1 login login 命令使用提供的参数向 Vault 验证用户或机器。身份验证成功会返回一个 Vault 令牌 - 在概念上类似于网站上的会话令牌。默认情况下&#xff0c;此令牌会被缓存在本地以供将来发起请求时使用。 -method 标志允许使用其他身份验证方法&#xff0c;例如 userpass、…

MySQL之CRUD,函数与union使用

目录 一.CRUD 1.1.SELECT(查询) 1.2.INSERT&#xff08;新增&#xff09; 1.3.UPDATE(修改) 1.4.DELETE&#xff08;删除&#xff09; 二.函数 2.1.常见函数 2.1.1.字符函数 2.1.2.数字函数 2.1.3.日期函数 2.2.流程控制函数 2.3.聚合函数 三.union与union all 四…

STM32学习笔记十八:WS2812制作像素游戏屏-飞行射击游戏(8)探索游戏多样性,范围伤害模式

前面我们的攻击手段比较单一&#xff0c;虽然已经分出了 EnemyT1 / EnemyT2 / EnemyT3&#xff0c; 但里面还是基本一样的。这回&#xff0c;我们尝试实现一些新的攻击方法&#xff0c;实现一些新的算法。 1、前面我们小飞机EnemyT1 的攻击方式是垂直向下发射子弹。 那么大飞机…

Linux 安装 MySQL

一、安装 MySQL 的准备工作 1. 查看系统版本 cat /etc/redhat-release2. 查看系统是否已经安装过 MySQL 查看是否安装了 MySQL rpm -qa | grep mysql查看是否有安装 mariadb&#xff0c;该软件与 MySQL 数据库有冲突&#xff0c;需要手动卸载 # 如果是 CentOS7 可以检测出…

Scene Creator

场景创建器是一个方便、易于使用的编辑工具&#xff0c;旨在简化创建新场景的过程。使用场景创建器&#xff0c;您可以选择一个模板场景&#xff0c;定义一个目录来存储您的场景&#xff0c;并在需要时自动将新场景添加到构建中。 下载&#xff1a; ​​Unity资源商店链接 资…

什么是CHATGPT

ChatGPT是一个基于大型变换器模型&#xff08;Transformer model&#xff09;的对话AI&#xff0c;它通过机器学习的方法训练&#xff0c;能够生成人类般的文本。GPT&#xff08;Generative Pre-trained Transformer&#xff09;是由OpenAI开发的&#xff0c;其中“GPT”表示模…

vue3安装vue-tools

https://github.com/vuejs/devtools/tree/v6.5.0/packages 打开浏览器扩展程序 这个文件直接拖进扩展程序

【Python】Python函数isalnum用法介绍

本文将从多个方面详细阐述Python函数isalnum的使用方法及其内部实现原理。 一、函数及其作用 isalnum()函数是Python中的一个内置函数&#xff0c;用于判断字符串是否只由数字和字母组成。如果是&#xff0c;则返回True&#xff0c;否则返回False。 str.isalnum() 其中&…

【源码分析】 Calcite 处理流程详解:calcite架构、处理流程以及就一个运行示例进行源码分析

文章目录 一. Calcite整体架构二. Calcite处理流程三. 处理流程样例说明1. 样例demo1.1. 样例数据1.2. 使用calcite 2. 流程源码分析Step1: SQL 解析阶段&#xff08;SQL–>SqlNode&#xff09;Step2: SqlNode 验证&#xff08;SqlNode–>SqlNode&#xff09;1. 注册元数…

Java-数据类型-FAQ-判断数据类型

1 需求 判断数据类型 对象变量.getClass().getName()对象变量 instanceof 特定对象类型 2 接口 3 示例 4 参考资料 java判断数据类型_java判断数据类型的方法-CSDN博客

整理的6个Linux运维脚本

整理的6个Linux运维脚本 1、统计/etc/passwd 中能登录的用户&#xff0c;并将对应在/etc/shadow 中第二列密码提取2、查看当前连接到本机的远程IP地址3、检测本机当前用户是否为超级管理员&#xff08;root&#xff09;4、检查指定目录下是否存在对应文件5、查找 Linux 系统中的…

在线的omniplan甘特图制作工具

在线的omniplan甘特图制作工具 快捷键 按住空格键 可以拖动画布Tab 将选中的任务右缩进&#xff08;设置为子任务&#xff09;Shift Tab 将选中的任务提升一级&#xff08;取消子任务&#xff09;按住Shift可以选择多个任务按住Ctrl 或者 Mac 的 command 可以选择多个任务按…

Redis专题(持续更新)

02-VIP-Redis持久化、主从与哨兵架构详解 文章目录 02-VIP-Redis持久化、主从与哨兵架构详解正文Redis哨兵高可用架构redis哨兵架构搭建步骤&#xff1a;sentinel集群都启动完毕后&#xff0c;会将哨兵集群的元数据信息写入所有sentinel的配置文件里去(追加在文件的最下面)&…

基于深度学习的PCB板缺陷检测系统(含UI界面、yolov8、Python代码、数据集)

项目介绍 项目中所用到的算法模型和数据集等信息如下&#xff1a; 算法模型&#xff1a;     yolov8 yolov8主要包含以下几种创新&#xff1a;         1. 添加注意力机制&#xff08;SE、CBAM等&#xff09;         2. 修改可变形卷积&#xff08;DySnake-主干c…

pod探针

Pod进阶&#xff1a; 探针* Poststart Prestop pod的声明周期开始&#xff1a; k8s的pod重启策略&#xff1a; Always deployment的yaml三种模式都可以&#xff0c;不论正常退出还是非正常退出都重启 OnFailure:只有状态码非零才会重启&#xff0c;正常退出事不重启的 …