-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsubmit_contact.php
More file actions
80 lines (70 loc) · 2.68 KB
/
submit_contact.php
File metadata and controls
80 lines (70 loc) · 2.68 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
<?php
/**
* On ne traite pas les super globales provenant de l'utilisateur directement,
* ces données doivent être testées et vérifiées.
*/
$postData = $_POST;
if (
!isset($postData['email'])
|| !filter_var($postData['email'], FILTER_VALIDATE_EMAIL)
|| empty($postData['message'])
|| trim($postData['message']) === ''
) {
echo('Il faut un email et un message valides pour soumettre le formulaire.');
return;
}
$isFileLoaded = false;
// Testons si le fichier a bien été envoyé et s'il n'y a pas des erreurs
if (isset($_FILES['screenshot']) && $_FILES['screenshot']['error'] === 0) {
// Testons, si le fichier est trop volumineux
if ($_FILES['screenshot']['size'] > 1000000) {
echo "L'envoi n'a pas pu être effectué, erreur ou image trop volumineuse";
return;
}
// Testons, si l'extension n'est pas autorisée
$fileInfo = pathinfo($_FILES['screenshot']['name']);
$extension = $fileInfo['extension'];
$allowedExtensions = ['jpg', 'jpeg', 'gif', 'png'];
if (!in_array($extension, $allowedExtensions)) {
echo "L'envoi n'a pas pu être effectué, l'extension {$extension} n'est pas autorisée";
return;
}
// Testons, si le dossier uploads est manquant
$path = __DIR__ . '/uploads/';
if (!is_dir($path)) {
echo "L'envoi n'a pas pu être effectué, le dossier uploads est manquant";
return;
}
// On peut valider le fichier et le stocker définitivement
move_uploaded_file($_FILES['screenshot']['tmp_name'], $path . basename($_FILES['screenshot']['name']));
$isFileLoaded = true;
}
?>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Site de Recettes - Contact reçu</title>
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css" rel="stylesheet">
</head>
<body>
<div class="container">
<?php require_once(__DIR__ . '/header.php'); ?>
<h1>Message bien reçu !</h1>
<div class="card">
<div class="card-body">
<h5 class="card-title">Rappel de vos informations</h5>
<p class="card-text"><b>Email</b> : <?php echo($postData['email']); ?></p>
<p class="card-text"><b>Message</b> : <?php echo(strip_tags($postData['message'])); ?></p>
<?php if ($isFileLoaded) : ?>
<div class="alert alert-success" role="alert">
L'envoi a bien été effectué !
</div>
<?php endif; ?>
</div>
</div>
</div>
</body>
</html>