I'm running a PHP script and continue to receive errors like:
Notice: Undefined variable: my_variable_name in C:\wamp\www\mypath\index.php on line 10
Notice: Undefined index: my_index C:\wamp\www\mypath\index.php on line 11
Line 10 and 11 looks like this:
echo "My variable value is: " . $my_variable_name;
echo "My index value is: " . $my_array["my_index"];
What is the meaning of these error messages?
Why do they appear all of a sudden? I used to use this script for years and I've never had any problem.
How do I fix them?
This is a General Reference question for people to link to as duplicate, instead of having to explain the issue over and over again. I feel this is necessary because most real-world answers on this issue are very specific.
Related Meta discussion:
Try these
Or, as a quick and dirty solution:
Note about sessions:
When using sessions,
session_start();
is required to be placed inside all files using sessions.http://php.net/manual/en/features.sessions.php
Another reason why an undefined index notice will be thrown, would be that a column was omitted from a database query.
I.e.:
Then trying to access more columns/rows inside a loop.
I.e.:
or in a
while
loop:Something else that needs to be noted is that on a *NIX OS and Mac OS X, things are case-sensitive.
Consult the followning Q&A's on Stack:
Are table names in MySQL case sensitive?
mysql case sensitive table names in queries
MySql - Case Sensitive issue of tables in different server
When dealing with files, a proper enctype and a POST method are required, which will trigger an undefined index notice if either are not included in the form.
The manual states the following basic syntax:
HTML
PHP
Reference:
I didn't want to disable notice because it's helpful, but wanted to avoid too much typing.
My solution was this function:
So if I want to reference to $name and echo if exists, I simply write:
For array elements:
In page if I want to refer to $_REQUEST['name']:
Using a ternary is simple, readable, and clean:
Pre PHP 7
Assign a variable to the value of another variable if it's set, else assign
null
(or whatever default value you need):PHP 7+
The same except using Null Coalescing Operator. There's no longer a need to call
isset()
as this is built in, and no need to provide the variable to return as it's assumed to return the value of the variable being checked:Both will stop the Notices from the OP question, and both are the exact equivalent of:
If you don't require setting a new variable then you can directly use the ternary's returned value, such as with
echo
, function arguments, etc:Echo:
Function:
The above will work just the same with arrays, including sessions etc, replacing the variable being checked with e.g.:
$_SESSION['checkMe']
or however many levels deep you need, e.g.:
$clients['personal']['address']['postcode']
Suppression:
It is possible to suppress the PHP Notices with
@
or reduce your error reporting level, but it does not fix the problem, it simply stops it being reported in the error log. This means that your code still tried to use a variable that was not set, which may or may not mean something doesn't work as intended - depending on how crucial the missing value is.You should really be checking for this issue and handling it appropriately, either serving a different message, or even just returning a null value for everything else to identify the precise state.
If you just care about the Notice not being in the error log, then as an option you could simply ignore the error log.
I asked a question about this and I was referred to this post with the message:
I am sharing my question and solution here:
This is the error:
Line 154 is the problem. This is what I have in line 154:
I think the problem is that I am writing if conditions for the variable
$city
, which is not the key but the value in$key => $city
. First, could you confirm if that is the cause of the warning? Second, if that is the problem, why is it that I cannot write a condition based on the value? Does it have to be with the key that I need to write the condition?UPDATE 1: The problem is that when executing
$citiesCounterArray[$key]
, sometimes the$key
corresponds to a key that does not exist in the$citiesCounterArray
array, but that is not always the case based on the data of my loop. What I need is to set a condition so that if$key
exists in the array, then run the code, otherwise, skip it.UPDATE 2: This is how I fixed it by using
array_key_exists()
: