PHP ve AJAX
AJAX nedir?
AJAX, Asenkron JavaScript ve XML. AJAX, XML, HTML, CSS ve Java Script yardımıyla daha iyi, daha hızlı ve daha etkileşimli web uygulamaları oluşturmak için yeni bir tekniktir.
Geleneksel web uygulaması, eşzamanlı istekleri kullanarak sunucuya ve sunucudan bilgi iletir. Bu, bir form doldurmanız, gönder düğmesine basmanız ve sunucudan gelen yeni bilgilerle yeni bir sayfaya yönlendirilmeniz anlamına gelir.
AJAX ile gönder düğmesine basıldığında, JavaScript sunucuya bir istekte bulunacak, sonuçları yorumlayacak ve mevcut ekranı güncelleyecektir. En saf anlamda, kullanıcı sunucuya herhangi bir şeyin iletildiğini asla bilemezdi.
AJAX hakkında tam öğrenme için lütfen AJAX Eğitimine bakın .
PHP ve AJAX Örneği
Ajax ve PHP kullanarak bir veritabanındaki bilgilere erişmenin ne kadar kolay olduğunu açıkça göstermek için, anında MySQL sorguları oluşturacağız ve sonuçları "ajax.html" üzerinde göstereceğiz. Ama devam etmeden önce zemin çalışması yapalım. Aşağıdaki komutu kullanarak bir tablo oluşturun.
NOTE - Aşağıdaki MySQL işlemlerini gerçekleştirmek için yeterli ayrıcalığa sahip olduğunuzu varsayıyoruz.
CREATE TABLE `ajax_example` (
`name` varchar(50) NOT NULL,
`age` int(11) NOT NULL,
`sex` varchar(1) NOT NULL,
`wpm` int(11) NOT NULL,
PRIMARY KEY (`name`)
)
Şimdi aşağıdaki SQL ifadelerini kullanarak aşağıdaki verileri bu tabloya boşaltın.
INSERT INTO `ajax_example` VALUES ('Jerry', 120, 'm', 20);
INSERT INTO `ajax_example` VALUES ('Regis', 75, 'm', 44);
INSERT INTO `ajax_example` VALUES ('Frank', 45, 'm', 87);
INSERT INTO `ajax_example` VALUES ('Jill', 22, 'f', 72);
INSERT INTO `ajax_example` VALUES ('Tracy', 27, 'f', 0);
INSERT INTO `ajax_example` VALUES ('Julie', 35, 'f', 90);
İstemci Tarafı HTML dosyası
Şimdi istemci tarafı ajax.html olan HTML dosyamıza sahip olalım ve aşağıdaki kodu alalım
<html>
<body>
<script language = "javascript" type = "text/javascript">
<!--
//Browser Support Code
function ajaxFunction(){
var ajaxRequest; // The variable that makes Ajax possible!
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;
}
}
}
// Create a function that will receive data
// sent from the server and will update
// div section in the same page.
ajaxRequest.onreadystatechange = function(){
if(ajaxRequest.readyState == 4){
var ajaxDisplay = document.getElementById('ajaxDiv');
ajaxDisplay.innerHTML = ajaxRequest.responseText;
}
}
// Now get the value from user and pass it to
// server script.
var age = document.getElementById('age').value;
var wpm = document.getElementById('wpm').value;
var sex = document.getElementById('sex').value;
var queryString = "?age=" + age ;
queryString += "&wpm=" + wpm + "&sex=" + sex;
ajaxRequest.open("GET", "ajax-example.php" + queryString, true);
ajaxRequest.send(null);
}
//-->
</script>
<form name = 'myForm'>
Max Age: <input type = 'text' id = 'age' /> <br />
Max WPM: <input type = 'text' id = 'wpm' />
<br />
Sex: <select id = 'sex'>
<option value = "m">m</option>
<option value = "f">f</option>
</select>
<input type = 'button' onclick = 'ajaxFunction()' value = 'Query MySQL'/>
</form>
<div id = 'ajaxDiv'>Your result will display here</div>
</body>
</html>
NOTE - Sorgudaki değişkenleri aktarmanın yolu HTTP standardına ve have formA'ya göredir.
URL?variable1=value1;&variable2=value2;
Şimdi yukarıdaki kod size aşağıda verildiği gibi bir ekran verecektir.
NOTE - Bu sahte ekrandır ve çalışmaz.
Sunucu Tarafı PHP dosyası
Öyleyse artık istemci tarafı komut dosyanız hazır. Şimdi, veritabanından yaş, wpm ve cinsiyeti alacak ve müşteriye geri gönderecek olan sunucu tarafı komut dosyamızı yazmamız gerekiyor. Aşağıdaki kodu "ajax-example.php" dosyasına koyun.
<?php
$dbhost = "localhost"; $dbuser = "dbusername";
$dbpass = "dbpassword"; $dbname = "dbname";
//Connect to MySQL Server
mysql_connect($dbhost, $dbuser, $dbpass); //Select Database mysql_select_db($dbname) or die(mysql_error());
// Retrieve data from Query String
$age = $_GET['age'];
$sex = $_GET['sex'];
$wpm = $_GET['wpm'];
// Escape User Input to help prevent SQL Injection
$age = mysql_real_escape_string($age);
$sex = mysql_real_escape_string($sex);
$wpm = mysql_real_escape_string($wpm);
//build query
$query = "SELECT * FROM ajax_example WHERE sex = '$sex'";
if(is_numeric($age)) $query .= " AND age <= $age"; if(is_numeric($wpm))
$query .= " AND wpm <= $wpm";
//Execute query
$qry_result = mysql_query($query) or die(mysql_error());
//Build Result String
$display_string = "<table>"; $display_string .= "<tr>";
$display_string .= "<th>Name</th>"; $display_string .= "<th>Age</th>";
$display_string .= "<th>Sex</th>"; $display_string .= "<th>WPM</th>";
$display_string .= "</tr>"; // Insert a new row in the table for each person returned while($row = mysql_fetch_array($qry_result)) { $display_string .= "<tr>";
$display_string .= "<td>$row[name]</td>";
$display_string .= "<td>$row[age]</td>";
$display_string .= "<td>$row[sex]</td>";
$display_string .= "<td>$row[wpm]</td>";
$display_string .= "</tr>"; } echo "Query: " . $query . "<br />";
$display_string .= "</table>"; echo $display_string;
?>
Şimdi "Maksimum Yaş" veya başka bir kutuya geçerli bir değer girmeyi deneyin ve ardından MySQL Sorgula düğmesini tıklayın.
Bu dersi başarıyla tamamladıysanız, Ajax uygulamaları yazmak için MySQL, PHP, HTML ve Javascript'i birlikte nasıl kullanacağınızı biliyorsunuzdur.