PHP error undefined index

Posted on 2008-06-09
Medium Priority
Last Modified: 2013-12-13
Can somebody take a look at my code and see what I'm doing wrong?
I'm trying to create a login page and when I call the funtion "checkLogin()" it bombs on me.
It's supposed to check what level of access the user has.
Below are the roles.
1=> SYS ADMIN(everything plus DELETE), \
3=>ANALYST(view only)

I have an edit page that calls the function like this:
checkLogin('1 2 3')

//----- functions.php -----
	//1=> SYS ADMIN(everything plus DELETE), 2=>ADMIN(edit,view,update) 3=>ANALYST(view only)
	function checkLogin($role)
	echo $role;
			$access = FALSE;
		else {
			$kt = split(' ', $role);
			$query = mysql_query('SELECT level_access FROM tblUsers WHERE ID = "'. mysql_real_escape_string($_SESSION['user_id']).'"');
			$row = mysql_fetch_assoc($query);
			$access = FALSE;			
 while(list($key,$val)=each($kt))  <-- ERROR LINE
				{//if the user level matches one of the allowed levels
					$access = TRUE;
			header("Location: login.php");
		else {
		//do nothing: continue

Open in new window

Question by:Isaac
LVL 17

Expert Comment

ID: 21747815
In line 10, you echo $role and then in line 11 you have
so none of the code below that will be executed.

Author Comment

ID: 21747945
Please ignore lines 10 and 11.  That was just for debugging purposes.

Here's the error I get

Notice: Undefined index: LEVEL_access in /home/serveinc/serveinc.org/docs/admin/functions.php on line 52

Notice: Undefined index: LEVEL_access in /home/serveinc/serveinc.org/docs/admin/functions.php on line 52

Notice: Undefined index: LEVEL_access in /home/serveinc/serveinc.org/docs/admin/functions.php on line 52

Warning: Cannot modify header information - headers already sent by (output started at /home/serveinc/serveinc.org/docs/admin/functions.php:52) in /home/serveinc/serveinc.org/docs/admin/functions.php on line 60

Line 52 refers to the While Loop and Line 60 is 'header("Location: login.php");'
LVL 22

Expert Comment

ID: 21747983
Add these lines at the top of the page..


Make sure these are the first lines on the page..

LVL 16

Accepted Solution

DrNikon224 earned 2000 total points
ID: 21748138
You're seeing the Notice probably because you have error_reporting(E_ALL); (or an equivalent thereof) in your code somewhere. It's not an error really, just a notification that you're making reference to an array index which you've not defined. Specifically, the index "LEVEL_access" - which is not the same as "level_access" which is what you've used in your SELECT query. Case sensitive. If the table field is "level_access" then you'll need to use $row['level_access'].

The "Notice" messages can be disabled (though resolving the issue triggering the Notice is better) - they are not fatal errors.

Featured Post

Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

There are times when I have encountered the need to decompress a response from a PHP request. This is how it's done, but you must have control of the request and you can set the Accept-Encoding header.
It’s a season to be thankful, and we’re thankful for users like you who engage on site, solve technology problems, and network with others in the industry. What tech are we most thankful for? Keep reading.
Learn how to match and substitute tagged data using PHP regular expressions. Demonstrated on Windows 7, but also applies to other operating systems. Demonstrated technique applies to PHP (all versions) and Firefox, but very similar techniques will w…
The viewer will learn how to count occurrences of each item in an array.
Suggested Courses
Course of the Month14 days, 17 hours left to enroll

840 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question