首页 > 文章列表 > 如何使用MySQL和Java实现一个简单的邮件发送功能

如何使用MySQL和Java实现一个简单的邮件发送功能

java mysql 邮件发送
478 2023-09-22

如何使用MySQL和Java实现一个简单的邮件发送功能

在当今互联网时代,电子邮件被广泛运用于个人和企业之间的沟通,因此实现一个简单的邮件发送功能对于很多开发者来说是非常有用的。

本文将介绍如何使用MySQL和Java来实现一个简单的邮件发送功能,并提供具体的代码示例。

  1. 创建数据库表结构

首先,我们需要创建一个MySQL数据库,并在其中创建一张表来存储邮件相关的信息。在本例中,我们假设数据库名称为"mail",表名称为"mails"。

下面是创建表结构的SQL语句:

CREATE DATABASE mail;

USE mail;

CREATE TABLE mails (
    id INT PRIMARY KEY AUTO_INCREMENT,
    sender VARCHAR(50),
    receiver VARCHAR(50),
    subject VARCHAR(100),
    body TEXT,
    sent_date DATETIME
);
  1. 编写Java类

接下来,我们创建一个Java类来实现邮件发送的功能。本例中,我们使用JavaMail API来发送邮件。

首先,我们需要导入JavaMail API和MySQL连接驱动的相关依赖。

import java.util.Properties;

import javax.mail.Authenticator;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
import javax.sql.DataSource;
import javax.naming.InitialContext;
import javax.naming.NamingException;

import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.ScalarHandler;

import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;

public class MailSender {
    // 邮件服务器地址
    private static final String SMTP_HOST = "smtp.example.com";
    // 邮件服务器端口
    private static final int SMTP_PORT = 587;
    // 发送者邮箱地址
    private static final String SENDER_EMAIL = "sender@example.com";
    // 发送者邮箱密码
    private static final String SENDER_PASSWORD = "password";

    // 数据库连接池
    private static DataSource dataSource;

    // 初始化数据库连接池
    static {
        dataSource = setupDataSource();
    }

    // 获取数据库连接
    private static DataSource setupDataSource() {
        MysqlDataSource ds = new MysqlDataSource();
        ds.setURL("jdbc:mysql://localhost:3306/mail");
        ds.setUser("root");
        ds.setPassword("password");
        return ds;
    }

    // 发送邮件
    public void sendMail(String receiver, String subject, String body) throws MessagingException, NamingException {
        // 创建会话
        Properties props = new Properties();
        props.put("mail.smtp.host", SMTP_HOST);
        props.put("mail.smtp.port", SMTP_PORT);

        Session session = Session.getInstance(props, new Authenticator() {
            public PasswordAuthentication getPasswordAuthentication() {
                return new PasswordAuthentication(SENDER_EMAIL, SENDER_PASSWORD);
            }
        });

        // 创建邮件
        MimeMessage message = new MimeMessage(session);
        message.setFrom(new InternetAddress(SENDER_EMAIL));
        message.setRecipients(Message.RecipientType.TO, InternetAddress.parse(receiver));
        message.setSubject(subject);
        message.setText(body);

        // 发送邮件
        Transport.send(message);

        // 将邮件记录插入数据库
        try (Connection conn = dataSource.getConnection()) {
            String sql = "INSERT INTO mails(sender, receiver, subject, body, sent_date) VALUES (?, ?, ?, ?, NOW())";
            Object[] params = { SENDER_EMAIL, receiver, subject, body };
            QueryRunner runner = new QueryRunner();
            runner.insert(conn, sql, new ScalarHandler<>(), params);
        }
    }
}
  1. 使用邮件发送功能

使用上述的MailSender类非常简单。只需要在你的应用程序中引入MailSender类,并调用其sendMail方法即可发送邮件。

public class Main {
    public static void main(String[] args) {
        MailSender sender = new MailSender();
        
        try {
            String receiver = "receiver@example.com";
            String subject = "邮件主题";
            String body = "邮件内容";

            sender.sendMail(receiver, subject, body);
            
            System.out.println("邮件发送成功!");
        } catch (MessagingException | NamingException e) {
            e.printStackTrace();
        }
    }
}

在这个示例中,我们使用sendMail方法来发送一封邮件,并将邮件的相关信息存储到数据库中。

总结

本文介绍了如何使用MySQL和Java实现一个简单的邮件发送功能。通过使用JavaMail API发送邮件,并使用MySQL保存邮件记录,我们可以方便地实现简单的邮件发送功能。

希望本文对您有所帮助!