


Comment utiliser MySQL et Java pour implémenter une fonction simple d'envoi d'e-mails
Comment utiliser MySQL et Java pour implémenter une simple fonction d'envoi d'e-mails
À l'ère d'Internet d'aujourd'hui, le courrier électronique est largement utilisé pour la communication entre les particuliers et les entreprises, donc la mise en œuvre d'une simple fonction d'envoi d'e-mails est pour de nombreux développeurs. utile.
Cet article expliquera comment utiliser MySQL et Java pour implémenter une fonction simple d'envoi d'e-mails et fournira des exemples de code spécifiques.
- Créer une structure de table de base de données
Tout d'abord, nous devons créer une base de données MySQL et y créer une table pour stocker les informations relatives aux e-mails. Dans cet exemple, nous supposons que le nom de la base de données est « mail » et que le nom de la table est « mails ».
Ce qui suit est l'instruction SQL pour créer la structure de la table :
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 );
- Écrire une classe Java
Ensuite, nous créons une classe Java pour implémenter la fonction d'envoi d'e-mails. Dans cet exemple, nous utilisons l'API JavaMail pour envoyer des e-mails.
Tout d'abord, nous devons importer les dépendances associées de l'API JavaMail et du pilote de connexion 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); } } }
- Utilisation de la fonction d'envoi de mail
Il est très simple d'utiliser la classe MailSender ci-dessus. Introduisez simplement la classe MailSender dans votre application et appelez sa méthode sendMail pour envoyer des e-mails.
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(); } } }
Dans cet exemple, nous utilisons la méthode sendMail pour envoyer un e-mail et stocker les informations pertinentes de l'e-mail dans la base de données.
Résumé
Cet article explique comment utiliser MySQL et Java pour implémenter une fonction simple d'envoi d'e-mails. En utilisant l'API JavaMail pour envoyer des e-mails et en utilisant MySQL pour enregistrer les enregistrements d'e-mails, nous pouvons facilement implémenter des fonctions simples d'envoi d'e-mails.
J'espère que cet article vous sera utile !
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

L'un des changements majeurs introduits dans MySQL 8.4 (la dernière version LTS en 2024) est que le plugin « MySQL Native Password » n'est plus activé par défaut. De plus, MySQL 9.0 supprime complètement ce plugin. Ce changement affecte PHP et d'autres applications

Java 8 présente l'API Stream, fournissant un moyen puissant et expressif de traiter les collections de données. Cependant, une question courante lors de l'utilisation du flux est: comment se casser ou revenir d'une opération FOREAK? Les boucles traditionnelles permettent une interruption ou un retour précoce, mais la méthode Foreach de Stream ne prend pas directement en charge cette méthode. Cet article expliquera les raisons et explorera des méthodes alternatives pour la mise en œuvre de terminaison prématurée dans les systèmes de traitement de flux. Lire plus approfondie: Améliorations de l'API Java Stream Comprendre le flux Forach La méthode foreach est une opération terminale qui effectue une opération sur chaque élément du flux. Son intention de conception est

Java Made Simple : Guide du débutant sur la puissance de programmation Introduction Java est un langage de programmation puissant utilisé dans tout, des applications mobiles aux systèmes d'entreprise. Pour les débutants, la syntaxe de Java est simple et facile à comprendre, ce qui en fait un choix idéal pour apprendre la programmation. Syntaxe de base Java utilise un paradigme de programmation orienté objet basé sur les classes. Les classes sont des modèles qui organisent ensemble les données et les comportements associés. Voici un exemple simple de classe Java : publicclassPerson{privateStringname;privateintage;

Java est un langage de programmation populaire qui peut être appris aussi bien par les développeurs débutants que par les développeurs expérimentés. Ce didacticiel commence par les concepts de base et progresse vers des sujets avancés. Après avoir installé le kit de développement Java, vous pouvez vous entraîner à la programmation en créant un simple programme « Hello, World ! ». Une fois que vous avez compris le code, utilisez l'invite de commande pour compiler et exécuter le programme, et « Hello, World ! » s'affichera sur la console. L'apprentissage de Java commence votre parcours de programmation et, à mesure que votre maîtrise s'approfondit, vous pouvez créer des applications plus complexes.

Les capsules sont des figures géométriques tridimensionnelles, composées d'un cylindre et d'un hémisphère aux deux extrémités. Le volume de la capsule peut être calculé en ajoutant le volume du cylindre et le volume de l'hémisphère aux deux extrémités. Ce tutoriel discutera de la façon de calculer le volume d'une capsule donnée en Java en utilisant différentes méthodes. Formule de volume de capsule La formule du volume de la capsule est la suivante: Volume de capsule = volume cylindrique volume de deux hémisphères volume dans, R: Le rayon de l'hémisphère. H: La hauteur du cylindre (à l'exclusion de l'hémisphère). Exemple 1 entrer Rayon = 5 unités Hauteur = 10 unités Sortir Volume = 1570,8 unités cubes expliquer Calculer le volume à l'aide de la formule: Volume = π × r2 × h (4

Spring Boot simplifie la création d'applications Java robustes, évolutives et prêtes à la production, révolutionnant le développement de Java. Son approche "Convention sur la configuration", inhérente à l'écosystème de ressort, minimise la configuration manuelle, allo

Une pile est une structure de données qui suit le principe LIFO (dernier dans, premier sorti). En d'autres termes, le dernier élément que nous ajoutons à une pile est le premier à être supprimé. Lorsque nous ajoutons (ou poussons) des éléments à une pile, ils sont placés sur le dessus; c'est-à-dire surtout

Une surveillance efficace des bases de données Redis est essentielle pour maintenir des performances optimales, identifier les goulots d'étranglement potentiels et garantir la fiabilité globale du système. Redis Exporter Service est un utilitaire robuste conçu pour surveiller les bases de données Redis à l'aide de Prometheus. Ce didacticiel vous guidera tout au long de l'installation et de la configuration complètes de Redis Exporter Service, vous garantissant ainsi d'établir une solution de surveillance de manière transparente. En suivant ce didacticiel, vous obtiendrez une configuration de surveillance entièrement opérationnelle pour surveiller efficacement les mesures de performances de votre base de données Redis.
