From fbcfc6cdaf8b4bd51d69ad941e5bc480f67370d6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=CE=A3lie=20*?= <44349276+tetelie@users.noreply.github.com> Date: Fri, 27 Feb 2026 18:57:31 +0100 Subject: [PATCH] secure mysql connexion --- pom.xml | 5 ++ src/main/java/fr/tetelie/crawler/Crawler.java | 18 ++----- .../fr/tetelie/crawler/DatabaseConfig.java | 54 +++++++++++++++++++ 3 files changed, 62 insertions(+), 15 deletions(-) create mode 100644 src/main/java/fr/tetelie/crawler/DatabaseConfig.java diff --git a/pom.xml b/pom.xml index 23db87d..de8577b 100644 --- a/pom.xml +++ b/pom.xml @@ -25,6 +25,11 @@ mariadb-java-client 3.3.3 + + io.github.cdimascio + dotenv-java + 3.0.0 + diff --git a/src/main/java/fr/tetelie/crawler/Crawler.java b/src/main/java/fr/tetelie/crawler/Crawler.java index 9156ef0..05cbd44 100644 --- a/src/main/java/fr/tetelie/crawler/Crawler.java +++ b/src/main/java/fr/tetelie/crawler/Crawler.java @@ -17,23 +17,11 @@ public class Crawler { public static void main(String[] args) { + new DatabaseConfig(); + boolean isConnected = DatabaseConfig.getInstance().connect(); - String dbUrl = "jdbc:mariadb://localhost:3306/Crawler"; - String user = "root"; - String password = ""; - - System.out.println("Tentative de connexion à la base de données..."); - - try (Connection connection = DriverManager.getConnection(dbUrl, user, password)) { - if (connection != null) { - System.out.println("✅ SUCCÈS : Connexion établie avec brio !"); - System.out.println("Serveur distant : " + connection.getMetaData().getDatabaseProductName()); - } - } catch (SQLException e) { - System.err.println("❌ ÉCHEC : Impossible de se connecter."); - System.err.println("Erreur : " + e.getMessage()); - } + if(!isConnected){return;}; String url = "https://www.amazon.fr/Victool-temp%C3%A9rature-professionnel-r%C3%A9paration-%C3%A9lectronique/dp/B0FP2D7TBY/?_encoding=UTF8&pd_rd_w=UWXHj&content-id=amzn1.sym.5633189b-a269-4b24-8a80-52a48568a326%3Aamzn1.symc.752cde0b-d2ce-4cce-9121-769ea438869e&pf_rd_p=5633189b-a269-4b24-8a80-52a48568a326&pf_rd_r=G56TKFERTQ9WS62C7WY4&pd_rd_wg=mtTBQ&pd_rd_r=519dfa29-c58c-41b3-89ca-4d01e27bfc2e&ref_=pd_hp_d_atf_ci_mcx_mr_ca_hp_atf_d"; diff --git a/src/main/java/fr/tetelie/crawler/DatabaseConfig.java b/src/main/java/fr/tetelie/crawler/DatabaseConfig.java new file mode 100644 index 0000000..94be49b --- /dev/null +++ b/src/main/java/fr/tetelie/crawler/DatabaseConfig.java @@ -0,0 +1,54 @@ +package fr.tetelie.crawler; + +import io.github.cdimascio.dotenv.Dotenv; + +import javax.xml.crypto.Data; +import java.sql.Connection; +import java.sql.DriverManager; +import java.sql.SQLException; + +public class DatabaseConfig { + + static DatabaseConfig instance; + + String dbUrl; + String dbUser; + String dbPass; + + public static DatabaseConfig getInstance() { + return instance; + + } + + public DatabaseConfig() { + + instance = this; + // Charge le fichier .env + Dotenv dotenv = Dotenv.load(); + + // Récupère les variables + dbUrl = dotenv.get("DB_URL"); + dbUser = dotenv.get("DB_USER"); + dbPass = dotenv.get("DB_PASS"); + + // Maintenant tu peux utiliser dbPass dans ton DriverManager.getConnection() + System.out.println("Configuration chargée avec succès !"); + } + + public boolean connect() + { + System.out.println("Tentative de connexion à la base de données..."); + + try (Connection connection = DriverManager.getConnection(DatabaseConfig.getInstance().dbUrl, DatabaseConfig.getInstance().dbUser, DatabaseConfig.getInstance().dbPass)) { + if (connection != null) { + System.out.println("✅ SUCCÈS : Connexion établie avec brio !"); + System.out.println("Serveur distant : " + connection.getMetaData().getDatabaseProductName()); + } + } catch (SQLException e) { + System.err.println("❌ ÉCHEC : Impossible de se connecter."); + System.err.println("Erreur : " + e.getMessage()); + return false; + } + return true; + } +}