posting to php through ajax

Posted on 2009-04-03
Last Modified: 2013-12-12
I am stumpped on posting variables to a php file.
From my html I call 'calledFromHTMLform()'.  This file generates an ajax variable and posts to a file called 'myPHPfile.php'.
The php file sends an email. The email is successfully sent but I cannot read any of the posted variables.
In the following code, the $message variable contains nothing.
Any input as to what I am missing?


function calledFromHTMLform() { 

	var ajaxVar = getAjaxRequestVariable(); 

	ajaxVar.onreadystatechange = function() { 

		if(ajaxVar.readyState == 4) { 

			var myResponse = ajaxVar.responseText; 


	}"POST", "myPHPfile.php", true); 




function getAjaxRequestVariable() { 

	try { // Opera 8.0+, Firefox, Safari 

		ajaxRequest = new XMLHttpRequest(); 

	} catch (e) { // Internet Explorer Browsers 

		try { 

			ajaxRequest = new ActiveXObject("Msxml2.XMLHTTP"); 

		} catch (e) { 

			try { 

				ajaxRequest = new ActiveXObject("Microsoft.XMLHTTP"); 

			} catch (e) { // Something went wrong 

				alert("Your browser broke!"); 

				return false; 




	return ajaxRequest; 




	$email = '';

	$subject = 'This is the subject';

	$message = $_POST["name"]; 

	$from = "";

	$headers = "From: $from";

	if(mail($email,$subject,$message,$headers)) {

		echo "Thank you for sending email";

	} else {

		echo "Can't send email to $email";




Open in new window

Question by:pconder
  • 2

Expert Comment

ID: 24064479
Are you certain these variables are being populated correctly?


Dump them to the screen to ensure they have data.

Author Comment

ID: 24064602
I did that already. The string going to the post looks good (I think). The following is a sample string being sent to the post from the actual code - not the stripped and hard coded code that I posted with the question:

Accepted Solution

Pantalaim0n earned 500 total points
ID: 24066932
Try adding this before ajaxVar.send(...). Replace lengthOfTheQueryString with an appropriate value.

ajaxVar.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");

ajaxVar.setRequestHeader('Content-Length', lengthOfTheQueryString);

Open in new window


Author Closing Comment

ID: 31566444
Someone also recomended that I add:
ajaxVar.setRequestHeader("Connection", "close");
after the two lines you indicated.  Works great. Thanks.

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

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

Suggested Solutions

Introduction HyperText Transfer Protocol ( or "HTTP" is the underpinning of internet communication.  As a teacher of web development I have heard many questions, mostly from my younger students who have come to t…
These days socially coordinated efforts have turned into a critical requirement for enterprises.
The viewer will learn how to dynamically set the form action using jQuery.
The viewer will learn how to count occurrences of each item in an array.

939 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

Need Help in Real-Time?

Connect with top rated Experts

6 Experts available now in Live!

Get 1:1 Help Now