commit e5a82f84f2d272ec7432f7766e82ea82c121fe83 Author: clement.bouillot Date: Wed Oct 20 11:18:27 2021 +0200 diff --git a/SDIS29/.gitignore b/SDIS29/.gitignore new file mode 100644 index 0000000..178135c --- /dev/null +++ b/SDIS29/.gitignore @@ -0,0 +1 @@ +/dist/ diff --git a/SDIS29/build.xml b/SDIS29/build.xml new file mode 100644 index 0000000..710713e --- /dev/null +++ b/SDIS29/build.xml @@ -0,0 +1,71 @@ + + + + + + + + + + + Builds, tests, and runs the project SDIS29. + + + diff --git a/SDIS29/library/jakarta.servlet.jsp.jstl-2.0.0.jar b/SDIS29/library/jakarta.servlet.jsp.jstl-2.0.0.jar new file mode 100644 index 0000000..92712b0 Binary files /dev/null and b/SDIS29/library/jakarta.servlet.jsp.jstl-2.0.0.jar differ diff --git a/SDIS29/library/jakarta.servlet.jsp.jstl-api-2.0.0.jar b/SDIS29/library/jakarta.servlet.jsp.jstl-api-2.0.0.jar new file mode 100644 index 0000000..81059ec Binary files /dev/null and b/SDIS29/library/jakarta.servlet.jsp.jstl-api-2.0.0.jar differ diff --git a/SDIS29/library/mysql-connector-java-8.0.26.jar b/SDIS29/library/mysql-connector-java-8.0.26.jar new file mode 100644 index 0000000..9d038f8 Binary files /dev/null and b/SDIS29/library/mysql-connector-java-8.0.26.jar differ diff --git a/SDIS29/nbproject/ant-deploy.xml b/SDIS29/nbproject/ant-deploy.xml new file mode 100644 index 0000000..c2349eb --- /dev/null +++ b/SDIS29/nbproject/ant-deploy.xml @@ -0,0 +1,57 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/SDIS29/nbproject/build-impl.xml b/SDIS29/nbproject/build-impl.xml new file mode 100644 index 0000000..a697847 --- /dev/null +++ b/SDIS29/nbproject/build-impl.xml @@ -0,0 +1,1434 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Must set src.dir + Must set test.src.dir + Must set build.dir + Must set build.web.dir + Must set build.generated.dir + Must set dist.dir + Must set build.classes.dir + Must set dist.javadoc.dir + Must set build.test.classes.dir + Must set build.test.results.dir + Must set build.classes.excludes + Must set dist.war + + + + + + + + + +The Java EE server classpath is not correctly set up - server home directory is missing. +Either open the project in the IDE and assign the server or setup the server classpath manually. +For example like this: + ant -Dj2ee.server.home=<app_server_installation_directory> + + +The Java EE server classpath is not correctly set up. Your active server type is ${j2ee.server.type}. +Either open the project in the IDE and assign the server or setup the server classpath manually. +For example like this: + ant -Duser.properties.file=<path_to_property_file> (where you put the property "j2ee.platform.classpath" in a .properties file) +or ant -Dj2ee.platform.classpath=<server_classpath> (where no properties file is used) + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Must set javac.includes + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + No tests executed. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +The libs.CopyLibs.classpath property is not set up. +This property must point to +org-netbeans-modules-java-j2seproject-copylibstask.jar file which is part +of NetBeans IDE installation and is usually located at +<netbeans_installation>/java<version>/ant/extra folder. +Either open the project in the IDE and make sure CopyLibs library +exists or setup the property manually. For example like this: + ant -Dlibs.CopyLibs.classpath=a/path/to/org-netbeans-modules-java-j2seproject-copylibstask.jar + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Must set JVM to use for profiling in profiler.info.jvm + Must set profiler agent JVM arguments in profiler.info.jvmargs.agent + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Must select some files in the IDE or set javac.includes + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Must select some files in the IDE or set javac.jsp.includes + + + + + + + + + + + + + + + + + + + + + + + + + + Must select a file in the IDE or set jsp.includes + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Browser not found, cannot launch the deployed application. Try to set the BROWSER environment variable. + + + Launching ${browse.url} + + + + + + Must select one file in the IDE or set run.class + + + + Must select one file in the IDE or set run.class + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Must select one file in the IDE or set debug.class + + + + + + + + + + + + Must select one file in the IDE or set debug.class + + + + + Must set fix.includes + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + This target only works when run from inside the NetBeans IDE. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Must select some files in the IDE or set javac.includes + + + + + + + + + + + + + + + + + + + Some tests failed; see details above. + + + + + + + + + Must select some files in the IDE or set test.includes + + + + Some tests failed; see details above. + + + + Must select some files in the IDE or set test.class + Must select some method in the IDE or set test.method + + + + Some tests failed; see details above. + + + + + Must select one file in the IDE or set test.class + + + + Must select one file in the IDE or set test.class + Must select some method in the IDE or set test.method + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/SDIS29/nbproject/genfiles.properties b/SDIS29/nbproject/genfiles.properties new file mode 100644 index 0000000..26302cb --- /dev/null +++ b/SDIS29/nbproject/genfiles.properties @@ -0,0 +1,8 @@ +build.xml.data.CRC32=fb8fe3ea +build.xml.script.CRC32=3bb75b60 +build.xml.stylesheet.CRC32=1707db4f@1.86.0.1 +# This file is used by a NetBeans-based IDE to track changes in generated files such as build-impl.xml. +# Do not edit this file. You may delete it but then the IDE will never regenerate such files for you. +nbproject/build-impl.xml.data.CRC32=fb8fe3ea +nbproject/build-impl.xml.script.CRC32=d5603c36 +nbproject/build-impl.xml.stylesheet.CRC32=334708a0@1.86.0.1 diff --git a/SDIS29/nbproject/project.properties b/SDIS29/nbproject/project.properties new file mode 100644 index 0000000..cd8b205 --- /dev/null +++ b/SDIS29/nbproject/project.properties @@ -0,0 +1,90 @@ +annotation.processing.enabled=true +annotation.processing.enabled.in.editor=true +annotation.processing.processors.list= +annotation.processing.run.all.processors=true +annotation.processing.source.output=${build.generated.sources.dir}/ap-source-output +auxiliary.org-netbeans-modules-projectapi.jsf_2e_language=JSP +build.classes.dir=${build.web.dir}/WEB-INF/classes +build.classes.excludes=**/*.java,**/*.form +build.dir=build +build.generated.dir=${build.dir}/generated +build.generated.sources.dir=${build.dir}/generated-sources +build.test.classes.dir=${build.dir}/test/classes +build.test.results.dir=${build.dir}/test/results +build.web.dir=${build.dir}/web +build.web.excludes=${build.classes.excludes} +client.urlPart=/Accueil +compile.jsps=false +conf.dir=${source.root}/conf +debug.classpath=${build.classes.dir}:${javac.classpath} +debug.test.classpath=\ + ${run.test.classpath} +display.browser=true +# Files to be excluded from distribution war +dist.archive.excludes= +dist.dir=dist +dist.ear.war=${dist.dir}/${war.ear.name} +dist.javadoc.dir=${dist.dir}/javadoc +dist.war=${dist.dir}/${war.name} +endorsed.classpath=\ + ${libs.javaee-endorsed-api-7.0.classpath} +excludes= +file.reference.jakarta.servlet.jsp.jstl-2.0.0.jar=D:/Downloads/jakarta.servlet.jsp.jstl-2.0.0.jar +file.reference.jakarta.servlet.jsp.jstl-api-2.0.0.jar=D:/Downloads/jakarta.servlet.jsp.jstl-api-2.0.0.jar +file.reference.mysql-connector-java-8.0.26.jar=C:/Program Files (x86)/MySQL/Connector J 8.0/mysql-connector-java-8.0.26.jar +includes=** +j2ee.compile.on.save=true +j2ee.copy.static.files.on.save=true +j2ee.deploy.on.save=true +j2ee.platform=1.7-web +j2ee.platform.classpath=${j2ee.server.domain}/lib/annotations-api.jar:${j2ee.server.domain}/lib/catalina-ant.jar:${j2ee.server.domain}/lib/catalina-ha.jar:${j2ee.server.domain}/lib/catalina-ssi.jar:${j2ee.server.domain}/lib/catalina-storeconfig.jar:${j2ee.server.domain}/lib/catalina-tribes.jar:${j2ee.server.domain}/lib/catalina.jar:${j2ee.server.domain}/lib/ecj-4.20.jar:${j2ee.server.domain}/lib/el-api.jar:${j2ee.server.domain}/lib/jakartaee-migration-1.0.0-shaded.jar:${j2ee.server.domain}/lib/jasper-el.jar:${j2ee.server.domain}/lib/jasper.jar:${j2ee.server.domain}/lib/jaspic-api.jar:${j2ee.server.domain}/lib/jsp-api.jar:${j2ee.server.domain}/lib/servlet-api.jar:${j2ee.server.domain}/lib/tomcat-api.jar:${j2ee.server.domain}/lib/tomcat-coyote.jar:${j2ee.server.domain}/lib/tomcat-dbcp.jar:${j2ee.server.domain}/lib/tomcat-i18n-cs.jar:${j2ee.server.domain}/lib/tomcat-i18n-de.jar:${j2ee.server.domain}/lib/tomcat-i18n-es.jar:${j2ee.server.domain}/lib/tomcat-i18n-fr.jar:${j2ee.server.domain}/lib/tomcat-i18n-ja.jar:${j2ee.server.domain}/lib/tomcat-i18n-ko.jar:${j2ee.server.domain}/lib/tomcat-i18n-pt-BR.jar:${j2ee.server.domain}/lib/tomcat-i18n-ru.jar:${j2ee.server.domain}/lib/tomcat-i18n-zh-CN.jar:${j2ee.server.domain}/lib/tomcat-jdbc.jar:${j2ee.server.domain}/lib/tomcat-jni.jar:${j2ee.server.domain}/lib/tomcat-util-scan.jar:${j2ee.server.domain}/lib/tomcat-util.jar:${j2ee.server.domain}/lib/tomcat-websocket.jar:${j2ee.server.domain}/lib/websocket-api.jar +j2ee.server.type=Tomcat +jar.compress=false +javac.classpath=\ + ${file.reference.mysql-connector-java-8.0.26.jar}:\ + ${file.reference.jakarta.servlet.jsp.jstl-2.0.0.jar}:\ + ${file.reference.jakarta.servlet.jsp.jstl-api-2.0.0.jar} +# Space-separated list of extra javac options +javac.compilerargs= +javac.debug=true +javac.deprecation=false +javac.processorpath=\ + ${javac.classpath} +javac.source=1.7 +javac.target=1.7 +javac.test.classpath=\ + ${javac.classpath}:\ + ${build.classes.dir} +javac.test.processorpath=\ + ${javac.test.classpath} +javadoc.additionalparam= +javadoc.author=false +javadoc.encoding=${source.encoding} +javadoc.noindex=false +javadoc.nonavbar=false +javadoc.notree=false +javadoc.preview=true +javadoc.private=false +javadoc.splitindex=true +javadoc.use=true +javadoc.version=false +javadoc.windowtitle= +lib.dir=${web.docbase.dir}/WEB-INF/lib +persistence.xml.dir=${conf.dir} +platform.active=default_platform +resource.dir=setup +run.test.classpath=\ + ${javac.test.classpath}:\ + ${build.test.classes.dir} +# Space-separated list of JVM arguments used when running a class with a main method or a unit test +# (you may also define separate properties like run-sys-prop.name=value instead of -Dname=value): +runmain.jvmargs= +source.encoding=UTF-8 +source.root=src +src.dir=${source.root}/java +test.src.dir=test +war.content.additional= +war.ear.name=${war.name} +war.name=SDIS29.war +web.docbase.dir=web +webinf.dir=web/WEB-INF diff --git a/SDIS29/nbproject/project.xml b/SDIS29/nbproject/project.xml new file mode 100644 index 0000000..e3b6e85 --- /dev/null +++ b/SDIS29/nbproject/project.xml @@ -0,0 +1,31 @@ + + + org.netbeans.modules.web.project + + + SDIS29 + 1.6.5 + + + ${file.reference.mysql-connector-java-8.0.26.jar} + WEB-INF/lib + + + ${file.reference.jakarta.servlet.jsp.jstl-2.0.0.jar} + WEB-INF/lib + + + ${file.reference.jakarta.servlet.jsp.jstl-api-2.0.0.jar} + WEB-INF/lib + + + + + + + + + + + + diff --git a/SDIS29/src/conf/MANIFEST.MF b/SDIS29/src/conf/MANIFEST.MF new file mode 100644 index 0000000..58630c0 --- /dev/null +++ b/SDIS29/src/conf/MANIFEST.MF @@ -0,0 +1,2 @@ +Manifest-Version: 1.0 + diff --git a/SDIS29/src/java/bdd/Connexion.java b/SDIS29/src/java/bdd/Connexion.java new file mode 100644 index 0000000..3c01e7c --- /dev/null +++ b/SDIS29/src/java/bdd/Connexion.java @@ -0,0 +1,62 @@ +package bdd; +/* +Connexion.java +Classe permettant d'établir une connexion avec une base de données mySQL +*/ +import java.sql.Connection; +import java.sql.DriverManager; + +public class Connexion { + private static Connection connect; // Variable de connexion + + /** + * Constructeur + * @param serveur nom du serveur, localhost si local + * @param bdd nom de la base de données + * @param nomUtil nom utilisateur + * @param mdp mot de passe lié à l'utilisateur + */ + private Connexion(String serveur, String bdd, String nomUtil, String mdp) { + try { + // 1. Chargement du driver + //Class.forName("com.mysql.jdbc.Driver"); + Class.forName("com.mysql.cj.jdbc.Driver"); + System.out.println("Driver accessible"); + + // 2. Initialisation des paramètres de connexion + String host = serveur; // Serveur de bd + String dbname = bdd; // Nom bd + String url = "jdbc:mysql://" + host + "/" + dbname; // url de connexion + //url += "?autoReconnect=true"; // Ajout 26/09/2021 + System.out.println("url : "+url); + String user = nomUtil; // nom du user + System.out.println("nomUtil : "+nomUtil); + String passwd = mdp; // mot de passe + System.out.println("mdp : "+mdp); + + // 3. Connexion + connect = (Connection) DriverManager.getConnection(url, user, passwd); + System.out.println("Connexion réussie !"); + + } catch (Exception e) { + e.printStackTrace(); + } + } + + /** + * Retourne la connection établie (Création d'une connection si elle n'existe pas) + * @param serveur nom du serveur, localhost si local + * @param bdd nom de la base de données + * @param nomUtil nom utilisateur + * @param mdp mot de passe lié à l'utilisateur + * @return connection établie + */ + public static Connection getConnect(String serveur, String bdd, String nomUtil, String mdp) { + System.out.println("getConnect"); + if (connect == null) { + new Connexion(serveur, bdd, nomUtil, mdp); + } + return connect; + } + +} diff --git a/SDIS29/src/java/bdd/PompierMysql.java b/SDIS29/src/java/bdd/PompierMysql.java new file mode 100644 index 0000000..5468ea2 --- /dev/null +++ b/SDIS29/src/java/bdd/PompierMysql.java @@ -0,0 +1,178 @@ +/* + * PompierMysql.java + */ +package bdd; + +import com.test.beans.Pompier; +import java.sql.Connection; +import java.sql.PreparedStatement; +import java.sql.ResultSet; +import java.sql.SQLException; +import java.sql.Statement; +import java.util.ArrayList; +import java.util.logging.Level; +import java.util.logging.Logger; + +/** + * + * @author Clément B + */ +public class PompierMysql { + + private Connection theConnection; + private Pompier unClient; + + /** + * Constructeur + */ + public PompierMysql() { + theConnection = Connexion.getConnect("localhost", //s erveur + "sdis29", // base de données + "adminBDsdis",// user + "mdpBDsdis"); // mot de passe PompierMysql() { + } + + /** + * Recherche de tous les clients + * @return collection de clients + */ + public ArrayList readAll() { + ArrayList lesPompiers = new ArrayList<>(); + +// try { +// Statement stmt = theConnection.createStatement(); +// ResultSet resultQ = null; +// resultQ = stmt.executeQuery("SELECT * FROM client"); SELECT * FROM pompier WHERE pseudo AND mdp +// while (resultQ.next()) { +// unPompier = new Pompier(resultQ.getInt("id"), +// resultQ.getInt("idCaserne"), +// resultQ.getString("nom"), +// resultQ.getString("prenom"), +// resultQ.getInt("statut"), +// resultQ.getInt("typePers"), +// resultQ.getString("mail"), +// resultQ.getString("login"), +// resultQ.getString("mdp"), +// resultQ.getString("adresse"), +// resultQ.getString("cp"), +// resultQ.getString("ville"), +// resultQ.getInt("bip"), +// resultQ.getInt("nbGardes"), +// resultQ.getInt("grade"), +// resultQ.getString("commentaire"), +// resultQ.getString("dateEnreg"), +// resultQ.getString("dateModif"), +// resultQ.getInt("idEquipe")); +// +// } +// lesPompiers.add(unPompier); +// resultQ.close(); +// stmt.close(); +// //theConnection.close(); +// } catch (SQLException ex) { +// System.out.println("SQLException : " + ex.getMessage()); +// System.out.println("SQLState : " + ex.getSQLState()); +// System.out.println("Code erreur : " + ex.getErrorCode()); +// } +// +// return lesPompiers; +// } +// +// /** +// * Creation du client passé en paramètre dans la table Pompier +// * Requête non préparée +// * @param c objet de type Pompier (sans identifiant) +// * @return int : id du Pompier créé +// */ +// public int create(Pompier c) { +// int id = -1; +// try { +// Statement stmt = theConnection.createStatement(); +// int status = stmt.executeUpdate( +// "INSERT INTO pompier (id, idCaserne ,nom, prenom,statut, typePersonne,login ,mail, mdp, adresse, cp, ville, bip, nbGardes, grade, commentaire', dateEnreg, dateModif, idEquipe) " +// + "VALUES ('" + c.getId() + "', '" +// +c.getIdCaserne()+"', '" +// + c.getNom() + "', '" +// + c.getPrenom() + "', '" +// + c.getStatut() + "', " +// + c.getTypePers()+ ", '" +// + c.getLogin()+ "', '" +// + c.getMail()+ "', '" +// + c.getMdp()+ "', '" +// + c.getAdresse()+ "', '" +// + c.getCp()+ "', '" +// + c.getVille() + "', '" +// +c.getBip()+"', '" +// +c.getNbGardes()+"', '" +// +c.getGrade()+"', '" +// +c.getCommentaire()+"', '" +// +c.getDateEnreg()+"', '" +// +c.getDateModif()+"', '" +// +c.getIdEquipe() + "');", +// Statement.RETURN_GENERATED_KEYS); +// +// // Recherche de l'identifiant du client créé +// if (status > 0) { +// ResultSet result = stmt.getGeneratedKeys(); +// if (result.first()) { +// id = result.getInt(1); +// } +// } +// } catch (SQLException ex) { +// System.out.println("SQLException : " + ex.getMessage()); +// System.out.println("SQLState : " + ex.getSQLState()); +// System.out.println("Code erreur : " + ex.getErrorCode()); +// } + return new ArrayList(); + } + + /** + * Creation du client passé en paramètre dans la table client + * Requête préparée + * @param c objet de type Pompier (sans identifiant) + * @return int : id du client créé + */ + public int createRP(Pompier c) { + int id = -1; + try { + PreparedStatement stmt = null; + String sql = "INSERT INTO client (id, idCaserne ,nom, prenom,statut, typePersonne,login ,mail, mdp, adresse, cp, ville, bip, nbGardes, grade, commentaire', dateEnreg, dateModif, idEquipe) " + + "VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ? , ? , ? , ? ,?, ?, ?);"; + stmt = theConnection.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS); + stmt.setInt(1, c.getId()); + stmt.setInt(2, c.getIdCaserne()); + stmt.setString(3, c.getNom()); + stmt.setString(4, c.getPrenom()); + stmt.setString(5, c.getStatut()); + stmt.setInt(6, c.getTypePers()); + stmt.setString(7, c.getLogin()); + stmt.setString(8, c.getMdp()); + stmt.setString(9, c.getAdresse()); + stmt.setString(10, c.getCp()); + stmt.setString(11, c.getVille()); + stmt.setInt(12, c.getBip()); + stmt.setInt(13, c.getNbGardes()); + stmt.setInt(14, c.getGrade()); + stmt.setString(15, c.getCommentaire()); + stmt.setString(16, c.getDateEnreg()); + stmt.setString(17, c.getDateModif()); + stmt.setInt(18, c.getIdEquipe()); + System.out.println("Requête : " + stmt.toString()); + int status = stmt.executeUpdate(); + + + // Recherche de l'identifiant du client créé + if (status > 0) { + ResultSet result = stmt.getGeneratedKeys(); + if (result.first()) { + id = result.getInt(1); + } + } + } catch (SQLException ex) { + System.out.println("SQLException : " + ex.getMessage()); + System.out.println("SQLState : " + ex.getSQLState()); + System.out.println("Code erreur : " + ex.getErrorCode()); + } + return id; + } +} diff --git a/SDIS29/src/java/com/test/beans/Pompier.java b/SDIS29/src/java/com/test/beans/Pompier.java new file mode 100644 index 0000000..59e49f5 --- /dev/null +++ b/SDIS29/src/java/com/test/beans/Pompier.java @@ -0,0 +1,313 @@ +/* + * Bean Pompier + */ +package com.test.beans; + +import java.util.Objects; + +/** + * + * @author ClementB + */ +public class Pompier { + private int id; + private int idCaserne; + private String nom; + private String prenom; + private String statut; + private int typePers; + private String mail; + private String login; + private String mdp; + private String adresse; + private String cp; + private String ville; + private int bip; + private int nbGardes; + private int grade; + private String commentaire; + private String dateEnreg; + private String dateModif; + private int idEquipe; + + public Pompier() { + } + + public int getId() { + return id; + } + + public void setId(int id) { + this.id = id; + } + + public int getIdCaserne() { + return idCaserne; + } + + public void setIdCaserne(int idCaserne) { + this.idCaserne = idCaserne; + } + + public String getNom() { + return nom; + } + + public void setNom(String nom) { + this.nom = nom; + } + + public String getPrenom() { + return prenom; + } + + public void setPrenom(String prenom) { + this.prenom = prenom; + } + + public String getStatut() { + return statut; + } + + public void setStatut(String statut) { + this.statut = statut; + } + + public int getTypePers() { + return typePers; + } + + public void setTypePers(int typePers) { + this.typePers = typePers; + } + + public String getMail() { + return mail; + } + + public void setMail(String mail) { + this.mail = mail; + } + + public String getLogin() { + return login; + } + + public void setLogin(String login) { + this.login = login; + } + + public String getMdp() { + return mdp; + } + + public void setMdp(String mdp) { + this.mdp = mdp; + } + + public String getAdresse() { + return adresse; + } + + public void setAdresse(String adresse) { + this.adresse = adresse; + } + + public String getCp() { + return cp; + } + + public void setCp(String cp) { + this.cp = cp; + } + + public String getVille() { + return ville; + } + + public void setVille(String dateNais) { + this.ville = dateNais; + } + + public int getBip() { + return bip; + } + + public void setBip(int bip) { + this.bip = bip; + } + + public int getNbGardes() { + return nbGardes; + } + + public void setNbGardes(int nbGardes) { + this.nbGardes = nbGardes; + } + + public int getGrade() { + return grade; + } + + public void setGrade(int grade) { + this.grade = grade; + } + + public String getCommentaire() { + return commentaire; + } + + public void setCommentaire(String commentaire) { + this.commentaire = commentaire; + } + + public String getDateEnreg() { + return dateEnreg; + } + + public void setDateEnreg(String dateEnreg) { + this.dateEnreg = dateEnreg; + } + + public String getDateModif() { + return dateModif; + } + + public void setDateModif(String dateModif) { + this.dateModif = dateModif; + } + + public int getIdEquipe() { + return idEquipe; + } + + public void setIdEquipe(int idEquipe) { + this.idEquipe = idEquipe; + } + + @Override + public int hashCode() { + int hash = 7; + hash = 59 * hash + this.id; + hash = 59 * hash + Objects.hashCode(this.idCaserne); + hash = 59 * hash + Objects.hashCode(this.nom); + hash = 59 * hash + Objects.hashCode(this.prenom); + hash = 59 * hash + Objects.hashCode(this.statut); + hash = 59 * hash + this.typePers; + hash = 59 * hash + Objects.hashCode(this.mail); + hash = 59 * hash + Objects.hashCode(this.login); + hash = 59 * hash + Objects.hashCode(this.mdp); + hash = 59 * hash + Objects.hashCode(this.adresse); + hash = 59 * hash + Objects.hashCode(this.cp); + hash = 59 * hash + Objects.hashCode(this.ville); + hash = 59 * hash + Objects.hashCode(this.bip); + hash = 59 * hash + this.nbGardes; + hash = 59 * hash + this.grade; + hash = 59 * hash + Objects.hashCode(this.commentaire); + hash = 59 * hash + Objects.hashCode(this.dateEnreg); + hash = 59 * hash + Objects.hashCode(this.dateModif); + hash = 59 * hash + this.idEquipe; + return hash; + } + + @Override + public boolean equals(Object obj) { + if (this == obj) { + return true; + } + if (obj == null) { + return false; + } + if (getClass() != obj.getClass()) { + return false; + } + final Pompier other = (Pompier) obj; + if (this.id != other.id) { + return false; + } + if (this.typePers != other.typePers) { + return false; + } + if (this.nbGardes != other.nbGardes) { + return false; + } + if (this.grade != other.grade) { + return false; + } + if (this.idEquipe != other.idEquipe) { + return false; + } + if (!Objects.equals(this.idCaserne, other.idCaserne)) { + return false; + } + if (!Objects.equals(this.nom, other.nom)) { + return false; + } + if (!Objects.equals(this.prenom, other.prenom)) { + return false; + } + if (!Objects.equals(this.statut, other.statut)) { + return false; + } + if (!Objects.equals(this.mail, other.mail)) { + return false; + } + if (!Objects.equals(this.login, other.login)) { + return false; + } + if (!Objects.equals(this.mdp, other.mdp)) { + return false; + } + if (!Objects.equals(this.adresse, other.adresse)) { + return false; + } + if (!Objects.equals(this.cp, other.cp)) { + return false; + } + if (!Objects.equals(this.ville, other.ville)) { + return false; + } + if (!Objects.equals(this.bip, other.bip)) { + return false; + } + if (!Objects.equals(this.commentaire, other.commentaire)) { + return false; + } + if (!Objects.equals(this.dateEnreg, other.dateEnreg)) { + return false; + } + if (!Objects.equals(this.dateModif, other.dateModif)) { + return false; + } + return true; + } + + @Override + public String toString() { + return "Pompier{" + "id=" + id + ", idCaserne=" + idCaserne + ", nom=" + nom + ", prenom=" + prenom + ", statut=" + statut + ", typePers=" + typePers + ", mail=" + mail + ", login=" + login + ", mdp=" + mdp + ", adresse=" + adresse + ", cp=" + cp + ", ville=" + ville + ", bip=" + bip + ", nbGardes=" + nbGardes + ", grade=" + grade + ", commentaire=" + commentaire + ", dateEnreg=" + dateEnreg + ", dateModif=" + dateModif + ", idEquipe=" + idEquipe + '}'; + } + + public Pompier(int id, int idCaserne, String nom, String prenom, String statut, int typePers, String mail, String login, String mdp, String adresse, String cp, String ville, int bip, int nbGardes, int grade, String commentaire, String dateEnreg, String dateModif, int idEquipe) { + this.id = id; + this.idCaserne = idCaserne; + this.nom = nom; + this.prenom = prenom; + this.statut = statut; + this.typePers = typePers; + this.mail = mail; + this.login = login; + this.mdp = mdp; + this.adresse = adresse; + this.cp = cp; + this.ville = ville; + this.bip = bip; + this.nbGardes = nbGardes; + this.grade = grade; + this.commentaire = commentaire; + this.dateEnreg = dateEnreg; + this.dateModif = dateModif; + this.idEquipe = idEquipe; + } + + +} diff --git a/SDIS29/src/java/com/test/filter/AuthentifFiltrer.java b/SDIS29/src/java/com/test/filter/AuthentifFiltrer.java new file mode 100644 index 0000000..0db60b9 --- /dev/null +++ b/SDIS29/src/java/com/test/filter/AuthentifFiltrer.java @@ -0,0 +1,259 @@ +/* + * To change this license header, choose License Headers in Project Properties. + * To change this template file, choose Tools | Templates + * and open the template in the editor. + */ +package com.test.filter; + +import jakarta.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpSession; +import java.io.IOException; +import java.io.PrintStream; +import java.io.PrintWriter; +import java.io.StringWriter; +import jakarta.servlet.Filter; +import jakarta.servlet.FilterChain; +import jakarta.servlet.FilterConfig; +import jakarta.servlet.ServletException; +import jakarta.servlet.ServletRequest; +import jakarta.servlet.ServletResponse; + +/** + * + * @author Clément B + */ +public class AuthentifFiltrer implements Filter { + + private static final boolean debug = true; + + // The filter configuration object we are associated with. If + // this value is null, this filter instance is not currently + // configured. + private FilterConfig filterConfig = null; + + public AuthentifFiltrer() { + } + + private void doBeforeProcessing(ServletRequest request, ServletResponse response) + throws IOException, ServletException { + if (debug) { + log("AuthentifFiltrer:DoBeforeProcessing"); + } + + // Write code here to process the request and/or response before + // the rest of the filter chain is invoked. + // For example, a logging filter might log items on the request object, + // such as the parameters. + /* + for (Enumeration en = request.getParameterNames(); en.hasMoreElements(); ) { + String name = (String)en.nextElement(); + String values[] = request.getParameterValues(name); + int n = values.length; + StringBuffer buf = new StringBuffer(); + buf.append(name); + buf.append("="); + for(int i=0; i < n; i++) { + buf.append(values[i]); + if (i < n-1) + buf.append(","); + } + log(buf.toString()); + } + */ + } + + private void doAfterProcessing(ServletRequest request, ServletResponse response) + throws IOException, ServletException { + if (debug) { + log("AuthentifFiltrer:DoAfterProcessing"); + } + + // Write code here to process the request and/or response after + // the rest of the filter chain is invoked. + // For example, a logging filter might log the attributes on the + // request object after the request has been processed. + /* + for (Enumeration en = request.getAttributeNames(); en.hasMoreElements(); ) { + String name = (String)en.nextElement(); + Object value = request.getAttribute(name); + log("attribute: " + name + "=" + value.toString()); + + } + */ + // For example, a filter might append something to the response. + /* + PrintWriter respOut = new PrintWriter(response.getWriter()); + respOut.println("

This has been appended by an intrusive filter."); + */ + } + + /** + * + * @param request The servlet request we are processing + * @param response The servlet response we are creating + * @param chain The filter chain we are processing + * + * @exception IOException if an input/output error occurs + * @exception ServletException if a servlet error occurs + */ + public void doFilter(ServletRequest request, ServletResponse response, + FilterChain chain) + throws IOException, ServletException { +// +// if (debug) { +// log("AuthentifFiltrer:doFilter()"); +// } +// +// doBeforeProcessing(request, response); +// +// Throwable problem = null; +// try { +// chain.doFilter(request, response); +// } catch (Throwable t) { +// // If an exception is thrown somewhere down the filter chain, +// // we still want to execute our after processing, and then +// // rethrow the problem after that. +// problem = t; +// t.printStackTrace(); +// } +// +// doAfterProcessing(request, response); +// +// // If there was a problem, we want to rethrow it if it is +// // a known type, otherwise log it. +// if (problem != null) { +// if (problem instanceof ServletException) { +// throw (ServletException) problem; +// } +// if (problem instanceof IOException) { +// throw (IOException) problem; +// } +// sendProcessingError(problem, response); +// } + + // Cast de l'objet request +HttpServletRequest requete = (HttpServletRequest) request; +// Pas de filtrage des css, des images, des js +String chemin = +requete.getRequestURI().substring(requete.getContextPath().length()); +if (chemin.startsWith("/css") || chemin.startsWith("/images") || +chemin.startsWith("/js")) { +chain.doFilter(request, response); +return; +} +// Récupération de la session +HttpSession maSession = requete.getSession(); +// Récupération du booléen d'authentification +boolean authentificationOK = false; +if (maSession.getAttribute("isAuthentified") != null) { + +authentificationOK = (boolean) +maSession.getAttribute("isAuthentified"); +} +if (authentificationOK) { +// Poursuite sans problème +chain.doFilter(request, response); +} else { +// retour vers la page d'authentification +request.getRequestDispatcher("Accueil").forward(request, response); +} + + } + + /** + * Return the filter configuration object for this filter. + */ + public FilterConfig getFilterConfig() { + return (this.filterConfig); + } + + /** + * Set the filter configuration object for this filter. + * + * @param filterConfig The filter configuration object + */ + public void setFilterConfig(FilterConfig filterConfig) { + this.filterConfig = filterConfig; + } + + /** + * Destroy method for this filter + */ + public void destroy() { + } + + /** + * Init method for this filter + */ + public void init(FilterConfig filterConfig) { + this.filterConfig = filterConfig; + if (filterConfig != null) { + if (debug) { + log("AuthentifFiltrer:Initializing filter"); + } + } + } + + /** + * Return a String representation of this object. + */ + @Override + public String toString() { + if (filterConfig == null) { + return ("AuthentifFiltrer()"); + } + StringBuffer sb = new StringBuffer("AuthentifFiltrer("); + sb.append(filterConfig); + sb.append(")"); + return (sb.toString()); + } + + private void sendProcessingError(Throwable t, ServletResponse response) { + String stackTrace = getStackTrace(t); + + if (stackTrace != null && !stackTrace.equals("")) { + try { + response.setContentType("text/html"); + PrintStream ps = new PrintStream(response.getOutputStream()); + PrintWriter pw = new PrintWriter(ps); + pw.print("\n\nError\n\n\n"); //NOI18N + + // PENDING! Localize this for next official release + pw.print("

The resource did not process correctly

\n
\n");                
+                pw.print(stackTrace);                
+                pw.print("
\n"); //NOI18N + pw.close(); + ps.close(); + response.getOutputStream().close(); + } catch (Exception ex) { + } + } else { + try { + PrintStream ps = new PrintStream(response.getOutputStream()); + t.printStackTrace(ps); + ps.close(); + response.getOutputStream().close(); + } catch (Exception ex) { + } + } + } + + public static String getStackTrace(Throwable t) { + String stackTrace = null; + try { + StringWriter sw = new StringWriter(); + PrintWriter pw = new PrintWriter(sw); + t.printStackTrace(pw); + pw.close(); + sw.close(); + stackTrace = sw.getBuffer().toString(); + } catch (Exception ex) { + } + return stackTrace; + } + + public void log(String msg) { + filterConfig.getServletContext().log(msg); + } + +} diff --git a/SDIS29/src/java/com/test/forms/AuthentifForm.java b/SDIS29/src/java/com/test/forms/AuthentifForm.java new file mode 100644 index 0000000..eefd82c --- /dev/null +++ b/SDIS29/src/java/com/test/forms/AuthentifForm.java @@ -0,0 +1,55 @@ +/* + * To change this license header, choose License Headers in Project Properties. + * To change this template file, choose Tools | Templates + * and open the template in the editor. + */ +package com.test.forms; + +//import com.test.beans.User; +import jakarta.servlet.http.HttpServletRequest; +import java.sql.Connection; +import java.sql.ResultSet; +import java.sql.SQLException; +import java.sql.Statement; +import java.util.ArrayList; +import java.util.logging.Level; +import java.util.logging.Logger; +//import java.sql.Connection; + +/** + * + * @author Clément B + */ +public class AuthentifForm { + + private String resultat; + + public String getResultat() { + return resultat; + } + + public void setResultat(String resultat) { + this.resultat = resultat; + } + + /** + * Contôle si les paramètres ztPseudo et ztMDP passé dans request + * correspondent à ceux de l'administrateur, Mise à jour de l'attribut + * resultat + * + * @param request + * @return true is ok, false sinon + */ + public boolean controlerAdmin(HttpServletRequest request) { + //reccupération des zones saisies ztPseudo et ztMdp- hasher le mdp + + //acces a la table pompier en selectionnant le msp et le pseudo + + // si trouvé, determiner son role + stocker ses éléments en session + + // mise a jour bool + + return true; + } + +} diff --git a/SDIS29/src/java/com/test/forms/NouveauPompierForm.java b/SDIS29/src/java/com/test/forms/NouveauPompierForm.java new file mode 100644 index 0000000..b5c1c9a --- /dev/null +++ b/SDIS29/src/java/com/test/forms/NouveauPompierForm.java @@ -0,0 +1,70 @@ +/* + * NouveauPompierForm.java + */ +package com.test.forms; + +import bdd.PompierMysql; +import com.mysql.cj.util.StringUtils; +import com.test.beans.Pompier; +import jakarta.servlet.http.HttpServletRequest; +import java.util.Enumeration; + +/** + * + * @author Clément B + */ +public class NouveauPompierForm { + + String message=""; + + public int verifNouveauPompier(HttpServletRequest request) { + + + // Contrôle car "<" dans les zones de texte + //String [] lesSaisies = request.getParameterValues(noRueString); // Valeurs saisies + Enumeration lesNoms = request.getParameterNames(); + int erreur = 0; + while (erreur ==0 && lesNoms.hasMoreElements()) { + Object paramObjet=lesNoms.nextElement(); + String param=(String)paramObjet; + String value=request.getParameter(param); + if (value.contains("<")) { + message = "Veullez recommencer votre saisie, une anomalie sur une zone de saisie a été détectée "; + erreur=1; + } + } + if (erreur > 0) return -1; + +// Creation d'un objet de type Pompier avec les données transmises + Pompier unPompier = new Pompier(request.getParameter.("ztId"), + request.getParameter("ztIdCaserne"), + request.getParameter("ztNom"), + request.getParameter("ztPrenom"), + request.getParameter("ztStatut"), + + request.getParameter("ztTypePers"), + request.getParameter("ztMail"), + request.getParameter("ztLogin"), + request.getParameter("ztMdp"), + request.getParameter("ztAdresse"), + request.getParameter("ztCp"), + request.getParameter("ztVille"), + request.getParameter("ztBip"), + request.getParameter("ztNbGrade"), + request.getParameter("ztCommentaire"), + request.getParameter("ztDateEnreg"), + request.getParameter("ztDateModif"), + request.getParameter("ztIdEquipe")); + PompierMysql cm = new PompierMysql(); + int idPompier = cm.createRP(unPompier); // Requête préparée + if (idPompier == -1) { + message = "Erreur lors de la création du pompier"; + } + return idPompier; + + } + + public String getMessage() { + return message; + } +} diff --git a/SDIS29/src/java/com/test/servlets/AccueilServlet.java b/SDIS29/src/java/com/test/servlets/AccueilServlet.java new file mode 100644 index 0000000..09a6082 --- /dev/null +++ b/SDIS29/src/java/com/test/servlets/AccueilServlet.java @@ -0,0 +1,105 @@ +/* + * To change this license header, choose License Headers in Project Properties. + * To change this template file, choose Tools | Templates + * and open the template in the editor. + */ +package com.test.servlets; + +import com.test.forms.AuthentifForm; +import java.io.IOException; +import java.io.PrintWriter; +import jakarta.servlet.ServletException; +import jakarta.servlet.http.HttpServlet; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletResponse; +import jakarta.servlet.http.HttpSession; + +/** + * + * @author ClementB + */ +public class AccueilServlet extends HttpServlet { + + /** + * Processes requests for both HTTP GET and POST + * methods. + * + * @param request servlet request + * @param response servlet response + * @throws ServletException if a servlet-specific error occurs + * @throws IOException if an I/O error occurs + */ + protected void processRequest(HttpServletRequest request, HttpServletResponse response) + throws ServletException, IOException { + response.setContentType("text/html;charset=UTF-8"); + try ( PrintWriter out = response.getWriter()) { + /* TODO output your page here. You may use following sample code. */ + out.println(""); + out.println(""); + out.println(""); + out.println("Servlet AccueilServlet"); + out.println(""); + out.println(""); + out.println("

Servlet AccueilServlet at " + request.getContextPath() + "

"); + out.println(""); + out.println(""); + } + } + + // + /** + * Handles the HTTP GET method. + * + * @param request servlet request + * @param response servlet response + * @throws ServletException if a servlet-specific error occurs + * @throws IOException if an I/O error occurs + */ + @Override + protected void doGet(HttpServletRequest request, HttpServletResponse response) + throws ServletException, IOException { + //processRequest(request, response); + HttpSession maSession = request.getSession(); + maSession.removeAttribute("isAuthentified"); + System.out.println("****blablabla****"); + getServletContext().getRequestDispatcher("/WEB-INF/accueilJSP.jsp").forward(request, response); + } + + /** + * Handles the HTTP POST method. + * + * @param request servlet request + * @param response servlet response + * @throws ServletException if a servlet-specific error occurs + * @throws IOException if an I/O error occurs + */ + @Override + protected void doPost(HttpServletRequest request, HttpServletResponse response) + throws ServletException, IOException { + // Création de l'objet leControle de type AuthentifForm + AuthentifForm leControle = new AuthentifForm(); + // Appel de la méthode controlerAdmin + boolean isAdmin = leControle.controlerAdmin(request); + // Création de 2 attributs de requête (isAdmin et leControle) + request.setAttribute("isAdmin", isAdmin); + request.setAttribute("controlForm", leControle); + + HttpSession maSession = request.getSession(); + maSession.setAttribute("isAuthentified", true); + + // Affichage de la JSP + getServletContext().getRequestDispatcher("/WEB-INF/accueilJSP.jsp") + .forward(request, response); + } + + /** + * Returns a short description of the servlet. + * + * @return a String containing servlet description + */ + @Override + public String getServletInfo() { + return "Short description"; + }// + +} diff --git a/SDIS29/src/java/com/test/servlets/ListeServlet.java b/SDIS29/src/java/com/test/servlets/ListeServlet.java new file mode 100644 index 0000000..fc3ea76 --- /dev/null +++ b/SDIS29/src/java/com/test/servlets/ListeServlet.java @@ -0,0 +1,94 @@ +/* + * To change this license header, choose License Headers in Project Properties. + * To change this template file, choose Tools | Templates + * and open the template in the editor. + */ +package com.test.servlets; + +import bdd.PompierMysql; +import java.io.IOException; +import java.io.PrintWriter; +import jakarta.servlet.ServletException; +import jakarta.servlet.annotation.WebServlet; +import jakarta.servlet.http.HttpServlet; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletResponse; + +/** + * + * @author ClementB + */ +@WebServlet(name = "ListeServlet", urlPatterns = {"/ListeClients"}) +public class ListeServlet extends HttpServlet { + + /** + * Processes requests for both HTTP GET and POST + * methods. + * + * @param request servlet request + * @param response servlet response + * @throws ServletException if a servlet-specific error occurs + * @throws IOException if an I/O error occurs + */ + protected void processRequest(HttpServletRequest request, HttpServletResponse response) + throws ServletException, IOException { + response.setContentType("text/html;charset=UTF-8"); + try ( PrintWriter out = response.getWriter()) { + /* TODO output your page here. You may use following sample code. */ + out.println(""); + out.println(""); + out.println(""); + out.println("Servlet ListeServlet"); + out.println(""); + out.println(""); + out.println("

Servlet ListeServlet at " + request.getContextPath() + "

"); + out.println(""); + out.println(""); + } + } + + // + /** + * Handles the HTTP GET method. + * + * @param request servlet request + * @param response servlet response + * @throws ServletException if a servlet-specific error occurs + * @throws IOException if an I/O error occurs + */ + @Override + protected void doGet(HttpServletRequest request, HttpServletResponse response) + throws ServletException, IOException { + //processRequest(request, response); + + // Recherche de tous les clients et ajout dans un attribut de l'objet request + PompierMysql clientMs = new PompierMysql(); + request.setAttribute("lesClients", clientMs.readAll()); + getServletContext().getRequestDispatcher("/WEB-INF/listeJSP.jsp").forward(request, response); + } + + /** + * Handles the HTTP POST method. + * + * @param request servlet request + * @param response servlet response + * @throws ServletException if a servlet-specific error occurs + * @throws IOException if an I/O error occurs + */ + @Override + protected void doPost(HttpServletRequest request, HttpServletResponse response) + throws ServletException, IOException { + processRequest(request, response); + } + + /** + * Returns a short description of the servlet. + * + * @return a String containing servlet description + */ + @Override + public String getServletInfo() { + return "Short description"; + }// + +} diff --git a/SDIS29/src/java/com/test/servlets/NouveauServlet.java b/SDIS29/src/java/com/test/servlets/NouveauServlet.java new file mode 100644 index 0000000..cd565ea --- /dev/null +++ b/SDIS29/src/java/com/test/servlets/NouveauServlet.java @@ -0,0 +1,115 @@ +/* + * To change this license header, choose License Headers in Project Properties. + * To change this template file, choose Tools | Templates + * and open the template in the editor. + */ +package com.test.servlets; + +import com.test.forms.NouveauPompierForm; +import java.io.IOException; +import java.io.PrintWriter; +import jakarta.servlet.ServletException; +import jakarta.servlet.http.HttpServlet; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletResponse; +import jakarta.servlet.http.HttpSession; +import java.util.ArrayList; + +/** + * + * @author ClementB + */ +public class NouveauServlet extends HttpServlet { + + /** + * Processes requests for both HTTP GET and POST + * methods. + * + * @param request servlet request + * @param response servlet response + * @throws ServletException if a servlet-specific error occurs + * @throws IOException if an I/O error occurs + */ + protected void processRequest(HttpServletRequest request, HttpServletResponse response) + throws ServletException, IOException { + response.setContentType("text/html;charset=UTF-8"); + try ( PrintWriter out = response.getWriter()) { + /* TODO output your page here. You may use following sample code. */ + out.println(""); + out.println(""); + out.println(""); + out.println("Servlet NouveauServlet"); + out.println(""); + out.println(""); + out.println("

Servlet NouveauServlet at " + request.getContextPath() + "

"); + out.println(""); + out.println(""); + } + } + + // + /** + * Handles the HTTP GET method. + * + * @param request servlet request + * @param response servlet response + * @throws ServletException if a servlet-specific error occurs + * @throws IOException if an I/O error occurs + */ + @Override + protected void doGet(HttpServletRequest request, HttpServletResponse response) + throws ServletException, IOException { + //processRequest(request, response); + getServletContext().getRequestDispatcher("/WEB-INF/nouveauJSP.jsp").forward(request, response); + } + + /** + * Handles the HTTP POST method. + * + * @param request servlet request + * @param response servlet response + * @throws ServletException if a servlet-specific error occurs + * @throws IOException if an I/O error occurs + */ + @Override + protected void doPost(HttpServletRequest request, HttpServletResponse response) + throws ServletException, IOException { + + NouveauPompierForm nvf = new NouveauPompierForm(); + int idPompier = nvf.verifNouveauPompier(request); + request.setAttribute("idPompier", idPompier); + request.setAttribute("message", nvf.getMessage()); + if(idPompier != -1) { + //Ajout du no du client créé, dans une collection d'entiers stockée en session + //1, Récupération de la session : + HttpSession maSession = request.getSession(); + //2, Récupération de la collection des clients si elle existe, création sinon : + ArrayList lesNouveauxClients = (ArrayList) + maSession.getAttribute("lesNvxClients"); + if(lesNouveauxClients == null) { + lesNouveauxClients = new ArrayList<>(); + } + //3, Ajout du no du client créé dans la collection : + lesNouveauxClients.add(idPompier); + //4, MAJ de la session + maSession.setAttribute("lesNvxClients", lesNouveauxClients); + } + getServletContext().getRequestDispatcher("/WEB-INF/nouveauJSP.jsp").forward(request, response); + HttpSession maSession = request.getSession(); +// String maChaine = null; +// if(maSession.getAttribute("monAttribut" != null) { +// String maChaine = (String) maSession.getAttribute("monAttribut"); +// } + } + + /** + * Returns a short description of the servlet. + * + * @return a String containing servlet description + */ + @Override + public String getServletInfo() { + return "Short description"; + }// + +} diff --git a/SDIS29/web/META-INF/context.xml b/SDIS29/web/META-INF/context.xml new file mode 100644 index 0000000..fc7e5a6 --- /dev/null +++ b/SDIS29/web/META-INF/context.xml @@ -0,0 +1,2 @@ + + diff --git a/SDIS29/web/WEB-INF/accueilJSP.jsp b/SDIS29/web/WEB-INF/accueilJSP.jsp new file mode 100644 index 0000000..fd3d56c --- /dev/null +++ b/SDIS29/web/WEB-INF/accueilJSP.jsp @@ -0,0 +1,80 @@ +<%@include file = "jspf/enteteJSPF.jspf" %> +<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> +<%@page import="com.test.forms.AuthentifForm" %> + + +

Bienvenue sur la nouvelle application de gestion des pompiers :

+${empty param.ztPseudo ? "Veuillez vous authentifier" : "Authentification réussie"} + + + +
+ Authentification +
+
+

+ +
+
+
+ + + +

${controlForm.getResultat()}

+
+
+ +
+ +<%@include file="jspf/menuJSPF.jspf" %> + + + + + + + diff --git a/SDIS29/web/WEB-INF/jspf/enteteJSPF.jspf b/SDIS29/web/WEB-INF/jspf/enteteJSPF.jspf new file mode 100644 index 0000000..aaa6160 --- /dev/null +++ b/SDIS29/web/WEB-INF/jspf/enteteJSPF.jspf @@ -0,0 +1,17 @@ +<%-- any content can be specified here e.g.: --%> +<%@page contentType="text/html" pageEncoding="UTF-8"%> +<%-- + Document : newjsp + Created on : 18 sept. 2021, 15:34:04 + Author : ClémentB +--%> + + + + + + Gestion des pompiers + + + +

Gestion des pompiers

diff --git a/SDIS29/web/WEB-INF/jspf/menuJSPF.jspf b/SDIS29/web/WEB-INF/jspf/menuJSPF.jspf new file mode 100644 index 0000000..b72dfdd --- /dev/null +++ b/SDIS29/web/WEB-INF/jspf/menuJSPF.jspf @@ -0,0 +1,7 @@ +<%-- any content can be specified here e.g.: --%> +<%@ page pageEncoding="UTF-8" %> + diff --git a/SDIS29/web/WEB-INF/listeJSP.jsp b/SDIS29/web/WEB-INF/listeJSP.jsp new file mode 100644 index 0000000..8dde894 --- /dev/null +++ b/SDIS29/web/WEB-INF/listeJSP.jsp @@ -0,0 +1,60 @@ + <%@include file = "jspf/enteteJSPF.jspf" %> +<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> +<%@page import="java.util.ArrayList" %> +

Liste des clients

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
IDIdCaserneNomPrénomStatutType PersonneMailLoginAdresseCPVilleBipNb gardeGradeCommentaireDate créationN Equipe
+
+ <%@include file="jspf/menuJSPF.jspf" %> + + diff --git a/SDIS29/web/WEB-INF/nouveauJSP.jsp b/SDIS29/web/WEB-INF/nouveauJSP.jsp new file mode 100644 index 0000000..8f6be3d --- /dev/null +++ b/SDIS29/web/WEB-INF/nouveauJSP.jsp @@ -0,0 +1,70 @@ +<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> +<%@include file = "jspf/enteteJSPF.jspf" %> +

Création d'un nouveau Pompier

+ +Page en construction +
+ Fiche Pompier +
+ + + + + + + + + +

+ Adresse postale : + + +

+ + + + + + +

+ Information Pompier: + + + +
+ + + + 60 +
+ +

+ + + +
+
+ +

+ + + Le Pompier no ${id} a été créé avec succès + + + E R R E U R : ${message} + + + Cliquez sur "Valider" après avoir renseigné les informations demandées + + +

+ +<%@include file="jspf/menuJSPF.jspf" %> +
+

Liste des numéros des clients récement créés :

+ + ${unClient} - + +
+ + diff --git a/SDIS29/web/WEB-INF/web.xml b/SDIS29/web/WEB-INF/web.xml new file mode 100644 index 0000000..52aed8e --- /dev/null +++ b/SDIS29/web/WEB-INF/web.xml @@ -0,0 +1,35 @@ + + + + AuthentifFiltrer + com.test.filter.AuthentifFiltrer + + + AuthentifFiltrer + /* + + + AccueilServlet + com.test.servlets.AccueilServlet + + + NouveauServlet + com.test.servlets.NouveauServlet + + + AuthentificationServlet + com.test.servlets.AuthentificationServlet + + + AccueilServlet + /Accueil + + + NouveauServlet + /NouveauClient + + + AuthentificationServlet + /Authentification + + diff --git a/SDIS29/web/css/defaultCSS.css b/SDIS29/web/css/defaultCSS.css new file mode 100644 index 0000000..a8a6c20 --- /dev/null +++ b/SDIS29/web/css/defaultCSS.css @@ -0,0 +1,84 @@ +/* +To change this license header, choose License Headers in Project Properties. +To change this template file, choose Tools | Templates +and open the template in the editor. +*/ +/* + Created on : 18 oct. 2021, 14:23:00 + Author : nathan.balducci +*/ + +.right { float:right; margin:0 10px 0 20px; } + +.backgroundGrey {background: #333333;} + +.textRedLED {font-family: Tahoma;text-shadow:0 0 3px #db0005, 0 0 10px #db0005, 0 0 20px #db0005;color:#db0005; background-color:#333333;} + +h1 {font-family: Tahoma;text-shadow:#ffe69a 0 -1px 0,#db0005 2px 2px 0,#db0005 3px 3px 0,#db0005 4px 4px 0,#db0005 5px 5px 10px;color:#ececec;} + +.textDegradOrange {font-family: Tahoma;text-shadow:#ffe69a 0 -1px 0,#ff6e18 2px 2px 0,#ff6e18 3px 3px 0,#ff6e18 4px 4px 0,#ff6e18 5px 5px 10px;color:#ececec;} + +.textBeige {font-family: Tahoma;color:#ffe69a;} + +a {font-family: Tahoma;color:#ff6e18;text-shadow:0;} + +html {font-family: Tahoma;text-shadow:1; padding: 30px;color:#fff;background-color:#333333;} + +fieldset +{ + border:3px solid #db0005; + -moz-border-radius:8px; + -webkit-border-radius:8px; + border-radius:8px; + border-style: inset; +} + +input { + +background: #ff6e18; + +color: #fff; + +border: 1px solid #eee; + +border-radius: 5px; + +border-style: outset; + +text-shadow:none; + +} + +input:hover { + +background: #db0005; + +color: #fff; + +border: 1px solid #eee; + +border-radius: 5px; + +border-style: inset; + +text-shadow:none; + +} + +table { + table-layout: inherit; + width: 100%; + border-collapse: collapse; + border: 3px #db0005; +} + +thead, tfoot { + color: white; + text-shadow: 1px 1px 1px black; +} + +thead th, tfoot th, tfoot td { + background: linear-gradient(to bottom, rgba(0,0,0,0.1), rgba(0,0,0,0.5)); + border: 3px #db0005; + width: 30%; +} \ No newline at end of file diff --git a/SDIS29/web/images/accueil.png b/SDIS29/web/images/accueil.png new file mode 100644 index 0000000..b80fc77 Binary files /dev/null and b/SDIS29/web/images/accueil.png differ diff --git a/SDIS29/web/images/bandeau.jpg b/SDIS29/web/images/bandeau.jpg new file mode 100644 index 0000000..3cbcb28 Binary files /dev/null and b/SDIS29/web/images/bandeau.jpg differ diff --git a/SDIS29/web/images/bandeau_SPV.jpg b/SDIS29/web/images/bandeau_SPV.jpg new file mode 100644 index 0000000..230706f Binary files /dev/null and b/SDIS29/web/images/bandeau_SPV.jpg differ diff --git a/SDIS29/web/images/bandeau_internet_reseaux_sociaux.jpg b/SDIS29/web/images/bandeau_internet_reseaux_sociaux.jpg new file mode 100644 index 0000000..a477e5d Binary files /dev/null and b/SDIS29/web/images/bandeau_internet_reseaux_sociaux.jpg differ diff --git a/SDIS29/web/images/bandeau_staying_alive.jpg b/SDIS29/web/images/bandeau_staying_alive.jpg new file mode 100644 index 0000000..45386d6 Binary files /dev/null and b/SDIS29/web/images/bandeau_staying_alive.jpg differ diff --git a/SDIS29/web/images/bandeau_surveillants_baignade_2018.jpg b/SDIS29/web/images/bandeau_surveillants_baignade_2018.jpg new file mode 100644 index 0000000..eb6d0eb Binary files /dev/null and b/SDIS29/web/images/bandeau_surveillants_baignade_2018.jpg differ diff --git a/SDIS29/web/images/camion.gif b/SDIS29/web/images/camion.gif new file mode 100644 index 0000000..6240b2a Binary files /dev/null and b/SDIS29/web/images/camion.gif differ diff --git a/SDIS29/web/images/img-photo-home.jpg b/SDIS29/web/images/img-photo-home.jpg new file mode 100644 index 0000000..28c2556 Binary files /dev/null and b/SDIS29/web/images/img-photo-home.jpg differ diff --git a/SDIS29/web/images/img-video-home.jpg b/SDIS29/web/images/img-video-home.jpg new file mode 100644 index 0000000..cba69df Binary files /dev/null and b/SDIS29/web/images/img-video-home.jpg differ diff --git a/SDIS29/web/images/logo-sdis.png b/SDIS29/web/images/logo-sdis.png new file mode 100644 index 0000000..c15050e Binary files /dev/null and b/SDIS29/web/images/logo-sdis.png differ diff --git a/SDIS29/web/images/pageEnConstruction.jpg b/SDIS29/web/images/pageEnConstruction.jpg new file mode 100644 index 0000000..60e3663 Binary files /dev/null and b/SDIS29/web/images/pageEnConstruction.jpg differ diff --git a/SDIS29/web/images/publications.png b/SDIS29/web/images/publications.png new file mode 100644 index 0000000..08b38c1 Binary files /dev/null and b/SDIS29/web/images/publications.png differ diff --git a/SDIS29/web/images/searchButton.gif b/SDIS29/web/images/searchButton.gif new file mode 100644 index 0000000..a8a1621 Binary files /dev/null and b/SDIS29/web/images/searchButton.gif differ diff --git a/SDIS29/web/images/slider-4.png b/SDIS29/web/images/slider-4.png new file mode 100644 index 0000000..907e1d9 Binary files /dev/null and b/SDIS29/web/images/slider-4.png differ diff --git a/SDIS29/web/index.html b/SDIS29/web/index.html new file mode 100644 index 0000000..f2e80aa --- /dev/null +++ b/SDIS29/web/index.html @@ -0,0 +1,16 @@ + + + + + Gestion des clients + + + + +
TODO write content
+ + diff --git a/SDIS29/web/welcomeJSF.jsp b/SDIS29/web/welcomeJSF.jsp new file mode 100644 index 0000000..05eb615 --- /dev/null +++ b/SDIS29/web/welcomeJSF.jsp @@ -0,0 +1,41 @@ +<%-- + Licensed to the Apache Software Foundation (ASF) under one + or more contributor license agreements. See the NOTICE file + distributed with this work for additional information + regarding copyright ownership. The ASF licenses this file + to you under the Apache License, Version 2.0 (the + "License"); you may not use this file except in compliance + with the License. You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, + software distributed under the License is distributed on an + "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + KIND, either express or implied. See the License for the + specific language governing permissions and limitations + under the License. + +--%> +<%@page contentType="text/html" pageEncoding="UTF-8"%> + +<%@taglib prefix="f" uri="http://java.sun.com/jsf/core"%> +<%@taglib prefix="h" uri="http://java.sun.com/jsf/html"%> + + + +<%-- + This file is an entry point for JavaServer Faces application. +--%> + + + + + JSP Page + + +

+ + +