Có 2 cách để Client có thể gửi thông tin cho Web Server:
Trước khi trình duyệt gửi thông tin, nó mã hóa nó bởi sử dụng một giản đồ gọi là URL encoding. Trong giản đồ này, các cặp name/value được kết hợp với kí hiệu = và các cặp khác nhau được phân tách nhau bởi dấu &.
name1=value1&name2=value2&name3=value3
Các khoảng trống được xóa bỏ, thay thế bằng kí tự + và bất kì kí tự không phải dạng số và chữ được thay thế bằng giá trị hexa. Sau khi thông tin được mã hóa, nó sẽ được gửi lên Server.
Phương thức GET gửi thông tin người dùng đã được mã hóa được phụ thêm vào yêu cầu trang. Trang và thông tin mã hóa được phân tách nhau bởi kí tự hỏi chấm (?).
http://www.test.com/index.htm?name1=value1&name2=value2
Bạn thử ví dụ sau bằng việc đặt source code sau đây vào test.php script:
<?php
if( $_GET["name"] || $_GET["age"] )
{
echo "Chào mừng ". $_GET['name']. "<br />";
echo "Bạn ". $_GET['age']. " tuổi.";
exit();
}
?>
<html>
<body>
<form action="<?php <b>$_PHP_SELF</b> ?>" method="GET">
Họ tên: <input type="text" name="name" />
Tuổi: <input type="text" name="age" />
<input type="submit" />
</form>
</body>
</html>
PHP code trên sẽ cho kết quả:
Phương thức POST truyền thông tin thông qua HTTP header. Thông tin này được mã hóa như mô tả trong trường hợp của phương thức GET và đặt vào một header được gọi là QUERY_STRING.
Bạn thử ví dụ sau bằng việc đặt source code vào test.php script:
<?php
if( $_POST["name"] || $_POST["age"] )
{
if (preg_match("/[^A-Za-z'-]/",$_POST['name'] ))
{
die ("Biến name không hợp lệ - nên là các chữ cái");
}
echo "Chào mừng ". $_POST['name']. "<br />";
echo "Bạn ". $_POST['age']. " tuổi.";
exit();
}
?>
<html>
<body>
<form action="<?php <b>$_PHP_SELF</b> ?>" method="POST">
Họ tên: <input type="text" name="name" />
Tuổi: <input type="text" name="age" />
<input type="submit" />
</form>
</body>
</html>
PHP code trên sẽ cho kết quả:
Biến $_REQUEST trong PHP chứa nội dung của cả $_GET, $_POST, và $_COOKIE. Chúng ta sẽ bàn về biến $_COOKIE khi giải thích về Cookie trong PHP.
Biến $_REQUEST trong PHP có thể được sử dụng để lấy kết quả từ form data được gửi bởi cả 2 phương thức GET và POST.
Bạn thử ví dụ sau bằng việc đặt source code vào test.php script:
<?php
if( $_REQUEST["name"] || $_REQUEST["age"] )
{
echo "Chào mừng ". $_REQUEST['name']. "<br />";
echo "Bạn ". $_REQUEST['age']. " tuổi.";
exit();
}
?>
<html>
<body>
<form action="<?php <b>$_PHP_SELF</b> ?>" method="POST">
Họ tên: <input type="text" name="name" />
Tuổi: <input type="text" name="age" />
<input type="submit" />
</form>
</body>
</html>
Ở đây, biến $_PHP_SELF chứa tên của chính script đó, script mà nó đang được gọi.
PHP code trên sẽ cho kết quả: