-
Notifications
You must be signed in to change notification settings - Fork 0
/
contact.php
75 lines (64 loc) · 1.75 KB
/
contact.php
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
<?php
//if $_POST is empty redirect
if (empty($_POST)) {
header("location: /Portfolio/");
exit();
}
include 'rooter.php';
//Le nom et prénom
$name = $_POST['name'];
// L'adresse mail
$email = $_POST['email'];
// the message
$msg = $_POST["message"];
// use wordwrap() if lines are longer than 70 characters
//$msg = wordwrap($msg,70);
//Validate first
if(empty($name)||empty($email))
{
$error = "Le nom et l'adresse mail sont obligatoires !";
$template = templateRequest('contact');
include $viewsPath.'templates/layout.phtml';
exit;
}
if(IsInjected($email))
{
$error = "L'adresse mail n'a pas été renseignée dans un format correct !";
$template = templateRequest('contact');
include $viewsPath.'templates/layout.phtml';
exit;
}
$email_from = '[email protected]';
$email_subject = "Prise de contact de la part de ".$name."" ;
$email_body = "Vous avez reçu un nouveau message de la part de $name.\n".
"Voici le message:\n $msg";
$to = "[email protected]";
$headers = "From: $email_from \r\n";
$headers .= "Reply-To: $email \r\n";
// send email
mail($to,$email_subject,$email_body,$headers);
//SYNTAX : mail(to,subject,message,headers,parameters);
// Function to validate against any email injection attempts
function IsInjected($str)
{
$injections = array('(\n+)',
'(\r+)',
'(\t+)',
'(%0A+)',
'(%0D+)',
'(%08+)',
'(%09+)'
);
$inject = join('|', $injections);
$inject = "/$inject/i";
if(preg_match($inject,$str))
{
return true;
}
else
{
return false;
}
}
$template = templateRequest('contact');
include $viewsPath.'templates/layout.phtml';