java小课设:使用MySQL做一个聊天室

bro是个懒狗,耗时一个晚上,只写了一些基础功能,其他的可以根据需要自己添加


实现思路:在MySQL数据库中设置一个message表,用来存储聊天信息,聊天界面输入的内容写入message表,用户程序每秒从MySQL中获取一次聊天记录,并加载进入自己的页面,实现聊天室。


食用方法:

ChatServer类中的数据库信息修改为自己的数据库

从ChatApplication类启动

复制粘贴主类中的user语句,可以添加多个用户窗口进行测试。

new User(server);

用户名用来作为聊天室中的昵称

下方的输入框里输入信息,回车键发送,实现相互聊天。



下面是源代码(附注释)


pom依赖

        <dependency>
            <groupId>commons-logging</groupId>
            <artifactId>commons-logging</artifactId>
            <version>1.1.1</version>
        </dependency>
        
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.32</version> <!-- 请根据需要更新版本号 -->
        </dependency>
        
        <!--        JSONObject.fromObject()的依赖, JSONArray.fromObject()-->
        <dependency>
            <groupId>net.sf.json-lib</groupId>
            <artifactId>json-lib</artifactId>
            <version>2.4</version>
            <classifier>jdk15</classifier>
        </dependency>

ChatApplication

import javax.swing.*;

// 定义一个名为ChatApplication的公共类,作为聊天应用程序的入口
public class ChatApplication {
    // main方法是Java程序的入口点
    public static void main(String[] args) {
        // 使用SwingUtilities.invokeLater确保GUI创建和更新在事件调度线程上进行
        SwingUtilities.invokeLater(() -> {
            // 创建ChatServer实例,用于管理聊天服务器和数据库交互
            ChatServer server = new ChatServer();
            // 创建三个User实例,模拟三个用户连接到聊天服务器
            new User(server);
            new User(server);
            new User(server);
        });
    }
}

ChatServer

import java.sql.*;

// ChatServer类,用于管理聊天服务器的功能,包括数据库连接、消息存储和检索
public class ChatServer {
    // 数据库连接对象
    private Connection connection;

    // ChatServer的构造函数,初始化数据库连接并准备聊天环境
    public ChatServer() {
        try {
            // 初始化数据库连接
            // 设置数据库URL、用户名和密码
            String url = "jdbc:mysql://localhost:3306/atguigudb"; // 数据库URL
            String user = "root"; // 数据库用户名
            String password = "123456"; // 数据库密码
            // 获取数据库连接
            connection = DriverManager.getConnection(url, user, password);

            // 创建消息表,如果表不存在则创建
            createMessagesTable();
            // 可选操作:清空聊天记录(根据需求决定是否执行)
            clearChatHistory();
        } catch (Exception e) {
            // 打印异常堆栈信息
            e.printStackTrace();
        }
    }

    // 创建消息表的方法
    private void createMessagesTable() {
        // SQL语句:如果消息表不存在,则创建它
        String createTableSQL = "CREATE TABLE IF NOT EXISTS messages ("
                + "id INT AUTO_INCREMENT PRIMARY KEY, " // 自增主键
                + "sender VARCHAR(255) NOT NULL, " // 发送者
                + "content TEXT NOT NULL, " // 消息内容
                + "timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP" // 时间戳,默认为当前时间
                + ")";
        try (Statement stmt = connection.createStatement()) {
            // 执行SQL语句
            stmt.execute(createTableSQL);
        } catch (Exception e) {
            // 打印异常堆栈信息
            e.printStackTrace();
        }
    }

    // 清空聊天记录的方法(可选)
    private void clearChatHistory() {
        try (PreparedStatement ps = connection.prepareStatement("DELETE FROM messages")) {
            // 执行删除操作,清空messages表
            ps.executeUpdate();
        } catch (Exception e) {
            // 打印异常堆栈信息
            e.printStackTrace();
        }
    }

    // 保存聊天消息的方法
    public void saveMessage(String sender, String message) {
        try (PreparedStatement ps = connection.prepareStatement("INSERT INTO messages (sender,content) VALUES (?, ?)")) {
            // 设置SQL语句中的参数值
            ps.setString(1, sender);
            ps.setString(2, message);
            // 执行插入操作
            ps.executeUpdate();
        } catch (Exception e) {
            // 打印异常堆栈信息
            e.printStackTrace();
        }
    }

    // 获取所有聊天消息的方法
    public String getAllMessages() {
        StringBuilder chatHistory = new StringBuilder();
        try (PreparedStatement ps = connection.prepareStatement(
                "SELECT sender, content FROM messages ORDER BY timestamp ASC")) {
            // 执行查询操作
            ResultSet rs = ps.executeQuery();
            // 遍历结果集,构建聊天历史字符串
            while (rs.next()) {
                String sender = rs.getString("sender");
                String content = rs.getString("content");
                chatHistory.append(sender).append(": ").append(content).append("\n");
            }
        } catch (Exception e) {
            // 打印异常堆栈信息
            e.printStackTrace();
        }
        return chatHistory.toString(); // 返回聊天历史字符串
    }
}

User

import javax.swing.*;
import java.awt.*;

// User类,用于管理用户登录界面和启动聊天客户端
public class User {
    private ChatServer server;

    // User的构造函数,接收ChatServer实例并启动用户登录界面
    public User(ChatServer server) {
        this.server = server;
        loginUser(); // 只启动一个用户的登录窗口,用于演示
    }

    // 启动用户登录界面的方法
    public void loginUser() {
        JFrame loginFrame = new JFrame("请输入用户名");
        JTextField usernameField = new JTextField(15);
        JButton loginButton = new JButton("登录");

        loginFrame.setLayout(new FlowLayout());
        loginFrame.add(new JLabel("用户名:"));
        loginFrame.add(usernameField);
        loginFrame.add(loginButton);

        loginFrame.setSize(400, 200);
        loginFrame.setLocationRelativeTo(null);
        loginFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        loginFrame.setVisible(true);

        // 为登录按钮添加事件监听器
        loginButton.addActionListener(e -> {
            String username = usernameField.getText().trim();
            if (!username.isEmpty()) {
                loginFrame.dispose();
                new ChatClient(username, server); // 启动聊天客户端
            } else {
                JOptionPane.showMessageDialog(loginFrame, "请输入用户名", "错误", JOptionPane.ERROR_MESSAGE);
            }
        });
    }
}

ChatClient

import javax.swing.*;
import java.awt.*;

// ChatClient类,用于管理聊天客户端的界面和功能
public class ChatClient {
    private JFrame frame;
    private JTextArea chatArea;
    private JTextField inputField;

    private ChatServer server;
    private String username;

    // ChatClient的构造函数,接收用户名和ChatServer实例并初始化聊天客户端
    public ChatClient(String username, ChatServer server) {
        this.server = server;
        this.username = username;

        frame = new JFrame(username + " - 聊天室");
        frame.setSize(600, 400);
        frame.setLocationRelativeTo(null);

        chatArea = new JTextArea();
        chatArea.setFont(new Font("Noto Sans CJK", Font.PLAIN, 16));
        chatArea.setEditable(false); // 禁止编辑聊天区域
        inputField = new JTextField();
        inputField.setFont(new Font("Noto Sans CJK", Font.PLAIN, 16));

        frame.setLayout(new BorderLayout());
        frame.add(new JScrollPane(chatArea), BorderLayout.CENTER);
        frame.add(inputField, BorderLayout.SOUTH);

        loadChatHistory(); // 加载聊天历史

        // 为输入框添加事件监听器,用于发送消息
        inputField.addActionListener(e -> sendMessage());

        // 启动一个线程,定期加载聊天历史以更新聊天区域
        new Thread(() -> {
            while (true) {
                try {
                    Thread.sleep(1000); // 每秒更新一次
                    loadChatHistory();
                } catch (InterruptedException ex) {
                    ex.printStackTrace();
                }
            }
        }).start();

        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        frame.setVisible(true);
    }

    // 发送消息的方法
    private void sendMessage() {
        String message = inputField.getText();
        if (!message.trim().isEmpty()) {
            server.saveMessage(username, message); // 保存消息到服务器
            inputField.setText(""); // 清空输入框
        }
    }

    // 加载聊天历史的方法
    private void loadChatHistory() {
        String chatHistory = server.getAllMessages(); // 从服务器获取聊天历史
        chatArea.setText(chatHistory); // 设置聊天区域的内容
        chatArea.setCaretPosition(chatArea.getDocument().getLength()); // 将光标移动到文本末尾
    }
}
posted @ 2024-11-11 19:59  你这过氧化氢掺水了  阅读(80)  评论(0编辑  收藏  举报