Skip to main content

AJAX XML example to show selected user details

This example will use the Ajax XML way of sending response.
For this tutorial, first create a table, "xml_users" with the following fields:

id int(1) NOT NULL PRIMARY KEY AUTO_INCREMENT
FirstName varchar(12)
LastName varchar(12)
Age int(2)
HomeTown varchar(15)
Job varchar(12)

Insert few records in the table.

Now write the index.php file, that shows the drop down list of users' names from the table. The onchange event of this select box will fire the javascript function that sends the data to a php file using ajax.

Ex: onchange="showUser(this.value)"

The javascript:

function showUser(str)
{
xmlHttp=GetXmlHttpObject()

var url="responsexml.php"
url=url+"?q="+str // q is the id passed
url=url+"&sid="+Math.random()
xmlHttp.onreadystatechange=stateChanged
xmlHttp.open("GET",url,true)
xmlHttp.send(null)
}

/* Now write the span tags for showing the response */

<span id="job"></span><br />
<span id="age_text"></span>
<span id="age"></span><br />
<span id="hometown_text"></span>
<span id="hometown"></span><br />

Finally, write the php file: responsexml.php, that is called by the ajax code of js.

<?php
// Establish database connection

$q=$_GET["q"];
$sql="SELECT * FROM xml_users WHERE id = ".$q."";

$result = mysql_query($sql);

echo '<?xml version="1.0" encoding="ISO-8859-1"?>
<person>';
while($row = mysql_fetch_array($result))
{
echo "<age>" . $row['Age'] . "</age>";
echo "<hometown>" . $row['HomeTown'] . "</hometown>";
echo "<job>" . $row['Job'] . "</job>";
}
echo "</person>";
?>

On success, the response is shown in our page, like for example, the job value:

document.getElementById("job").innerHTML=
xmlDoc.getElementsByTagName("job")[0].childNodes[0].nodeValue;

Note: change the database connection values, as needed.

Now test the application. When you select a user from the drop down list, it will show the corresponding user's details below.

You can download the entire source code here

Comments

Popular posts from this blog

Retaining checkbox status of a form after submitting it

we will learn here how to post back or retain the value ( status ) of the checkbox. We will use php header redirection to post back the values to our main page where checkbox is present. We will call form page as first page and action or submitted page as second page. The form data will be received by second page and it is supposed to post back the form data back to form page by using query string through address bar. To keep the second page simple we will keep only the redirection part. Here we have excluded the part which takes care if the form passes its validation and execute the actual script (redirection part). Here is the code of our form with two checkboxes, pb-check.php <?php $t1=$_GET['t1']; $t2=$_GET['t2']; if($t1=="yes"){$t1v="checked";} else{$t1v=="";} if($t2=="yes"){$t2v="checked";} else{$t2v=="";} ?> HTML Form code: <form method="post" action="pb-chk.php"> <inp...

Identify the user's browser

Sometimes there arises a need to identify the user's browser. It is pretty easy to find browser with jquery. So if you have included jquery in your page, it takes a simple line to identify the browser:  if ($. browser . msie ) {} // IE if (($.browser.msie) && ($.browser.version == '6.0')) {} // IE6 if ($. browser . opera ) {} // opera if ($. browser . mozilla) {} // Firefox With the help of php, you can get the browser  details with the help of:  $_SERVER['HTTP_USER_AGENT']; Or you can even use the combined version of php and javascript. php + javascript code: <script type="text/javascript"> var string1 = "<?php echo $_SERVER['HTTP_USER_AGENT']; ?>"; // Browser string var myRegExp1 = /Firefox/; var matchPos1 = string1.search(myRegExp1); var myRegExp2 = /Chrome/; var matchPos2 = string1.search(myRegExp2); var myRegExp3 = /MSIE/; var matchPos3 = string1.search(myRegExp3); if(matchPos1 != -1) ...

Facebook connect using graph api

An example of using facebook graph api to authenticate users: Setup a new application in facebook apps and get the app id and secret. Now follow the steps: Remember to give the same url in the below code, as that of the app settings. <?php if( !isset($_GET['code'])) { ?> <a href="https://graph.facebook.com/oauth/authorize?client_id=xxxxxxxx&redirect_uri=http://xxxxxxxxxxxxxxxx/">Connect using Facebook</a> <?php } $code = trim($_GET['code']); if(isset($_GET['code'])) $token = file_get_contents("https://graph.facebook.com/oauth/access_token?client_id=xxxxxxxx&redirect_uri=http://xxxxxxxxxxxxxxx&client_secret=xxxxxxxxxxxx&code=$code"); $token = explode("=", $token); if(isset($_GET['code'])) $user = json_decode(file_get_contents('https://graph.facebook.com/me?access_token='.$token[1]));  print_r($user); ?>