commit 1062bf48b204a24f5a0b4ca7f80067f810aaea84 Author: clement.bouillot Date: Mon Oct 18 11:00:32 2021 +0200 diff --git a/build.xml b/build.xml new file mode 100644 index 0000000..710713e --- /dev/null +++ b/build.xml @@ -0,0 +1,71 @@ + + + + + + + + + + + Builds, tests, and runs the project SDIS29. + + + diff --git a/library/jakarta.servlet.jsp.jstl-2.0.0.jar b/library/jakarta.servlet.jsp.jstl-2.0.0.jar new file mode 100644 index 0000000..92712b0 Binary files /dev/null and b/library/jakarta.servlet.jsp.jstl-2.0.0.jar differ diff --git a/library/jakarta.servlet.jsp.jstl-api-2.0.0.jar b/library/jakarta.servlet.jsp.jstl-api-2.0.0.jar new file mode 100644 index 0000000..81059ec Binary files /dev/null and b/library/jakarta.servlet.jsp.jstl-api-2.0.0.jar differ diff --git a/library/mysql-connector-java-8.0.26.jar b/library/mysql-connector-java-8.0.26.jar new file mode 100644 index 0000000..9d038f8 Binary files /dev/null and b/library/mysql-connector-java-8.0.26.jar differ diff --git a/nbproject/ant-deploy.xml b/nbproject/ant-deploy.xml new file mode 100644 index 0000000..c2349eb --- /dev/null +++ b/nbproject/ant-deploy.xml @@ -0,0 +1,57 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/nbproject/build-impl.xml b/nbproject/build-impl.xml new file mode 100644 index 0000000..a697847 --- /dev/null +++ b/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/nbproject/genfiles.properties b/nbproject/genfiles.properties new file mode 100644 index 0000000..26302cb --- /dev/null +++ b/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/nbproject/project.properties b/nbproject/project.properties new file mode 100644 index 0000000..cd8b205 --- /dev/null +++ b/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/nbproject/project.xml b/nbproject/project.xml new file mode 100644 index 0000000..e3b6e85 --- /dev/null +++ b/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/src/conf/MANIFEST.MF b/src/conf/MANIFEST.MF new file mode 100644 index 0000000..58630c0 --- /dev/null +++ b/src/conf/MANIFEST.MF @@ -0,0 +1,2 @@ +Manifest-Version: 1.0 + diff --git a/src/java/bdd/ClientMysql.java b/src/java/bdd/ClientMysql.java new file mode 100644 index 0000000..3fe2e15 --- /dev/null +++ b/src/java/bdd/ClientMysql.java @@ -0,0 +1,155 @@ +/* + * ClientMysql.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 Dominique_2 + */ +public class ClientMysql { + + private Connection theConnection; + private Pompier unClient; + + /** + * Constructeur + */ + public ClientMysql() { + theConnection = Connexion.getConnect("localhost", //s erveur + "bdclient", // base de données + "adminBDClient",// user + "mdpBDClient"); // mot de passe ClientMysql() { + } + + /** + * Recherche de tous les clients + * @return collection de clients + */ + public ArrayList readAll() { + ArrayList lesClients = new ArrayList<>(); + + try { + Statement stmt = theConnection.createStatement(); + ResultSet resultQ = null; + resultQ = stmt.executeQuery("SELECT * FROM client"); + while (resultQ.next()) { + unClient = new Pompier(resultQ.getInt("id"), + resultQ.getString("civilite"), + resultQ.getString("nom"), + resultQ.getString("prenom"), + resultQ.getString("mdp"), + resultQ.getInt("adrno"), + resultQ.getString("adrrue"), + resultQ.getString("adrville"), + resultQ.getString("adrcp"), + resultQ.getString("adrmail"), + resultQ.getString("tel"), + resultQ.getString("dateNais")); + lesClients.add(unClient); + } + 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 lesClients; + } + + /** + * Creation du client passé en paramètre dans la table client + * Requête non préparée + * @param c objet de type Pompier (sans identifiant) + * @return int : id du client créé + */ + public int create(Pompier c) { + int id = -1; + try { + Statement stmt = theConnection.createStatement(); + int status = stmt.executeUpdate( + "INSERT INTO client (civilite, nom, prenom, mdp, adrno, adrrue, adrville, adrcp, adrmail, tel, dateNais) " + + "VALUES ('" + c.getCivilite() + "', '" + + c.getNom() + "', '" + + c.getPrenom() + "', '" + + c.getMdp() + "', " + + c.getAdrNo() + ", '" + + c.getAdrRue() + "', '" + + c.getAdrCP() + "', '" + + c.getAdrVille() + "', '" + + c.getAdrmail()+ "', '" + + c.getTel()+ "', '" + + c.getDateNais() + "');", + 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 id; + } + + /** + * 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 (civilite, nom, prenom, mdp, adrno, adrrue, adrville, adrcp, adrmail, tel, dateNais) " + + "VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?);"; + stmt = theConnection.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS); + stmt.setString(1, c.getCivilite()); + stmt.setString(2, c.getNom()); + stmt.setString(3, c.getPrenom()); + stmt.setString(4, c.getMdp()); + stmt.setInt(5, c.getAdrNo()); + stmt.setString(6, c.getAdrRue()); + stmt.setString(7, c.getAdrCP()); + stmt.setString(8, c.getAdrVille()); + stmt.setString(9, c.getAdrmail()); + stmt.setString(10, c.getTel()); + stmt.setString(11, c.getDateNais()); + 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/src/java/bdd/Connexion.java b/src/java/bdd/Connexion.java new file mode 100644 index 0000000..3c01e7c --- /dev/null +++ b/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/src/java/com/test/beans/Pompier.java b/src/java/com/test/beans/Pompier.java new file mode 100644 index 0000000..adf08a8 --- /dev/null +++ b/src/java/com/test/beans/Pompier.java @@ -0,0 +1,247 @@ +/* + * Bean Pompier + */ +package com.test.beans; + +import java.util.Objects; + +/** + * + * @author Dominique_2 + */ +public class Pompier { + private int id; + private String civilite; + private String nom; + private String prenom; + private String mdp; + private int adrNo; + private String adrRue; + private String adrVille; + private String adrCP; + private String adrmail; + private String tel; + private String dateNais; + + public Pompier() { + } + + /** + * Constructeur entier + * @param id + * @param civilite + * @param nom + * @param prenom + * @param mdp + * @param adrNo + * @param adrRue + * @param adrVille + * @param adrCP + * @param adrmail + * @param tel + * @param dateNais + */ + public Pompier(int id, String civilite, String nom, String prenom, String mdp, int adrNo, String adrRue, String adrVille, String adrCP, String adrmail, String tel, String dateNais) { + this(civilite, nom, prenom, mdp, adrNo, adrRue, adrVille, adrCP, adrmail, tel, dateNais); + this.id = id; + } + + /** + * Constructeur sans id + * @param civilite + * @param nom + * @param prenom + * @param mdp + * @param adrNo + * @param adrRue + * @param adrVille + * @param adrCP + * @param adrmail + * @param tel + * @param dateNais + */ + public Pompier(String civilite, String nom, String prenom, String mdp, int adrNo, String adrRue, String adrVille, String adrCP, String adrmail, String tel, String dateNais) { + this.civilite = civilite; + this.nom = nom; + this.prenom = prenom; + this.mdp = mdp; + this.adrNo = adrNo; + this.adrRue = adrRue; + this.adrVille = adrVille; + this.adrCP = adrCP; + this.adrmail = adrmail; + this.tel = tel; + this.dateNais = dateNais; + } + + public int getId() { + return id; + } + + public void setId(int id) { + this.id = id; + } + + public String getCivilite() { + return civilite; + } + + public void setCivilite(String civilite) { + this.civilite = civilite; + } + + 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 getMdp() { + return mdp; + } + + public void setMdp(String mdp) { + this.mdp = mdp; + } + + public int getAdrNo() { + return adrNo; + } + + public void setAdrNo(int adrNo) { + this.adrNo = adrNo; + } + + public String getAdrRue() { + return adrRue; + } + + public void setAdrRue(String adrRue) { + this.adrRue = adrRue; + } + + public String getAdrVille() { + return adrVille; + } + + public void setAdrVille(String adrVille) { + this.adrVille = adrVille; + } + + public String getAdrCP() { + return adrCP; + } + + public void setAdrCP(String adrCP) { + this.adrCP = adrCP; + } + + public String getAdrmail() { + return adrmail; + } + + public void setAdrmail(String adrmail) { + this.adrmail = adrmail; + } + + public String getTel() { + return tel; + } + + public void setTel(String tel) { + this.tel = tel; + } + + public String getDateNais() { + return dateNais; + } + + public void setDateNais(String dateNais) { + this.dateNais = dateNais; + } + + @Override + public int hashCode() { + int hash = 5; + hash = 17 * hash + this.id; + hash = 17 * hash + Objects.hashCode(this.civilite); + hash = 17 * hash + Objects.hashCode(this.nom); + hash = 17 * hash + Objects.hashCode(this.prenom); + hash = 17 * hash + Objects.hashCode(this.mdp); + hash = 17 * hash + this.adrNo; + hash = 17 * hash + Objects.hashCode(this.adrRue); + hash = 17 * hash + Objects.hashCode(this.adrVille); + hash = 17 * hash + Objects.hashCode(this.adrCP); + hash = 17 * hash + Objects.hashCode(this.adrmail); + hash = 17 * hash + Objects.hashCode(this.tel); + hash = 17 * hash + Objects.hashCode(this.dateNais); + 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.adrNo != other.adrNo) { + return false; + } + if (!Objects.equals(this.civilite, other.civilite)) { + return false; + } + if (!Objects.equals(this.nom, other.nom)) { + return false; + } + if (!Objects.equals(this.prenom, other.prenom)) { + return false; + } + if (!Objects.equals(this.mdp, other.mdp)) { + return false; + } + if (!Objects.equals(this.adrRue, other.adrRue)) { + return false; + } + if (!Objects.equals(this.adrVille, other.adrVille)) { + return false; + } + if (!Objects.equals(this.adrCP, other.adrCP)) { + return false; + } + if (!Objects.equals(this.adrmail, other.adrmail)) { + return false; + } + if (!Objects.equals(this.tel, other.tel)) { + return false; + } + if (!Objects.equals(this.dateNais, other.dateNais)) { + return false; + } + return true; + } + + @Override + public String toString() { + return "Client{" + "id=" + id + ", civilite=" + civilite + ", nom=" + nom + ", prenom=" + prenom + ", mdp=" + mdp + ", adrNo=" + adrNo + ", adrRue=" + adrRue + ", adrVille=" + adrVille + ", adrCP=" + adrCP + ", adrmail=" + adrmail + ", tel=" + tel + ", dateNais=" + dateNais + '}'; + } + +} diff --git a/src/java/com/test/beans/User.java b/src/java/com/test/beans/User.java new file mode 100644 index 0000000..d73e844 --- /dev/null +++ b/src/java/com/test/beans/User.java @@ -0,0 +1,70 @@ +/* + * 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.beans; + +import java.util.Objects; + +/** + * + * @author Dominique_2 + */ +public class User { + private String pseudo; + private String mdp; + + public User(String pseudo, String mdp) { + this.pseudo = pseudo; + this.mdp = mdp; + } + + public String getPseudo() { + return pseudo; + } + + public void setPseudo(String pseudo) { + this.pseudo = pseudo; + } + + public String getMdp() { + return mdp; + } + + public void setMdp(String mdp) { + this.mdp = mdp; + } + + @Override + public int hashCode() { + int hash = 7; + hash = 67 * hash + Objects.hashCode(this.pseudo); + hash = 67 * hash + Objects.hashCode(this.mdp); + 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 User other = (User) obj; + if (!Objects.equals(this.pseudo, other.pseudo)) { + return false; + } + if (!Objects.equals(this.mdp, other.mdp)) { + return false; + } + return true; + } + + + +} diff --git a/src/java/com/test/filter/AuthentifFiltrer.java b/src/java/com/test/filter/AuthentifFiltrer.java new file mode 100644 index 0000000..037437e --- /dev/null +++ b/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 nathan.balducci + */ +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/src/java/com/test/forms/AuthentifForm.java b/src/java/com/test/forms/AuthentifForm.java new file mode 100644 index 0000000..1628ddf --- /dev/null +++ b/src/java/com/test/forms/AuthentifForm.java @@ -0,0 +1,57 @@ +/* + * 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 Dominique_2 + */ +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'addministrateur Mise à jour de l'attribut + * resultat + * + * @param request + * @return true is ok, false sinon + */ + public boolean controlerAdmin(HttpServletRequest request) { + /* Comparaison entre l'utilisateur admin et un utilisateur créé + avec le pseudo et le mdp saisi */ + User admin = new User("Lovelace", "Ada"); + User userSaisi = new User( request.getParameter("ztPseudo"), + request.getParameter("ztMDP")); + boolean isAdmin = userSaisi.equals(admin); + + // Mise à jour de l'attribut resultat + setResultat(isAdmin ? "Vous êtes administrateur" : "Vous n'êtes pas administrateur"); + + return isAdmin; + } + +} diff --git a/src/java/com/test/forms/NouveauPompierForm.java b/src/java/com/test/forms/NouveauPompierForm.java new file mode 100644 index 0000000..a80c2c8 --- /dev/null +++ b/src/java/com/test/forms/NouveauPompierForm.java @@ -0,0 +1,70 @@ +/* + * NouveauPompierForm.java + */ +package com.test.forms; + +import bdd.ClientMysql; +import com.mysql.cj.util.StringUtils; +import com.test.beans.Pompier; +import jakarta.servlet.http.HttpServletRequest; +import java.util.Enumeration; + +/** + * + * @author domin + */ +public class NouveauPompierForm { + + String message=""; + + public int verifNouveauClient(HttpServletRequest request) { + + // Contrôle du no de rue qui doit être numérique + String noRueString = request.getParameter("ztNoRue"); + boolean isNumeric = StringUtils.isStrictlyNumeric(noRueString); + if (!isNumeric) { + message = "Le no de rue doit être numérique"; + return -1; + } + int noRue = Integer.parseInt(noRueString); + + // 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 unClient = new Pompier(request.getParameter("btrCivilite"), + request.getParameter("ztNom"), + request.getParameter("ztPrenom"), + request.getParameter("ztPwd"), + noRue, + request.getParameter("ztRue"), + request.getParameter("ztCP"), + request.getParameter("ztVille"), + request.getParameter("ztMail"), + request.getParameter("ztTel"), + request.getParameter("ztDateNais")); + ClientMysql cm = new ClientMysql(); + int idClient = cm.createRP(unClient); // Requête préparée + if (idClient == -1) { + message = "Erreur lors de la création du client"; + } + return idClient; + + } + + public String getMessage() { + return message; + } +} diff --git a/src/java/com/test/servlets/AccueilServlet.java b/src/java/com/test/servlets/AccueilServlet.java new file mode 100644 index 0000000..5ce53bc --- /dev/null +++ b/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 Dominique_2 + */ +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/src/java/com/test/servlets/ListeServlet.java b/src/java/com/test/servlets/ListeServlet.java new file mode 100644 index 0000000..d1844cb --- /dev/null +++ b/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.ClientMysql; +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 Dominique_2 + */ +@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 + ClientMysql clientMs = new ClientMysql(); + 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/src/java/com/test/servlets/NouveauServlet.java b/src/java/com/test/servlets/NouveauServlet.java new file mode 100644 index 0000000..1061fb1 --- /dev/null +++ b/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 Dominique_2 + */ +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 idClient = nvf.verifNouveauClient(request); + request.setAttribute("idClient", idClient); + request.setAttribute("message", nvf.getMessage()); + if(idClient != -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(idClient); + //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/web/META-INF/context.xml b/web/META-INF/context.xml new file mode 100644 index 0000000..fc7e5a6 --- /dev/null +++ b/web/META-INF/context.xml @@ -0,0 +1,2 @@ + + diff --git a/web/WEB-INF/accueilJSP.jsp b/web/WEB-INF/accueilJSP.jsp new file mode 100644 index 0000000..fd2939d --- /dev/null +++ b/web/WEB-INF/accueilJSP.jsp @@ -0,0 +1,79 @@ +<%@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 clients

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

+ +
+
+
+ + + +

${controlForm.getResultat()}

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

Tests divers

F +${ 10 / 4}
+

Test avec EL et JSTL

+

ztPseudo : ${param.ztPseudo}

+ +

isAdmin : ${isAdmin}

+

Message reçu : ${controlForm.getResultat()}

+ + + + Je ne sais pas encore si vous êtes administrateur + + + +

Voici le message : ${message}

+ +

Test sur controlForm : +${empty controlForm.getResultat() ? "" : controlForm.getResultat()} +

+ + + + + +

Langue : ${langue}

+ + + Test positif + +

Résultat du test : ${resultatTest}

+ + + Instructions à répéter (html, ou jstl)- ${i}
+
+ + Voici les controles :
+ + + ${unControle.toString()}
+
+ + + + + diff --git a/web/WEB-INF/jspf/enteteJSPF.jspf b/web/WEB-INF/jspf/enteteJSPF.jspf new file mode 100644 index 0000000..1fe65d1 --- /dev/null +++ b/web/WEB-INF/jspf/enteteJSPF.jspf @@ -0,0 +1,16 @@ +<%-- 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 : Dominique_2 +--%> + + + + + + Gestion des clients + + +

Gestion des clients

diff --git a/web/WEB-INF/jspf/menuJSPF.jspf b/web/WEB-INF/jspf/menuJSPF.jspf new file mode 100644 index 0000000..779842d --- /dev/null +++ b/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/web/WEB-INF/listeJSP.jsp b/web/WEB-INF/listeJSP.jsp new file mode 100644 index 0000000..e2a42f3 --- /dev/null +++ b/web/WEB-INF/listeJSP.jsp @@ -0,0 +1,48 @@ +<%@include file = "jspf/enteteJSPF.jspf" %> +<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> +<%@page import="java.util.ArrayList" %> +

Liste des clients

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
NoCivilitéNomPrénomMot de passeNoRueVilleCode postalMailTélDate naissance
+
+ <%@include file="jspf/menuJSPF.jspf" %> + + diff --git a/web/WEB-INF/nouveauJSP.jsp b/web/WEB-INF/nouveauJSP.jsp new file mode 100644 index 0000000..98e047a --- /dev/null +++ b/web/WEB-INF/nouveauJSP.jsp @@ -0,0 +1,58 @@ +<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> +<%@include file = "jspf/enteteJSPF.jspf" %> +

Création d'un nouveau client

+ +Page en construction +
+ Fiche client +
+ + + + + + + + + +
+ Adresse postale : + + + +
+ + + + + + +
+ +
+
+
+ +

+ + + Le client no ${idClient} 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/web/WEB-INF/web.xml b/web/WEB-INF/web.xml new file mode 100644 index 0000000..52aed8e --- /dev/null +++ b/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/web/images/pageEnConstruction.jpg b/web/images/pageEnConstruction.jpg new file mode 100644 index 0000000..60e3663 Binary files /dev/null and b/web/images/pageEnConstruction.jpg differ diff --git a/web/index.html b/web/index.html new file mode 100644 index 0000000..f2e80aa --- /dev/null +++ b/web/index.html @@ -0,0 +1,16 @@ + + + + + Gestion des clients + + + + +
TODO write content
+ + diff --git a/web/welcomeJSF.jsp b/web/welcomeJSF.jsp new file mode 100644 index 0000000..05eb615 --- /dev/null +++ b/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 + + +

+ + +