Bonjour à tous,

J'ai un petit soucis avec la fonction in_array :

J'ai une appli WEB authentifiant l'utilisateur via son nom de session utilisé pour l'authentification NTLM.

J'utilise ce script trouvé sur le net pour récupérer celui-ci :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
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
<?php
 
session_start();
 
$headers = apache_request_headers();
 
if (!isset($headers['Authorization'])){
	header('HTTP/1.1 401 Unauthorized');
	header('WWW-Authenticate: NTLM');
	exit;
}
 
$auth = $headers['Authorization'];
 
if (substr($auth,0,5) == 'NTLM ') {
	$msg = base64_decode(substr($auth, 5));
	if (substr($msg, 0, 8 ) != "NTLMSSP\x00") {
		die('error header not recognised');
	}
	if ($msg[8] == "\x01") {
		$msg2 = "NTLMSSP\x00\x02"."\x00\x00\x00\x00". // target name len/alloc
		"\x00\x00\x00\x00". // target name offset
		"\x01\x02\x81\x01". // flags
		"\x00\x00\x00\x00\x00\x00\x00\x00". // challenge
		"\x00\x00\x00\x00\x00\x00\x00\x00". // context
		"\x00\x00\x00\x00\x30\x00\x00\x00"; // target info len/alloc/offset
		header('HTTP/1.1 401 Unauthorized');
		header('WWW-Authenticate: NTLM '.trim(base64_encode($msg2)));
		exit;
	} else if ($msg[8] == "\x03") {
		function get_msg_str($msg, $start, $unicode = true) {
			$len = (ord($msg[$start+1]) * 256) + ord($msg[$start]);
			$off = (ord($msg[$start+5]) * 256) + ord($msg[$start+4]);
			if ($unicode)
				return str_replace("",  », substr($msg, $off, $len));
			else
				return substr($msg, $off, $len);
			}
		$_SESSION['username'] = get_msg_str($msg, 36);
		$_SESSION['workstation'] = get_msg_str($msg, 44);
	}
}
?>
J'ai ensuite sur la page d'authentification un simple in_array() qui vérifie si la variable $_SESSION['username'] est présente dans un tableau prédéfini :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
<?php
session_start();
 
$personnes_autorisees = array(
"JDUPONT",
"NGONTRAND"
);
 
if (in_array($_SESSION['username'], $personnes_autorisees)) {
 
[...]
 
}?>
Le souci c'est que ça ne fonctionne pas, le in_array() n'a pas l'air de fonctionner...
Est-ce un problème de comparaison de différents types de variables ?

Merci de votre aide !