Skip to content
Snippets Groups Projects
Commit 66f1fffd authored by RASOLOSON MANDA's avatar RASOLOSON MANDA
Browse files

TPNoté Web

parent d0c3bee9
No related merge requests found
......@@ -61,7 +61,14 @@ Vous devrez créer une requête AJAX dans le fichier : `ajax.js`. **(3 points)**
**Questions Javascript** :
- Qu'est-ce que AJAX ? Quel est son intérêt ? **(1 point)**
**->AJAX est une méthode utilisé dans le développement web.Elle permet de modifier et ajouter quelque chose sur une page web sans avoira rafraichir la page toute entiere.**
- Donnez deux cas d'usage où AJAX est particulièrement utile. **(2 points)**
**->1-Un site web qui propose une application de discussion par message utilise par exemple AJAX pour ne pas rafraichir a chaque fois la page de discussion et recevoir les messages en temps rééls.**
**->2-Un site web qui propose la geolocalisation utillise AJAX pour obtenir les informations en temps réél.**
### HTML (8 points)
......@@ -72,9 +79,22 @@ section `<section id="signup">`. **(3 points)**
- Expliquez les points de vigilance quand on crée un formulaire en HTML par rapport à l'accessibilité ou aux bonnes
pratiques par exemple. **(2 points)**
**->1-On doit bien choisir les labels chaque champs pour que l'utilisateur sache ce qu'il doit saisir (pareil pour les placeholder)**
**->2-Pour les champs de saisie, on doit bien specifier les types de champs ou types de données.Par exemple, si on veut saisir un email, on doit bien le mettre en type email, et si on veut saisir un mot de passe, on doit bien le mettre en type mot de passe.**
**->3-Pour les champs obligatoire, on doit bien specifier l'attribut required dans la balise <input>**
**->4-Il faut toujours valider les données entrées par l'utilisateur coté serveur**
- Expliquez les deux attributs dans la balise `<form>` qui vous sont nécessaires ici pour créer votre formulaire. **(1
point)**
**les attributs:**
**action: permet de specifier le lien vers lequel envoyer les données de notre formulaire**
**method: permet de specifier le methode utiliser pour envoyer les données(ici POST)**
- Expliquez la ou les différences entre les méthodes GET et POST. Quand utiliser l'une ou l'autre ? **(2 points)**
**La methode GET est utilisé pour recuperer les données pou les informations depuis un URL.Tandis que la methode POST permet de transmettre les données au serveur**
**Quand on utilise la methode GET, on peut remarquer que le lien est visible dans le lien de l'onglet.Tandis que quand on utilise la methode POST, les données sont envoyés dans le corps du message et le lien n'est pas visible dans le lien de l'onglet.**
**POST est alors plus sécurisé que GET et elle est utiliser pour envoyer des données sensibles et confidentiels.La capacité de GET est limitée tandis que celle de POST est illimitée**
### PHP (8 points)
......@@ -85,8 +105,13 @@ données. **(5 points)**
- Expliquez les points d'attention à avoir quand on traite des données provenant d'un formulaire et qu'on insère
celles-ci dans une base de données. **(3 points)**
### CSS (3 points)
**Bien veifier les données entrées par l'utilisateur si elles sont bien valides et correspondent à nos critères avant de les insérer dans la base de données.Par exemple, si l'utilisateur doit saisir son age, l'age ne doit pas etre plus de 120 ans ni plus petit que 0**
**->Pour les mots de passe, on doit bien verifier que l'utilisateur s'en souvient bien avant de l'inserer dans la base de données.On peut par exemple demander à l'utilisateur de saisir deux fois son mot de passe et verifier si les deux mots de passe saisies sont identiques.Si oui, on peut l'inserer dans la bdd sinon, on lui demande de réécrire sont mot de passe.On peut également crypter le mot de passe avant de l'inserer pour plus de sécurité**
**on doit aussi utiliser des requêtes préparées avec des paramètres nommés pour éviter toutes forme de piratage ou cyberattaque**
**On doit limiter l'acces a la base de données**
Vous devrez réaliser un style CSS pour la liste des projets pour qu'elle ressemble à **(3 points)** :
![index](./public/index.png)
const initProjects = async () => {
/**
* AJAX
......
......@@ -14,6 +14,17 @@ $db->query('CREATE TABLE IF NOT EXISTS users (
* PHP :
*
* Récupérer les données du formulaire.
*
* Faire l'insertion en base de données des données en respectant toutes les bonnes pratiques vues en cours.
* Rediriger l'utilisateur vers la page d'accueil.
*/
$email = $_POST['email'];
$password = $_POST['mot_de_passe'];
$stmt = $db->prepare('INSERT INTO users (email, password) VALUES (:email, :password)');
$stmt->bindParam(':email', $email);
$stmt->bindParam(':password', $password);
$stmt->execute();
header('Location: index.html');
exit();
......@@ -11,6 +11,49 @@
<body>
<section id="projects">
<h1>Mes projets</h1>
<ul class="premier">
<li>
<h2>title 1</h2>
<p>21/04/2024</p>
<p>content</p>
</li>
</ul>
<ul class="deuxieme">
<li>
<h2>title 2</h2>
<p>21/04/2024</p>
<p>content</p>
</li>
</ul>
<ul class="troisieme">
<li>
<h2>title 3</h2>
<p>21/04/2024</p>
<p>content</p>
</li>
</ul>
<ul class="quatrieme">
<li>
<h2>title 3</h2>
<p>21/04/2024</p>
<p>content</p>
</li>
</ul>
<ul class="cinquieme">
<li>
<h2>title 3</h2>
<p>21/04/2024</p>
<p>content</p>
</li>
</ul>
<ul class="sixieme">
<li>
<h2>title 3</h2>
<p>21/04/2024</p>
<p>content</p>
</li>
</ul>
</section>
<section id="signup">
......@@ -23,6 +66,13 @@
Le formulaire doit être envoyé en POST vers la page form.php
-->
<form action="form.php" method="post">
<label for="email">Email</label>
<input type="email" name="email" id="email" placeholder="Veuillez entrer votre adresse email" required>
<label for="mot_de_passe">Mot de passe</label>
<input type="password" name="mot_de_passe" id="mot_de_passe" placeholder="Veuillez entrer votre mot de passe" required>
<input type="submit" value="S'inscrire">
</form>
</section>
</body>
</html>
\ No newline at end of file
......@@ -24,11 +24,46 @@ body {
border-radius: 0.5rem;
}
/*
CSS :
Sans utiliser de div, de class ou d'ID supplémentaires, ajoutez les sélecteurs et les options CSS nécessaires pour faire en sorte que la liste des projets ressemble à l'image dans le README.md.
*/
#projects {
display: grid;
grid-template-columns: repeat(3, 1fr);
grid-template-rows: repeat(2, auto);
gap: 1rem;
}
#projects ul {
list-style: none;
padding: 0;
background-color: grey;
}
#projects ul.premier {
grid-column: 1 / 2;
grid-row: 1 / 2;
}
#projects ul.deuxieme {
grid-column: 2 / 3;
grid-row: 1 / 2;
}
#projects ul.troisieme {
grid-column: 3 / 4;
grid-row: 1 / 2;
}
#projects ul.quatrieme {
grid-column: 1 / 2;
grid-row: 2 / 3;
}
#projects ul.cinquieme {
grid-column: 2 / 3;
grid-row: 2 / 3;
}
#projects ul.sixieme {
grid-column: 3 / 4;
grid-row: 2 / 3;
}
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment