beginning php5 apache

  - 1 - 

BEGINNING PHP5.APACHE.MYSQL WEB 

DEVELOPMENT 

  - 2 - 

MỤC LỤC 

Chƣơng  1:  SƠ LƢỢC VỀ APACHE, PHP, MYSQL VÀ CÁCH CÀI ĐẶT ......... 5 

1.1.  Tóm tắt sơ lƣợc về Apache, PHP, MySQL: ................................................ 5 

1.1.1.  Apache : .............................................................................................. 6 

1.1.2.  PHP: ................................................................................................... 6 

1.1.3.  MySQL : ............................................................................................. 6 

1.2.  Cài đặt: ...................................................................................................... 6 

Chƣơng  2:  TẠO NHỮNG TRANG PHP SỬ DỤNG PHP5 ................................ 10 

2.1.  Sử dụng “echo” để trình bài text ............................................................... 10 

2.2.  Định dạng text bằng HTML và PHP......................................................... 11 

2.3.  Sử dụng hằng và biến ............................................................................... 13 

2.3.1.  Tổng quan về hằng: ........................................................................... 13 

2.3.2.  Tổng quan về biến. ............................................................................ 13 

2.4.  Truyền biến giữa các trang ....................................................................... 15 

2.4.1.  Truyền biến qua URL ....................................................................... 16 

2.4.1.1.  Phƣơng thức đầu tiên để truyền biến giữa các trang là thông qua một 

URL.  16 

2.4.1.2.  Ký tự đặc biệt của URL. ................................................................ 20 

2.5.  Session và Cooking .................................................................................. 20 

2.5.1.  Session .............................................................................................. 20 

2.5.2.  Cookies. ............................................................................................ 22 

2.6.  HTML FORMS........................................................................................ 23 

2.6.1.  Lƣu chuyển thông tin với form. ......................................................... 23 

2.7.  CÂU LỆNH IF/ELSE .............................................................................. 26 

2.7.1.  Mệnh đề if......................................................................................... 26 

2.7.2.  Sử dụng if và else lồng nhau. ............................................................ 28 

2.8.  Sử dụng include cho đoạn mã có hiệu quả hơn ......................................... 29 

2.9.  Sử dụng Hàm cho đoạn mã có hiệu quả hơn ............................................. 30 

2.10.  Mảng .................................................................................................... 33 

2.10.1.  Cú pháp của mảng. ............................................................................ 33 

2.10.1.1.  Mảng một chiều ........................................................................... 33 

2.10.1.2.  Mảng đa chiều: ............................................................................ 34 

2.10.1.3.  Sắp xếp mảng .............................................................................. 35 

2.10.2.  Cấu trúc Foreach ............................................................................... 36 

2.11.  While và do.. while ............................................................................... 43 

2.12.  Những  cú pháp xen lẫn trong php. ....................................................... 48 

2.12.1.  Xen lẫn giữa <?php và ?> ................................................................. 48 

2.12.2.  Xen lẫn trong mệnh đề echo .............................................................. 48 

2.12.3.  Xen lẫn giữa các phép toán logic. ...................................................... 48 

2.12.4.  Xen lẫn trong việc sử dụng dấu (“”). ................................................. 48 

2.12.5.  Xen lẫn những giá trị tăng, giảm ....................................................... 48 

2.13.  Tổng quan về OOP ............................................................................... 49 

2.13.1.  Tóm tắt những ví dụ về OOP ............................................................ 49 

2.13.2.  Vì sao sử dụng OOP ......................................................................... 52 

Chƣơng  3:  SỬ DỤNG PHP VỚI MYSQL .......................................................... 53 

  - 3 - 

3.1.  Tổng quan về cấu trúc và cú pháp của MySQL. ....................................... 53 

3.1.1.  Cấu trúc MySQL ............................................................................... 53 

3.1.2.  Các kiểu  dữ liệu ............................................................................... 54 

3.1.3.  Lựa chọn kiểu cho đúng .................................................................... 55 

3.1.4.  NULL/NOT NULL ........................................................................... 56 

3.1.5.  INDEXES ......................................................................................... 56 

3.1.6.  UNIQUE ........................................................................................... 57 

3.1.7.  Tăng tự động(auto Increment) ........................................................... 57 

3.1.8.  Những tham số khác ......................................................................... 57 

3.1.9.  Các kiểu bảng của My SQl và kỹ thuật lƣu trữ .................................. 57 

3.1.10.  Lệnh và cú pháp trong My SQL ........................................................ 57 

3.2.  Bắt đầu với My SQL và PHP nhƣ thế nào? .............................................. 58 

3.3.  Kết nối MY SQL Server ........................................................................... 58 

3.4.  Đọc, tạo cơ sở dữ liệu .............................................................................. 59 

3.5.  Truy vấn cơ sở dữ liệu.............................................................................. 62 

3.5.1.  WHERE , oh WHERE ...................................................................... 63 

3.5.2.  Làm việc với PHP và mảng dữ liệu: foreach ..................................... 65 

3.5.3.  Liên hệ giữa 2 bảng ........................................................................... 69 

3.5.4.  Kết nối hai bảng (Join two tables) ..................................................... 70 

3.6.  Help Tips và Suggestions ......................................................................... 72 

3.6.1.  Việc cung cấp tài liệu ........................................................................ 72 

3.6.2.  Việc sử dụng PHPMyAdmin ............................................................. 72 

Chƣơng  4:  SỬ DỤNG BẢNG ĐỂ TRÌNH BÀY DỮ LIỆU ................................ 74 

4.1.  Tạo bảng .................................................................................................. 74 

4.2.  Bảng thƣờng dùng .................................................................................... 75 

4.3.  Master là ai? ............................................................................................. 83 

4.4.  Quan hệ lâu dài ........................................................................................ 92 

Chƣơng  5:  NHỮNG THÀNH PHẦN CỦA FORM: CHO PHÉP NGƢỜI DÙNG 

LÀM VIỆC VỚI DỮ LIỆU .................................................................................. 100 

5.1.  Form đầu tiên ......................................................................................... 100 

5.1.1.  Thành phần form ............................................................................. 102 

5.1.2.  Phần tử nhập (INPUT) .................................................................... 103 

5.1.3.  Xử lý Form ..................................................................................... 104 

5.2.  Driving the User Input ........................................................................... 105 

5.2.1.  Kiểu nhập hộp checkbox ................................................................. 108 

5.2.2.  Một form đa tiến trình ..................................................................... 109 

5.2.3.  Những phần tử nhập nút Radio........................................................ 114 

5.2.4.  Những nút submit phức tạp ............................................................. 114 

5.2.5.  Việc kiểm tra nhập cơ bản ............................................................... 114 

5.2.6.  Tiêu đề trang động .......................................................................... 115 

5.2.7.  Điều khiển một chuỗi bằng tay nhƣ một mảng để đổi ký tự đầu tiên 116 

5.2.8.  Toán tử tam nguyên ........................................................................ 116 

5.3.  Kết hợp những phần tử của form ............................................................ 116 

5.3.1.  Tập lệnh khung ............................................................................... 127 

5.3.2.  Câu trả lời mặc định ........................................................................ 128 

5.3.3.  Thêm mục con ................................................................................ 128 

  - 4 - 

Chƣơng  6:  CHO PHÉP NGƢỜI SỬ DỤNG SOẠN THẢO CƠ SỞ DỮ LIỆU . 131 

6.1.  Chuẩn bị Battlefield ............................................................................... 131 

6.2.  Chèn một mẫu tin đơn giản từ phpMyAdmin ......................................... 134 

6.3.  Chèn một mẩu tin trong cơ sở dữ liệu quan hệ........................................ 137 

6.4.  Xóa một mẩu tin .................................................................................... 145 

6.5.  Sửa dữ liệu trong mẩu tin ....................................................................... 151 

Chƣơng  7:  THAO TÁC VÀ TẠO HÌNH ẢNH VỚI PHP ................................. 163 

7.1.  Làm việc với thƣ viện GD ...................................................................... 163 

7.1.1.  Tôi có thể sử dụng loại files gì với GD và PHP? ............................. 163 

7.1.2.  Biên dịch PHP với GD .................................................................... 164 

7.2.  Cho phép ngƣời dùng đƣa hình ảnh lên .................................................. 165 

7.3.  Chuyển đổi loại file hình ảnh ................................................................. 173 

7.4.  Màu trắng và đen ................................................................................... 180 

7.5.  Thêm những dấu đề ................................................................................ 188 

7.6.  Thêm hình mờ và kết hợp hình ảnh ........................................................ 191 

7.7.  Tạo Thumbnails ..................................................................................... 193 

Chƣơng  8:  NGƢỜI DÙNG NHẬP CÓ HIỆU LỰC .......................................... 200 

8.1.  Những ngƣời dùng chỉ là những ngƣời dùng … ..................................... 200 

8.2.  Kết hợp có hiệu lực vào Movie Site ....................................................... 200 

8.3.  Quên điều gì? ......................................................................................... 201 

8.4.  Việc kiểm tra những kiểu lỗi .................................................................. 214 

8.5.  Tóm tại .................................................................................................. 232 

Chƣơng  9:  ĐIỀU KHIỂN VÀ TRÁNH NHỮNG LỖI ...................................... 233 

9.1.  Tiếp xúc với lỗi Apache Web Server nhƣ thế nào? ................................. 233 

9.1.1.  Chỉ thị lỗi của Apache ..................................................................... 233 

9.1.2.  Lỗi tài liệu của Apache: Trang báo lỗi thông thƣờng ....................... 238 

9.2.  Thi hành lỗi và tạo ra việc sửa trang lỗi với PHP .................................... 243 

9.2.1.  Các loại lỗi trong PHP .................................................................... 243 

9.2.2.  Việc phát sinh lỗi PHP .................................................................... 244 

9.3.  Một phƣơng pháp khác của việc thi hành lỗi .......................................... 253 

9.3.1.  Những ngoại lệ ............................................................................... 254 

9.3.2.  Không gặp những điều kiện ............................................................ 256 

9.3.3.  Phân tích lỗi .................................................................................... 256 

9.4.  Tóm lại................................................................................................... 256 

  - 5 - 

Chƣơng  1:  SƠ LƢỢC VỀ APACHE, PHP, MYSQL VÀ 

CÁCH CÀI ĐẶT 

1.1.  Tóm tắt sơ lƣợc về Apache, PHP, MySQL: 

 Apache, PHP, MySQL là các phần của chƣơng trình phần mềm mã nguồn mở. 

Phần mềm này là sự hợp tác của những lập trình viên có đầu óc. Bằng việc thay đổi trên 

những mã nguồn có sẵn, các lập trình viên trên thế giới tiếp tục hoàn thiện và phát triền 

nó ngày càng trở nên mạnh hơn và hiệu quả hơn. Sự đóng góp của những ngƣời này đƣợc 

đƣa ra công khai cho ngƣời khác sử dụng mã nguồn, tạo ra các phần mềm nổi tiếng trên 

thế giới. 

Tại sao mã nguồn mở gây chấn động? 

-Nó miễn phí: vì là mã nguồn mở nên các lập trình viên có thể dựa trên mã 

nguồn sẵn có để phát triển thêm, phần mềm này không có bản quyền nên mọi 

ngƣời có thể tự do sử dụng . 

-Nó  dựa  trên  nền  chữ  thập  (cross_platform)  và  kỹ  thuật  trung 

lập(technolory-neutral).  Nó không có một nền tảng cụ thể. Tập đoàn mã nguồn 

mở bảo đảm rằng nó không đƣợc phát triển bởi một cá nhân nào. Do đó định nghĩa 

mã  nguồn  mở  đƣợc  cung  cấp  bởi  OSI (open  source  initiative),  mã  nguồn  mở 

không phụ thuộc vào bất cứ một kỹ thuật cá nhân hay một loại giao diện, nó phải 

là một kỹ thuật trung lập. 

-Nó không bị giới hạn bởi những phần mềm khác, điều này có nghĩa là nếu 

một  chƣơng  trình  mã  nguồn  mở  phân  phối  cho  nhiều  chƣơng  trình  thì  những 

chƣơng trình khác có thể cũng là mã mở nguồn mở và giao dịch trong tự nhiên, 

điều này làm cho phần mềm phát triển tối đa và linh hoạt. 

-Nó có tính đa dạng: đƣợc phát triển bởi nhiều ngƣời thuộc nhiều nền văn 

hoá, nhiều lĩnh vực phong phú. 

Những phần AMP ( Apache, MySQL, PHP) làm việc với nhau nhƣ thế nào? 

Tƣởng tƣợng trang web động nhƣ một nhà hàng, khách đến ăn không cần 

quan tâm đến nó làm ra nhƣ thế nào coi nhƣ nó có sẳn và ngƣời bồi bàn giúp bạn 

chọn món ăn.  

Tôi có thể mô tả 3 thành phần của AMP nhƣ sau: 

  - 6 - 

  Apache: Cứ tƣởng tƣợng nhƣ một đầu bếp . Khi khách hàng yêu cầu 

món ăn . Cô ta nhanh nhẹn linh hoạt và có thể chuẩn bị vô số những 

món ăn khác nhau. Hoạt động của Apache trong nhiều phƣơng thức 

giống nhau là phân tích những file riêng lẻ và đƣa ra kết quả. 

  PHP: giống nhƣ ngƣời bồi bàn trong khách sạn . Anh ta nhận lời đề 

nghi  của  khách  hàng và  mang  đến  món  ăn  từ  trong  nhà  bếp  với 

những lời hƣớng dẫn cụ thể. 

  MySQL: là những kho lƣu trữ, những thành phần thông tin. 

Khi khách đến ăn (ngƣời thăm trang web) đến nhà hàng Anh ta sẽ chú ý đến món ăn 

với nhu cầu của mình. Ngƣời bồi bàn (PHP) lấy thức ăn theo yêu cầu từ trong nhà bếp 

đƣợc làm bởi đầu bếp(Apache). Ngƣời đầu bếp này sẽ đến kho để lấy những nguyên 

liệu(dữ liệu) để chuẩn bị cho món ăn. 

1.1.1.  Apache : 

Hoạt động của apache nhƣ là web server của bạn : công việc chính của nó 

là phân tích bất kỳ những file yêu cầu của trình duyệt web nào và đƣa ra những kết 

quả chính xác.Apache tuyệt vời có thể hoàn thành hầu hết những yêu cầu của bạn. 

1.1.2.  PHP:  

PHP là một ngôn ngữ mở rộng chính mà cho phép trang web của bạn hoạt 

động. Nó linh hoạt và tƣơng đối nhỏ. Nó đã đƣợc áp dụng và phát triển trong kinh 

doanh. Nó cũng giống nhƣ ngôn ngữ Asp của Microsoft, Nhƣng PHP thân thiện 

hơn,dẽ sử dụng hơn. 

1.1.3.  MySQL : 

MySQL là một cấu trúc dữ liệu có thể kết hợp với PHP, Apache để làm 

việc với nhau. Nó là ngôn ngữ truy vấn có cấu trúc. Nó đƣa ra hiệu ứng và tốc độ 

cao. 

Nó cập nhật dữ liệu, xóa dữ liệu, thêm dữ liệu mà không ảnh hƣởng đến 

cấu trúc hệ thống. 

1.2.  Cài đặt: 

Các bƣớc cài đặt bộ ba Apache,PHP,MySQL 

  - 7 - 

Bƣớc 1: tải bộ ba Apache, PHP, MySQL tại địa chỉ : 

182Hhttp://www.apachefriends.org/download.php?xampp-win32-1.4.16-installer.exe 

Bƣớc 2 : Cài đặt bình thƣờng nhƣ những ứng dụng khác 

Bƣớc 3 : Kiểm tra cài đặt thành công chƣa: 

  Sau khi cài đặt  trên màn hình có biểu tƣợng nhƣ Hình 1.2-1 

Hinh 1.2.1 

  Nhấp đúp vào biểu tƣợng sẽ xuất hiện nhƣ Hình 1.2-2 

Hinh  1.2.2 

  Nhấp vào nút start của Apache và MySQL cho chƣơng trình chạy Hình 1.2.3 

Hinh 1.2.3 

Sau đó thực hiện các thao tác để viết lệnh trên PHP hoặc MySQL 

Lưu ý:khi thực hiện lệnh trên PHP hoặc MySQL thi vẫn để chƣơng trình XAMPP chạy 

song song với chƣơng trình đang thực hiện. 

  - 8 - 

Để kiểm tra việc cài đặt có thành công chƣa ta thực hiện nhƣ sau. 

Vào một trình soạn thảo chẳng hạng nhƣ Notepad gõ dòng lệnh: 

<?php 

  echo "Hello Mom"; 

?> 

Lƣu vào thƣ mục đã cài đặt XAMP: xamp\htdocs. Với đuôi *.php 

Sau đó mở trình duyệt web gõ 183Hhttp://localhost/*.php 

Nếu thành công trình duyệt sẽ xuất hiện nhƣ Hình 1.2.4: 

Hinh 1.2.4 

Nhƣ vậy là việc cài đặt đã thành công. 

Hoặc gõ nhƣ sau: 

<?php 

  phpinfo(); 

?> 

Bạn sẽ thấy kết quả nhƣ Hình 1.2.5: 

  - 9 - 

Hinh 1.2.5 

  - 10 - 

Chƣơng  2:  TẠO NHỮNG TRANG PHP SỬ DỤNG PHP5 

Chương 2 giới thiệu những phần sau: 

1.  Sử dụng “echo” để trình bài text. 

2.  Định dạng text bằng HTML và PHP. 

3.  Hằng và biến. 

4.  Sử dụng URL để truyền biến . 

5.  Sessions và cookies. 

6.  HTML forms. 

7.  Mệnh đề if/else. 

8.  Includes. 

9.  Functions. 

10. Array và foreach. 

11. While và do/while. 

12. Sử dụng lớp và thứ tự với OOP. 

Hai nguyên tắc cơ bản trong PHP 

- PHP hiển thị trong trang Web vơi thẻ mở và thẻ đóng nhƣ  sau: 

<?php 

  // First line of code goes here; 

  // Second line of code goes here; 

  // Third line of code goes here; 

?> 

-Những dòng PHP kết thúc bằng dấu “;”.Lời chú thích đựoc viết sau “//” (trên mỗi 

dòng) hoặc” /*” ở đầu đoạn chú thích và “*/” ở cuối đoạn chú thích 

2.1.  Sử dụng “echo” để trình bài text 

Hàm “echo” là hàm xuất cơ bản trên trình duyệt Web. 

  Vd: 

     <?php 

      echo “I‟m a lumberjack.”; 

      echo “And I‟m okay.”; 

?> 

  Kết quả Hình 2.1.1:  

  - 11 - 

Hinh 2.1.1 

  Chúng ta có thể lồng HTML với PHP. 

  Vd:  

    <?php 

      echo “<h1>I‟m a lumberjack.</h1>”; 

      echo “<h2>And I‟m okay.</h2>”; 

?> 

  Kết quả nhƣ Hình 2.1.2: 

Hinh 2.1.2 

2.2.  Định dạng text bằng HTML và PHP 

  <html> 

  <head> 

    <title>My First PHP Program</title> 

  </head> 

  <body> 

    <?php 

      echo “<h1>I‟m a lumberjack.</h1>”; 

      echo “<h2>And I‟m okay.</h2>”; 

    ?> 

  </body> 

  - 12 - 

</html> 

Việc kết hợp giữa HTML và PHP nhằm đạt tới hai muc tiêu : 

  Cải tiến đƣợc hình thức trình bày của web site 

  Có thể giữ xen kẻ những dòng mã HTML với các đoạn mã của PHP. 

Bạn có thể so sánh hai đoạn mã sau: 

Vd1: 

  <?php 

    echo “<table width=‟100%‟ border=‟2‟ bgcolor=‟#FFFFFF‟>”; 

    echo “<tr>”; 

    echo “<td width=‟50%‟>”; 

    echo “<font face=‟Verdana, Arial‟ size=‟2‟>”; 

    echo “First Name:”; 

    echo “</font></td”>; 

    echo “<td width=‟50%‟>”; 

    echo “<font face=‟Verdana, Arial‟ size=‟2‟>”; 

    echo $_POST[“fname”] 

    echo “</font></td>”; 

    echo “</tr>”; 

    echo “</table>”; 

?> 

Kết quả hiển thị ra trình duyệt Hình 2.2.1: 

  Hinh  2.2.1 

Vd2: 

<table> 

  <tr> 

    <td> 

      <font>First Name: 

      </font> 

</td> 

    <td> 

      <font> 

      <?php 

        echo $_POST["fname"]; 

      ?> 

      </font> 

</td> 

  </tr> 

</table> 

Kết quả hiển thị nhƣ Hình 2.2.2: 

  Hinh  2.2.2 

  - 13 - 

2.3.  Sử dụng hằng và biến  

2.3.1.  Tổng quan về hằng: 

Tƣơng tự nhƣ trong những ngôn ngữ lập trình khác, hằng trong PHP cũng là 

một giá trị đƣợc khai báo trƣớc khi sử dụng. Nó phải bắt đầu bằng chữ cái hoặc dấu 

gạch dƣới (_) và không đƣợc bắt đầu bằng số, nó có thể là một chuổi. 

Hằng trong PHP đƣợc định nghĩa bằng hàm define(). Nó không thay đổi và 

không đƣợc đƣợc định nghĩa lại. 

Vd: tạo một file mới, lƣu với tên moviesite.php 

<html> 

  <head> 

    <title>My Movie Site 

    </title> 

  </head> 

  <body> 

  <?php 

    define (“FAVMOVIE”, “The Life of Brian”); 

    echo “My favorite movie is “; 

    echo FAVMOVIE; 

  ?> 

  </body> 

</html> 

Kết quả: Trên trình duyệt xuất hiện nhƣ Hình 2.3.1: 

Hinh  2.3.1  

2.3.2.  Tổng quan về biến. 

Không giống nhƣ hằng, nó không cần định nghĩa, có thể thay đổi trong 

chƣơng trình. Cách đặt tên của biến cũng giống nhƣ cách đặt tên của Hằng. Biến 

  - 14 - 

phân biệt chữ hoa và chữ thƣờng. 

Tất cả biến trong PHP đều bắt đầu bằng dấu “$” bất chấp đó là loại biến gì: 

chuổi, số nguyên, số động hoặc mảng, tất cả chúng đều trông giống nhau. Nó tự 

động hiểu các kiểu biến ngƣời dùng không cần phải khai báo kiểu biến. 

Nói chung, khi sử dụng biến trong PHP ta cần quan tâm đến 3 vị trí khác 

nhau của biến: 

1.  Khai báo ngay trong mã lệnh PHP 

2.  Chuyển tiếp  từ một trang HTML. 

3.  Là biến sẳn có trong hệ thống PHP. 

Vd:  

Sử dụng lại ví dụ moviesite.php chỉ thêm vào biến movierate: 

<html> 

  <head> 

    <title>My Movie Site 

    </title> 

  </head> 

  <body> 

  <?php 

    define ("FAVMOVIE", "The Life of Brian"); 

    echo "My favorite movie is "; 

    echo FAVMOVIE; 

    echo "<br>"; 

    $movierate = 5; 

    echo "My movie rating for this movie is: "; 

    echo $movierate; 

  ?> 

  </body> 

</html> 

Kết quả hiển thị nhƣ Hình 2.3.2.1: 

Hinh  2.3.2.1 

Chú ý: 

  - 15 - 

  Trong PHP, phép gán là dấu” =”, so sánh là “= =”: 

  PHP có thể tự động chuyển đổi kiểu trong các phép tính. 

  PHP Có thể thực hiện việc cộng một biến số với một chuổi có số đứng 

đầu: 

Vd: 

$a = 2 ; 

$b = “2 con heo con”; 

$c = $a + $b; 

echo $c; 

Kết quả : $c = 4. 

PHP có một số hàm toán học đƣợc xây dựng dựa trên số mà bạn có thể sử 

dụng những biến chứa con số nhƣ những  hàm sau: 

    - rand(min),(max) phát sinh ra một số ngẫu nhiên. 

    - cell(number) làm tròn số thập phân thành một số nguyên kế tiếp lớn hơn. 

    - floor(number) làm tròn một số thập phân xuống một số nguyên nhỏ hơn. 

-  number_format(number[,dec  place]  [,dec  point]  [,thousands]):Định  dạng  

một số thập phân theo cách : chọn chữ số ờ phần thập phân, dấu ngăn cách giữa 

phần thập phân và phần nguyên, dấu phân cách giữa 3 chữ số của phần nguyên. 

    - max(argument1, argument2, ...):Trả về giá trị lớn nhất trong các đối số. 

- min(argument1, argument2, ...): Trả  về giá trị nhỏ nhất. 

2.4.  Truyền biến giữa các trang 

Có bốn cách cơ bản để truyền biến giữa các trang: truyền biến trong URL, qua 

session, cookie hoặc với một HTML form. 

Trƣớc khi bàn luận về 4 cách truyền biến giữa các trang ta cần hiểu một vài khái 

niệm gọi là biến toàn cục. Đây là cấu hình trong file php.ini. Khi nó đƣợc đặt là “off”, giá 

trị ban đầu của biến  có từ sự chèn vào giả tạo của một đoạn mã bên ngoài. Trong các 

phiên bản trƣớc PHP mặc định biến này trong php.ini là “on”. Kể từ phiên bản 4.2 thì nó 

mặc định là “off”. Đây là nguyên nhân khiến các lập trình viên phải mất ngủ bởi vì bạn 

phải đề cập đến một biến khác của bạn nếu biến toàn cục là “off” hoặc ngƣợc lại tìm tất 

cả các biến có giá trị tiến đến rỗng. 

Mặc dù có nhiều Web chủ đã điều chỉnh nó thành “on” nhƣng vì lý do bảo mật họ 

  - 16 - 

đã không làm thế. Trong tài liệu này biến toàn cục đƣợc điều chỉnh là “off”. 

Thay vì gọi giá trị của biến bởi cú pháp chuẩn $tên biến, khi biến toàn cục là “off” 

và bạn cần truyền biến qua các trang, bạn cần phải đề cập đến chúng trong một cách 

khác. Nhƣng chỉ trong trang tiếp nhận. Bạn sẽ thấy điều này trong phần tiếp theo. Nhƣng 

trong những cách khác có liên quan đến các biến phụ thuộc vào việc họ đã gửi chúng nhƣ 

thế nào. 

Cú pháp và cách sử dụng:  

$_GET[„tên biến‟]: Khi phƣơng thức chuyển biến là “GET” phƣơng thức trong HTML 

forms. 

$_POST[„tên biến‟]: Khi phƣơng thức chuyển biến là “POST” phƣơng thức trong HTML 

forms. 

$_SESSION[„tên biến‟]: Khi biến đã đƣợc ấn định giá trị từ một session đặc biệt. 

$_COOKIE[„tên biến‟]: Khi biến đã đƣợc ấn định giá trị từ một cookie. 

$_REQUEST[„tên  biến‟]:Khi  nó  không  quan  trọng  ($_REQUEST  bao  gồm  các  biến 

chuyển từ bất cứ cách nào ở trên). 

$_SERVER[„tên biến‟]:  Khi biến đã đƣợc ấn định giá trị từ một server. 

$_FILES[„tên biến‟]: Khi biến đã đƣợc ấn định giá trị từ một  file upload. 

$_ENV[„tên biến‟]: Khi biến đã đƣợc ấn định giá trị từ một môi trƣờng hệ điều hành. 

  Nếu bạn không gọi ra các biến sử dụng cú pháp này thì giá trị của nó sẽ là rỗng 

trong chƣơng trình của bạn, đây có thể là nguyên nhân làm cho chƣơng trình dịch của bạn 

bị thất bại. 

2.4.1.  Truyền biến qua URL 

2.4.1.1.  Phương thức đầu tiên để truyền biến giữa các trang là thông qua một 

URL. 

Ví dụ một URL:  

     http://www.mydomain.com/news/articles/showart.php?id=12345 

Những phần sau dấu ? gọi là chuổi truy vấn (query string). Có thể nối giữa 

các biến trong URL bằng cách dùng dấu & 

Nhƣ ví dụ sau:   

  185Hhttp://www.mydomain.com/news/articles/showart.php?id=12345&lang=en

  - 17 - 

Ở đây có một vài bất lợi : 

  Mọi ngƣời có thể nhìn thấy giá trị của biến, những thông tin nhạy cảm 

thì không đƣợc bảo mật khi sử dụng cách thức này. 

  Ngƣời dùng  có thể đổi giá trị biến trong URL, mở những phần  mà 

ngƣời lập trình không muốn hiển thị. 

  Một ngƣời sử dụng có thể gặp phải những thông tin không chính xác 

hoặc đã cũ khi dùng URL đã đƣợc lƣu với những biến cũ trong đó.. 

Ví dụ: sử dụng biến URL 

  Sửa file moviesite.php nhƣ sau. 

<html> 

  <head> 

    <title>My Movie Site - 

      <?php echo $favmovie; ?> 

    </title> 

  </head> 

  <body> 

  <?php 

    //xóa dòng: define(“FAVMOVIE”, “The Life of 

Brian”); 

    echo “My favorite movie is “; 

    echo $favmovie; 

    echo “<br>”; 

    $movierate = 5; 

    echo “My movie rating for this movie is: “; 

    echo $movierate; 

  ?> 

  </body> 

</html> 

Mở file mới nhập đoạn mã nhƣ sau và lƣu với tên movie1.php 

<html> 

  <head> 

    <title>Find my Favorite Movie! 

    </title> 

  </head> 

  <body> 

  <?php 

    echo "<a href='moviesite.php?favmovie=Stripes'>"; 

    echo "Click here to see information about my 

favorite movie!"; 

    echo "</a>"; 

  ?> 

  </body> 

</html> 

    Cho trình duyệt chạy file movie1.php 

Kết quả nhƣ Hình 2.4.1.1.1:  

  - 18 - 

Hinh  2.4.1.1.1 

Khi click vào liên kết bạn sẽ thấy kết quả nhƣ Hình 2.4.1.1.2: 

Hinh 2.4.1.1.2: 

Bạn thấy là giá trị của biến $favmovie là “Stripes” trong URL, phải hiển thị trong  

Hinh 2.4.1.1.3, Nhƣng ở đây không hiển thị giá trị trong thân chƣơng trinh của bạn, nó chỉ 

là tƣởng tƣợng. Nếu bạn có điều chỉnh E_ALL trong file php.ini, bạn sẽ thấy thông báo 

lỗi: “biến không đƣợc định nghĩa”. 

Có cái gì sai? Bạn đoán chính xác nếu bạn nói là biến toàn cục! Đây là một ví dụ 

đơn giản về việc không khôi phục lại biến trong cách hiệu chỉnh có thể làm cho trang 

web của bạn không làm việc  và làm bạn khó hiểu. 

Bây giờ sửa đổi file moviesite.php nhƣ sau. 

<html> 

  <head> 

    <title>My Movie Site - 

      <?php echo $_REQUEST[„favmovie‟]; ?> 

  - 19 - 

    </title> 

  </head> 

  <body> 

    <?php 

      echo “My favorite movie is “; 

      echo $_REQUEST[„favmovie‟]; 

      echo “<br>”; 

      $movierate = 5; 

      echo “My movie rating for this movie is: “; 

      echo $movierate; 

    ?> 

  </body> 

</html> 

  Bây giờ cho chạy lại movie1.php vào click vào liên kết sẽ cho kết quả nhƣ Hinh 

2.4.1.1.3 

Hinh 2.4.1.1.3 

  Chú ý: ở đây có một vài điều cần lƣu ý: 

-  Mã PHP có thể chèn vào bất cứ đâu trong chƣơng trình xen lẫn vào mã 

HTML (trong ví dụ này nó nằm ở phần “title”). 

-  Bạn thấy hiệu quả đầu tiên là không cần lấy biến toàn cục để truy cập 

vào một biến từ trang khác, nhƣng cần chú ý rằng khi bạn đề cập đến 

$movierate bạn không bao gồm cú pháp của biến toàn cục, bởi vì biến 

$movierate  nằm  trong  moviesite.php,bạn  không  thể  lấy  thông  tin  từ 

trang khác hoặc mã khác. 

-  $_REQUEST đã đƣợc chọn trong cú pháp biến của bạn bởi vì nó thật sự 

không có ý nghĩa trong ví dụ này nơi mà giá trị của biến $favmovie đƣa 

đến. Bạn không có khó khăn gì khi công nhận mọi thứ hoặc ngăn chặn 

ngƣời dùng không đƣợc phép vào web site của bạn. Bạn đơn giản chỉ 

muốn chuyển qua giá trị . 

  - 20 - 

2.4.1.2. Ký tự đặc biệt của URL. 

Khi truyền biến qua URL , trong trƣờng hợp biến đó chứa khoảng 

trắng, dấu & hay một ký tự đặc biệt nào đó, thì ta ta dùng hàm urlencode(). 

Ví dụ: 

<html> 

  <head> 

    <title>Find my Favorite Movie! 

    </title> 

  </head> 

  <body> 

  <?php 

    //thêm dòng: 

    $myfavmovie = urlencode("Life of Brian"); 

    //thay đổi dòng: 

    echo "<a href='moviesite.php?favmovie=$myfavmovie'>"; 

    //echo "<a href='moviesite.php?favmovie=Stripes'>"; 

    echo "Click here to see information about my favorite 

movie!"; 

    echo "</a>"; 

  ?> 

  </body> 

</html> 

Khi click vào liên kết kết quả nhƣ Hinh 2.4.1.2.1: 

Hinh 2.4.1.2.1 

2.5.  Session và Cooking 

2.5.1.  Session 

Session là tập hợp những biến tạm tồn tại cho đến khi đóng trình duyệt, trừ 

khi ta có những chỉ định khác trong php.ini. 

Mọi session có một session ID duy nhất, có thể đƣợc truyền qua cookie 

hoặc qua URL nếu phƣơng thức trƣớc không đƣợc phép. 

  - 21 - 

Để bắt đầu một session, sử dụng hàm session_start() và không đƣợc dùng 

hàm session_register, trong trƣờng hợp ta giả định register_globals trong php.ini là 

off. 

Ví dụ: 

Thêm vào ví dụ movie1.php 

<?php 

  session_start(); 

  $_SESSION[„username‟] = “Joe12345”; 

  $_SESSION[„authuser‟] = 1; 

?> 

<html> 

Thêm vào ví dụ moviesite.php 

<?php 

  session_start(); 

  //Kiểm tra để thấy nếu người dùng đâng nhập với một 

mật khẩu có sẳn. 

  if ($_SESSION[„authuser‟] != 1) 

  { 

    echo “Sorry, but you don‟t have permission to 

view this page, you loser!”; 

    exit(); 

  } 

?> 

<html> 

…………… 

<body> 

<?php 

  echo “Welcome to our site, “; 

  echo $_SESSION[„username‟]; 

  echo “! <br>”; 

?> 

Khi click vào liên kết kết quả nhƣ Hinh 2.5.1.1:     

Hinh 2.5.1.1 

Các thông tin về session phải đặt ngay đầu trang, trƣớc bất kỳ mã HTML 

  - 22 - 

nào. Nếu phần trƣớc đoạn mã PHP tại đầu trang có khoảng trắng thì sẽ có thông 

báo lỗi nhƣ Hinh 2.5.1.2: 

Hinh 2.5.1.2: 

Nếu sử dụng session variables thì phải dùng hàm session_start() ở đầu mỗi 

trang. 

2.5.2.  Cookies. 

Cookies là những mẫu thông tin nhỏ đƣợc lƣu trên máy ngƣời dùng web. 

Các Cookies do Webserver phát sinh, lƣu trữ lại, sau đó sẽ đƣợc đọc ở lần truy cập 

sau. 

Để có thể sử dụng một cookies bạn  phải sử dụng hàm: setcookie() nhƣ sau: 

setcookie(„tên cookie‟, „giá trị‟, „thời gian kết thúc‟, „đường dẫn‟, „vùng‟, „kết nối 

an toàn‟); 

Ví dụ: 

Thêm vào ví dụ movie1.php 

<?php 

  setcookie(„username‟, „Joe‟, time()+60); 

  //$_SESSION[„username‟]=”Joe12345”; 

Thêm vào ví dụ moviesite.php 

<?php 

  echo “Welcome to our site, “; 

  echo $_COOKIE[„username‟]; 

  //echo $_SESSION[„username‟]; 

  echo “! <br>”; 

Kết quả nhƣ Hinh 2.5.2.: 

  - 23 - 

Hinh 2.5.2. 

Sau 60 giây thì chữ  “Joe” sẽ biến mất(nếu cập nhật lại) 

2.6.  HTML FORMS 

2.6.1.  Lƣu chuyển thông tin với form. 

Form  là  mã  trong  HTML,  nó  đƣợc  bao  bởi  một  cặp  thẻ  mở  và  đóng: 

<form> </form>, nó có những thuộc tính sau: 

Action: Thuộc tính này chỉ ra đƣờng dẫn URL của trang mà Form sẽ đƣợc 

gởi đến để xử lý, nó chứa đƣờng dẫn URL tƣơng đối hoặc URL tuyệt đối. 

Method: Thuộc tính này chỉ ra kiểu HTTP yêu cầu trình duyệt gởi thông tin 

đến server, nó phải đƣợc thiết lập là POST hoặc GET. 

Name: Đây là thuộc tính hữu hiệu nhất trong việc quản lý các thành phần 

của form. Tên form không đƣợc gởi đến server khi form đƣợc gởi đi. 

Các kiểu phần tử nhập trên form: 

  Text:Đây là kiểu căn bản nó có những thuộc tính sau: Text có 3 thuộc tính: 

Size: chiều rộng ô text tính bằng số ký tự. 

Maxlength:Giới hạn số ký tự tối đa có thể nhập vào. 

Value:chứa giá trị mặc định trong văn bản, ngƣời dùng có thể nhập giá 

trị khác 

  Checkbox: Tên và giá trị của hộp kiểm này chỉ này chỉ đƣợc truyền nếu 

đƣợc chọn khi form đƣợc gởi. Nếu từ checked có trong thẻ thì hộp kiểm 

đƣợc chọn mặc định. 

  Radio: Nút này cho phép ngƣời dùng chọn chỉ một trong số các lựa chọn 

có cùng tên. 

  - 24 - 

  Select: Là hộp chọn sổ xuống, thƣờng cho phép ngƣời dùng chọn một từ 

một danh sách, sự lựa chọn  này có thể mô tả với thuộc tính value. 

  Password: Giống với kiểu text, tuy nhiên văn bản nhập vào hộp đƣợc hiển 

thị bằng ký tự thay thế (ký tự “*”) 

Những nút khác đƣợc miêu tả nhƣ nút submit, reset, hoặc những hình ảnh 

trên những nút do ngƣời dùng tạo ra. 

Ví dụ :Sử dụng form để lấy thông tin: 

Mở file movie1.php và sửa lỗi nhƣ sau: 

<?php 

  session_start(); 

  $_SESSION['username'] = $_POST['user']; 

  $_SESSION['userpass'] = $_POST['pass']; 

  $_SESSION['authuser'] = 0; 

  //Kiểm tra thông tin username và password 

  if (($_SESSION['username'] == 'Joe') and 

($_SESSION['userpass'] == '12345')) { 

      $_SESSION['authuser'] = 1; 

  } 

  else { 

      echo "Sorry, but you don’t have permission to view this 

page, you loser!"; 

      exit(); 

  } 

?> 

Sau đó sửa trong moviesite.php nhƣ sau: 

//xóa dòng này: echo $_COOKIE[„username‟]; echo 

$_SESSION['username']; Tạo một file mới lưu với tên 

login.php 

<?php 

  session_unset(); 

?> 

<html> 

  <head> 

    <title>Please Log In 

    </title> 

  </head> 

  <body> 

    <form> 

      <p>Enter your username: 

        <input> 

      </p> 

      <p>Enter your password: 

        <input> 

      </p> 

      <p> 

        <input 

value="Submit"> 

  - 25 - 

      </p> 

    </form> 

  </body> 

</html> 

Mở trình duyệt chạy file login.php, nhập  vào user name: Joe12345, password: 

12345, bạn sẽ thấy kết quả hiển thị nhƣ Hình 2.6.1.1: 

Hình 2.6.1.1 

Khi click vào Submit, sẽ thấy kết quả nhƣ Hình 2.6.1.2: 

Hình 2.6.1.2 

Nếu bây giờ ta nhập user name là Joe và password là 12345 thì kết quả nhƣ Hình 

2.6.1.3: 

  - 26 - 

Hình 2.6.1.3 

Khi click vào liên kết thì kết quả nhƣ Hình 2.6.1.4: 

Hinh 2.6.1.4 

2.7.  CÂU LỆNH IF/ELSE 

2.7.1.  Mệnh đề if. 

Khác với những ngôn ngữ lập trình khác, PHP sử dụng mệnh đề if riêng lẻ, 

cú pháp nhƣ sau: 

    if (điều kiện) mã lệnh được thi hành nếu điều kiện đúng; 

Ví dụ: 

    if ($stockmarket >= 10000) echo “Hooray! Time to Party!”; 

Trong trƣờng hợp mệnh đề if có nhiều câu lệnh thì ta dùng dấu “{}” để bao bọc nó. 

Ví dụ 

if ($stockmarket >= 10000) 

  echo “Hooray! Time to Party!”; 

  $mood = “happy”; 

  $retirement = “potentially obtainable”; 

  - 27 - 

Các phép toán dùng để so sánh trong mệnh đề if 

Operator           Appropriate Syntax 

Bằng                  : = = 

Không bằng                : != or <> 

Lớn hơn                :  > 

Nhỏ hơn                :  < 

Lớn hơn hoặc bằng              :  >= 

Nhỏ hơn hoặc bằng              : <= 

Bằng, và kiểu dữ liệu thỏa kiểu dữ liệu giống nhau    :  = = = 

Không bằng hoặc kiểu dữ liệu không giống nhau    : != = 

Ví dụ: 

<html> 

  <head> 

    <title>How many days in this month? 

    </title> 

  </head> 

  <body> 

<?php 

  $month = date("n"); 

  if ($month = = 1) echo "31"; 

  if ($month = = 2) echo "28 (unless it’s a leap 

year)"; 

  if ($month = = 3) echo "31"; 

  if ($month = = 4) echo "30"; 

  if ($month = = 5) echo "31"; 

  if ($month = = 6) echo "30"; 

  if ($month = = 7) echo "31"; 

  if ($month = = 8) echo "31"; 

  if ($month = = 9) echo "30"; 

  if ($month = = 10) echo "31"; 

  if ($month = = 11) echo "30"; 

  if ($month = = 12) echo "31"; 

    ?> 

  </body> 

</html> 

Kết quả nhƣ Hinh 2.7.1.1 : 

  - 28 - 

Hinh 2.7.1.1  

Hoạt động của mệnh đề if tƣơng tự nhƣ những ngôn ngữ lập trình khác . 

Điểm lƣu ý trong ví dụ này là hàm date("n")sẽ cho giá trị tháng hiện hành khi 

ngƣời truy cập  vào website. 

2.7.2.  Sử dụng if và else lồng nhau. 

Trong một số trƣờng hợp dùng mình “if” thì tốt, nhƣng đôi khi kết hợp giữa 

“if” và “else” sẽ cho ta kết quả nhƣ mong muốn. 

<html> 

  <head> 

    <title>Is it a leap year? 

    </title> 

  </head> 

  <body> 

    <?php 

      $leapyear = date("L"); 

      if ($leapyear = = 1) echo "Hooray! It’s a leap 

year!"; 

      else echo "Aww, sorry, mate. No leap year this 

year."; 

    ?> 

  </body> 

</html> 

Kết quả nhƣ Hình 2.7.2: 

  - 29 - 

Hình 2.7.2 

2.8.  Sử dụng include cho đoạn mã có hiệu quả hơn 

Khi thực hiện viết lệnh trong PHP để tránh sự lặp đi lặp lại không cần thiết ta dùng 

hàm include. 

Để hiểu rõ vấn đề này chúng ta hãy xét ví dụ sau: 

Tạo một file mới đặt với tên header.php 

<div> 

  <font>Welcome to my movie review site! 

  </font> 

  <br> 

  <?php 

    echo "Today is "; 

    echo date("F d"); 

    echo ", "; 

    echo date("Y"); 

  ?> 

</div> 

Sau đó thêm vào các file movie1.php, moviesite.php và login.php câu lệnh sau ngay sau 

thẻ <body>:  <?php include "header.php"; ?> 

Mở trình duyệt với tên login.php ban sẽ có kết quả nhƣ Hình 2.8: 

  - 30 - 

Hình 2.8 

Hoạt động:Khi PHP gặp một include trong đoạn mã script, nó ngừng hoạt động và 

ngay lập tức tìm đến file đƣợc chỉ dẫn bởi include. Server phân tích file này và trả kết quả 

trở lại file gốc và việc phân tích mã lại tiếp tục tại nơi đã dừng trƣớc đó. 

2.9.  Sử dụng Hàm cho đoạn mã có hiệu quả hơn 

Nhƣ với include, Hàm làm cho đoạn mã của bạn hiệu quả hơn và dễ dàng biên dịch 

hơn. Hàm là một khối lệnh có thể đƣợc gọi bất cứ nơi nào trong chƣơng trình. Chúng thể 

sử dụng lại ở bất cứ khi nào. Nó có thể giúp ta đặt hoặc cập nhật biến và có thể xếp lồng 

vào nhau. Bạn cũng có thể tạo một hàm chỉ đƣợc thực thi khi điều kiện nào đó thỏa mãn. 

Các hàm tự chúng là các chƣơng trình nhỏ. Chúng không biết bất cứ biến nào xung 

quanh nó trừ khi bạn khai báo biến toàn cục. Có thể dùng khai báo global $tên_biến để 

tạo biến toàn cục. Điều này không cần với những biến toàn cục mặc định nhƣ POST, 

GET. 

Ví dụ: 

Mở movie1.php thêm vào đọan mã nhƣ sau: 

echo "<br>"; 

echo "<a href ='moviesite.php?movienum=5'>"; 

echo "Click here to see my top 5 movies."; 

echo "</a>"; 

echo "<br>"; 

echo "<a href='moviesite.php?movienum=10'>"; 

  - 31 - 

echo "Click here to see my top 10 movies."; 

echo "</a>"; 

?> 

</body> 

</html> 

Mở moviesite.php thêm vào phần sau: 

<?php 

function listmovies_1() 

    echo "1. Life of Brian<br>"; 

    echo "2. Stripes<br>"; 

    echo "3. Office Space<br>"; 

    echo "4. The Holy Grail<br>"; 

    echo "5. Matrix<br>"; 

function listmovies_2() 

    echo "6. Terminator 2<br>"; 

    echo "7. Star Wars<br>"; 

    echo "8. Close Encounters of the Third Kind<br>"; 

    echo "9. Sixteen Candles<br>"; 

    echo "10. Caddyshack<br>"; 

if (isset($_REQUEST['favmovie'])) { 

    ---------------------- 

else { 

    echo "My top "; 

    echo $_REQUEST['movienum']; 

    echo " movies are:"; 

    echo "<br>"; 

    listmovies_1(); 

    if ($_REQUEST['movienum'] == 10) { 

        listmovies_2(); 

    } 

Bây giờ ta cho chạy file login.php : đăng nhập với tên username là Joe, password 

là 12345 

Bạn sẽ thấy kết quả nhƣ sau Hình 2.9.1: 

  - 32 - 

Hình 2.9.1 

Khi click vào liên kết thứ hai ta sẽ thấy nhƣ Hình 2.9.2: 

Hình 2.9.2 

Khi click vào liên kết thứ ba ta sẽ thấy nhƣ Hình 2.9.3: 

  - 33 - 

Hình 2.9.3 

2.10. Mảng 

Mảng là một danh sách chứa thông tin với khóa và đƣợc lƣu trữ với một tên biến. 

Một mảng có dòng thông tin và khóa, khóa là cột đầu tiên trong bảng. Khóa phải đồng 

nhất để dễ tổ chức và sử dụng.  

2.10.1.  Cú pháp của mảng. 

2.10.1.1.  Mảng một chiều 

<?php 

$husband = array("firstname"=>"Albert", 

"lastname"=>",instein", 

"age"=>"124"); 

echo $husband[firstname]; 

?> 

Kết quả xuất ra màn hình Hình 2.10.1.1:  

  - 34 - 

        Hinh 2.10.1.1 

Chú ý: Sử dụng => để thay cho dấu bằng, khi ấn định những giá trị đến khóa của 

mảng. Điều này cho bạn xuất ra “Albert” và tất cả giá trị vẫn đƣợc lƣu trữ trong biến 

$husband. 

Bạn cũng có thể đặt một mảng giá trị theo cách sau: 

$husband[“firstname”] = “Albert”; 

$husband[“lastname”] = “Einstein”; 

$husband[“age”] = 124; 

2.10.1.2.  Mảng đa chiều: 

Ví dụ: 

  <?php 

$table1 = array(“husband” => array(“firstname”=>”Albert”, 

“lastname”=>”Einstein”, 

“age”=>124), 

“wife” => array(“firstname”=>”Mileva”, 

“lastname”=>”Einstein”, 

“age”=>123)); 

//do the same for each table in your restaurant 

?> 

Nếu muốn xuất firstname của mọi ngƣời, ta dùng hàm xuất nhƣ sau: 

  <?php 

  - 35 - 

echo $table1[“husband”][“firstname”]; 

echo “ & “; 

echo $table1[“wife”][“firstname”];?> 

Kết quả Hình 2.10.1.2: 

Hình 2.10.1.2 

Để đơn giản ta có thể dùng một cách khác để lƣu trữ mảng nhƣ sau: 

  <?php 

$flavor[] = “blue raspberry”; 

$flavor[] = “root beer”; 

$flavor[] = “pineapple”; 

?> 

Để xuất thông tin ra ta thực hiện câu lệnh nhƣ sau: 

echo $flavor[0]; //xuất “blue raspberry” 

echo $flavor[1]; // xuất “root beer” 

echo $flavor[2]; // xuất “pineapple” 

2.10.1.3.  Sắp xếp mảng 

PHP cung cấp nhiều cách để lƣu trữ giá trị của mảng,  sau đây là mô tả  một 

vài hàm sắp xếp trong mảng. 

arsort(array) :Sắp xếp một mảng giảm theo giá trị và duy trì quan hệ của 

khóa/ giá trị 

asort(array): Sắp xếp một mảng tăng theo giá trị và duy trì quan hệ của 

khóa/ giá trị 

rsort(array): Sắp xếp một mảng giảm theo giá trị 

  - 36 - 

sort(array): Sắp xếp một mảng tăng theo giá trị 

Ví dụ: 

    <?php 

$flavor[] = "blue raspberry"; 

$flavor[] = "root beer"; 

$flavor[] = "pineapple"; 

sort($flavor); 

print_r($flavor); 

?> 

Kết quả nhƣ Hình 2.10.1.3: 

Hình 2.10.1.3 

Chú ý: 

Ở đây dùng hàm mới prinf_r, chức năng của hàm này là xuất thông tin về một biến 

mà ngƣời ta có thể đọc nó dễ dàng. Nó thƣờng đƣợc dùng để kiểm tra giá trị của 

mảng, một cách cụ thể.  

Ở đây hàm sort dùng để sắp xếp theo thứ tự Alpha 

2.10.2.  Cấu trúc Foreach   

Ví dụ: 

    <?php 

$flavor[] = "blue raspberry"; 

$flavor[] = "root beer"; 

  - 37 - 

$flavor[] = "pineapple"; 

echo "My favorite flavors are:<br>"; 

foreach ($flavor as $currentvalue) { 

//these lines will execute as long as there is a value in $flavor 

echo $currentvalue . "<br>

"; 

?> 

Kết quả nhƣ Hình 2.10.2.1:  

Hình 2.10.2.1 

Khi PHP xử lý trong mảng. Nó giữ vị trí của các khóa bằng cách sử dụng con trỏ 

trong mảng. 

Khi hàm foreach đƣợc gọi con trỏ chờ giá trị đầu tiên trong mảng. Cuối hàm con 

trỏ chuyển xuống khóa  cuối cùng trong mảng. Vị trí của con trỏ có thể là công cụ trợ 

giúp. 

Ví dụ: 

1/ Thay đổi moviesite nhƣ sau: 

<?php 

session_start(); 

//kiểm tra username và password 

if ($_SESSION['authuser'] != 1) { 

echo "Sorry, but you don't have permission to view this 

page, you loser!"; 

exit(); 

  - 38 - 

?> 

<html> 

<head> 

<title>My Movie Site</title> 

</head> 

<body> 

<?php include "header.php"; ?> 

<?php 

$favmovies = array("Life of Brian", 

"Stripes", 

"Office Space", 

"The Holy Grail", 

"Matrix", 

"Terminator 2", 

"Star Wars", 

"Close Encounters of the Third Kind", 

"Sixteen Candles", 

"Caddyshack"); 

/*/delete these lines: 

function listmovies_1()  

echo "1. Life of Brian<br>"; 

echo "2. Stripes<br>"; 

echo "3. Office Space<br>"; 

echo "4. The Holy Grail<br>"; 

echo "5. Matrix<br>"; 

function listmovies_2()  

echo "6. Terminator 2<br>"; 

  - 39 - 

echo "7. Star Wars<br>"; 

echo "8. Close Encounters of the Third Kind<br>"; 

echo "9. Sixteen Candles<br>"; 

echo "10. Caddyshack<br>"; 

//kết thúc dòng xóa*/ 

if (isset($_REQUEST['favmovie'])) 

 { 

echo "Welcome to our site, "; 

echo $_SESSION['username']; 

echo "! <br>"; 

echo "My favorite movie is "; 

echo $_REQUEST['favmovie']; 

echo "<br>"; 

$movierate = 5; 

echo "My movie rating for this movie is: "; 

echo $movierate; 

} else  

echo "My top 10 movies are:<br>"; 

if (isset($_REQUEST['sorted']))  

sort($favmovies); 

/*/delete these lines 

echo $_REQUEST['movienum']; 

echo " movies are:"; 

echo "<br>"; 

listmovies_1(); 

if ($_REQUEST['movienum'] == 10) listmovies_2(); 

//end of deleted lines*/ 

  - 40 - 

foreach ($favmovies as $currentvalue)  

echo $currentvalue; 

echo "<br>

"; 

?> 

</body> 

</html> 

2/ Thay đổi movie1.php nhƣ sau: 

<?php 

session_start(); 

$_SESSION['username'] = $_POST['user']; 

$_SESSION['userpass'] = $_POST['pass']; 

$_SESSION['authuser'] = 0; 

// kiểm tra username và password 

if (($_SESSION['username'] == 'Joe') and 

($_SESSION['userpass'] == '12345'))  

$_SESSION['authuser'] = 1; 

} else { 

echo "Sorry, but you don't have permission to view this 

page, you loser!"; 

exit(); 

?> 

<html> 

<head> 

<title>Find my Favorite Movie!</title> 

</head> 

  - 41 - 

<body> 

<?php include "header.php"; ?> 

<?php 

$myfavmovie = urlencode("Life of Brian"); 

echo "<a href='moviesite.php?favmovie=$myfavmovie'>"; 

echo "Click here to see information about my favorite movie!"; 

echo "</a>"; 

echo "<br>"; 

/*/delete these lines 

echo "<a href='moviesite.php?movienum=5'>"; 

echo "Click here to see my top 5 movies."; 

echo "</a>"; 

echo "<br>"; 

//end of deleted lines*/ 

//change the following line: 

echo "<a href='moviesite.php'>"; 

echo "Click here to see my top 10 movies."; 

echo "</a>"; 

echo "<br>"; 

echo "<a href='moviesite.php?sorted=true'>"; 

echo "Click here to see my top 10 movies, sorted alphabetically."; 

echo "</a>"; 

?> 

</body> 

</html> 

3/ Cho chạy login.php và click vào dòng 

186HClick here to see my top 10 movies. 

Bạn sẽ thấy kết quả nhƣ Hình 2.10.2.2 : 

  - 42 - 

Hình 2.10.2.2 

 Quay lại file movie1.php click vào: 

187HClick here to see my top 10 movies, sorted alphabetically. 

Bạn sẽ thấy kết quả nhƣ sau nhƣ Hình 2.10.2.3: 

Hình 2.10.2.3  

Ở đây đã có sự sắp xếp theo thứ tự alpha 

Cách thức hoạt động :  

Trƣớc tiên bạn đặt danh sách động trong biến, $favmovies với mảng. Sau đó bạn 

có  thể  để  danh  sách  movie  từng  cái  một  bằng  cách  sử  dụng  foreach  trong  file 

moviesite.php. Bạn cũng có thể thêm một liên kết để ngƣời sử dụng sắp xếp danh sách 

theo alphabel bằng cách dùng biến có tên $_REQUEST[sorted]. 

Khi biến này là true thì hàm sort() đƣợc thực thi và bạn truyền biến true qua URL trong 

liên kết. 

  - 43 - 

2.11. While và do.. while 

Nhƣ ta đã thấy hàm foreach hoạt động trên mỗi phần tử của mảng. Ta cũng có thể 

dùng câu lệnh while để làm điều đó. 

Ví dụ:  

 Sử dụng vòng lặp while để in ra dãy số từ 15 

  $num = 1; 

while ($num <= 5)  

echo $num; 

echo “<br>”; 

$num = $num + 1; 

Tƣơng tự với do .. while cũng cho ra cùng kết quả. 

$num = 1; 

do  

echo $num; 

echo “<br>”; 

$num = $num + 1 

}  

while ($num <= 5); 

Ví dụ : về việc sử dụng hàm while: 

1. Thay đổi  movie1.php nhƣ sau: 

<?php 

session_start(); 

$_SESSION[„username‟] = $_POST[„user‟]; 

$_SESSION[„userpass‟] = $_POST[„pass‟]; 

$_SESSION[„authuser‟] = 0; 

// kiểm tra username và password 

if  (($_SESSION[„username‟]  ==  „Joe‟)  and  $_SESSION[„userpass‟]  =  = 

„12345‟)) { 

  - 44 - 

$_SESSION[„authuser‟] = 1; 

} else { 

echo “Sorry, but you don‟t have permission to view this 

page, you loser!”; 

exit(); 

?> 

<html> 

<head> 

<title>Find my Favorite Movie!</title> 

</head> 

<body> 

<?php include “header.php” ?> 

<?php 

$myfavmovie=urlencode(“Life of Brian”); 

echo “<a href=‟moviesite.php?favmovie=$myfavmovie‟>”; 

echo “Click here to see information about my favorite movie!”; 

echo “</a>”; 

echo “<br>”; 

/* 

echo “<a href=‟moviesite.php‟>”; 

echo “Click here to see my top 10 movies.”; 

echo “</a>”; 

echo “<br>”; 

echo “<a href=‟moviesite.php?sorted=true‟>”; 

echo “Click here to see my top 10 movies, sorted alphabetically.”; 

echo “</a>”; 

*/ 

echo “Or choose how many movies you would like to see:”; 

echo “</a>”; 

echo “<br>”; 

  - 45 - 

?> 

<form method=”post” action=”moviesite.php”> 

<p>Enter number of movies (up to 10): 

<input type=”text” name=”num”> 

<br> 

Check here if you want the list sorted alphabetically: 

<input type=”checkbox” name=”sorted”> 

</p> 

<input type=”submit” name=”Submit” value=”Submit”> 

</form> 

</body> 

</html> 

2. Thay đổi moviesite.php: 

<?php 

session_start(); 

//check to see if user has logged in with a valid password 

if ($_SESSION[„authuser‟] != 1) { 

echo “Sorry, but you don‟t have permission to view this 

page, you loser!”; 

exit(); 

?> 

<html> 

<head> 

<title>My Movie Site</title> 

</head> 

<body> 

<?php include “header.php”; ?> 

<?php 

$favmovies = array(“Life of Brian”, 

“Stripes”, 

  - 46 - 

“Office Space”, 

“The Holy Grail”, 

“Matrix”, 

“Terminator 2”, 

“Star Wars”, 

“Close Encounters of the Third Kind”, 

“Sixteen Candles”, 

“Caddyshack”); 

if  (isset($_REQUEST[„favmovie‟]))  {//isset(xac  dinh  mot  bien  co  trong 

//tap hop khong) 

echo “Welcome to our site, “; 

echo $_SESSION[„username‟]; 

echo “! <br>”; 

echo “My favorite movie is “; 

echo $_REQUEST[„favmovie‟]; 

echo “<br>”; 

$movierate = 5; 

echo “My movie rating for this movie is: “; 

echo $movierate; 

} else { 

echo “My top “. $_POST[“num”] . “ movies are:<br>”; 

if (isset($_REQUEST[„sorted‟])) { 

sort($favmovies); 

//list the movies 

$numlist = 1; 

while ($numlist <= $_POST[“num”]) 

 { 

echo $numlist; 

echo “. “; 

echo pos($favmovies); 

  - 47 - 

next($favmovies); 

echo “<br>

”; 

$numlist = $numlist + 1; 

/* 

 foreach ($favmovies as $currentvalue) { 

echo $currentvalue; 

echo “<br>

”; 

*/ 

?> 

</body> 

</html> 

Kết quả Hình 2.11 

Hình 2.11 

Khi điền vào ô một số và đánh dấu check vào ô kiểm tra  thì kết quả sẽ hiện ra 

danh sách có số phần tử bằng với con số nhập vào và sắp xếp theo thứ tự alphabel. 

Chú ý: 

-  Chúng ta thêm vào echo một vài thủ thuật: 

Echo”My top”.$_POST[“num”].”movie are:<br>”; 

  - 48 - 

  Với phƣơng thức này bạn có thể gặp vài lỗi và dấu nháy kép(“) không đƣợc nhận 

ra. 

-  Bạn đặt $numlist là 1, và điều này kiểm tra con số bạn đặt. 

-  Bạn sử dụng biến $_POST[“num”] để đặt giới hạn danh sách bạn cho; con số này 

đƣợc cho bởi ngƣời sử dụng trong file movie1.php 

-  Hàm pos($favmovies) cũng là hàm mới. Hàm này trả về giá trị hiện hành nơi mà 

con trỏ đƣợc bắt đầu. Bạn muốn thấy giá trị hiện hành thì xuất ra hàm này. 

-  Hàm next($favmovies) cũng là hàm mảng khác mà con trỏ của mảng chỉ tới giá trị 

tiếp theo trong hàng. Điều này dễ dàng lặp lại trong mệnh đề tiếp theo. 

2.12. Những  cú pháp xen lẫn trong php. 

2.12.1.  Xen lẫn giữa <?php và ?> 

Bạn có thể xem code php trong html trong cách khác 

- <? và ?> Phải mở trong file php.ini với thẻ mở ngắn. 

- <% và %> Phải mở trong file php.ini với thẻ ASP 

- <script language=”PHP”> and </script>.Đây là giá trị không chuyển đổi 

trong file php.ini 

2.12.2.  Xen lẫn trong mệnh đề echo 

Bạn đã sử dụng print_r(), nhƣng bạn cũng đã sử dụng print() để trình bày 

đoạn text hoặc giá trị biến trong trang web của bạn. Sự khác nhau giữa echo() và 

printf() là khi bạn sử dụng print(), một giá trị 0 hoặc 1 sẽ đƣợc trả lại cho sự thành 

công hay thất bại của lệnh print(). Trong trƣờng hợp này, bạn cũng có thể nói mọi 

thứ không in ra khi sử dụng lệnh print(). Trong khi echo() chỉ đƣa ra những gì 

không có mà bạn biết là không có hoặc nó làm việc không chính xác. 

Trong các trƣờng hợp khác thì cả hai là nhƣ nhau. 

2.12.3.  Xen lẫn giữa các phép toán logic. 

Các phép toán and(&&), or(||) là các phép toán logic. 

2.12.4.  Xen lẫn trong việc sử dụng dấu (“”). 

Ngoài việc sử dụng dấu (“”) ta cũng có thể sử dụng dấu (= <<<) 

2.12.5.  Xen lẫn những giá trị tăng, giảm 

  ++$value:Tăng biến lên 1, trả về giá trị đã tăng. 

  - 49 - 

  $value++:Trả về giá trị , sau đó tăng lên 1. 

  --$value:Giảm 1, trả về  giá trị đã giảm. 

  $value--:Trả về giá trị, sau đó giảm 1. 

  $value=$value+1:Tăng giá trị lên 1. 

  $value+=1:Tăng giá trị lên 1. 

2.13. Tổng quan về OOP 

Bạn có hoặc không nghe những thứ vớ vẩn về PHP5 và việc sử dụng OOP. OOP 

nghĩa là lập trình hƣớng đối tƣợng và trong khi nó không là đoạn mã logic tốt nhất nhƣng 

có thể cung cấp một vài tập lệnh tốt. Số lƣợng lớn về OOP trong PHP5 thông qua hệ 

phƣơng pháp OOP có thể đƣợc chấp nhận trong PHP4. Với sự ra đời PHP5 nó trở nên dễ 

sử dụng và thực hiện. Khi một ngƣời bắt đầu, Bạn sẽ không cần nghiên cứu sâu về ngôn 

ngữ OOP, nhƣng nó quang trong để bạn hiểu những khái niệm đằng sau OOP. 

Trong bảng tóm tắt OOP lấy những hàm cập nhật thông thƣờng  và thay  vì đặt 

chúng trong include nhƣ bạn làm ở trƣớc thì bạn đặt chúng trong một lớp. Một lớp là 1 

tập hợp những biến và hàm mà xuất ra khi đƣợc gọi. Đối tƣợng là những kết quả từ lớp. 

2.13.1.  Tóm tắt những ví dụ về OOP 

Sử dụng OOP  giống nhƣ thứ tự tại một quầy pizza. Nó không làm bạn tăng 

cân và có một đôi chân đẹp, nhƣng nó yêu cầu phải vận động: 

   Trƣớc tiên ngƣời bồi bàn sẽ nhận yêu cầu của bạn và đến nhà bếp. Anh ta 

đề nghị  một cái bánh pizza thích hợp với yêu cầu của bạn để nấu. Nhà bếp sẽ  coi 

công thức làm cái bánh đó và cần thêm ngƣời phụ làm. Sau đó nhà bếp làm bề mặt 

của bánh pizza và nƣớng nó trong một thời gian. Cuối cùng họ sẽ mang bánh pizza 

cho ngƣời bồi bàn. 

  Trong ví dụ này những  cách thức nhào bột, làm bề mặt của bánh, nấu và 

lấy ra từ lò. Những thành phần này là những đặt tả. Đối tƣợng của bạn là một bánh 

pizza. 

  Nếu chúng ta thể hiện kinh nghiệm làm bánh trong PHP/hệ phƣơng pháp 

OOP thì nó nhƣ sau: 

<?php 

//đây là một lớp của chúng ta. 

  - 50 - 

class Pizza 

 { 

public $dough; 

public $toppings; 

public function MakeDough($dough)  

$this->dough = $dough; 

//lăn bột $this->dough 

public function addToppings($toppings)  

$this->toppings = $toppings; 

//chia nhỏ $this->toppings; 

//đặt $this->toppings on dough; 

public function bake()  

//nƣớng bánh 

return true; 

public function make_pizza($dough, $toppings)  

//làm bánh 

$step1 = $this->MakeDough($dough); 

if ($step1)  

$step2 = $this->addToppings($toppings); 

if ($step2)  

$step3 = $this->bake(); 

  - 51 - 

?> 

  Sau đó bạn có thể tạo ra bánh pizza bất cứ lúc nào bạn cảm thấy thích và 

bạn có thể chắc rằng cái bánh đƣợc tạo đúng. 

<?php 

//đây là tập lệnh PHP của chúng ta 

$table1 = new Pizza(); 

$table1->make_pizza(„hand-tossed‟, „pepperoni‟); 

if ($table1->bake()) 

 { 

//phân phối $pizza cho bảng 1; 

else echo “uh-oh, looks like you should have gone to eat fast food.”; 

?> 

Rõ ràng, nếu bạn chạy tập lệnh này nó sẽ không làm việc, đây chỉ là một hiển thị 

đơn giản. Bây giờ bạn có thể thấy cách tạo một cái bánh pizza nhƣ thế nào bất cứ khi nào 

bạn muốn, bằng cách sử dụng những biến nhƣ: $dough1, $toppings1, $pizza1, $dough2, 

$toppings2, $pizza2, table1, table2. Bất cứ lúc nào một ngƣời yêu cầu một cái pizza bạn 

có thể gọi lớp pizza và một cái bánh sẽ đƣợc tạo ra. Và khi khác một ngƣời khác  yêu cầu 

một cái bánh bạn cũng làm nhƣ trên. 

Một vài chú ý: 

-  Đặt tên lớp là sử dụng trộn lẫn chữ hoa và chữ thƣờng. 

-  Nếu  muốn  một  hàm  có  thể  sử  dụng  ở  mọi  nơi,  ta  cần  khai  báo  function 

_construct(), khai báo nhƣ hàm đầu tiên trong lớp, đƣợc gọi là constructor 

-  Ví dụ 

function __construct()  

$this->tray = $round; 

  - 52 - 

-  $this->variable tƣơng tự nhƣ trong cú pháp mảng, $this có thể là một đối tƣợng 

đặt biệt đƣợc tạo ra. 

-  Bạn để ý rằng lớp của bạn bắt đầu với dòng biến ban đầu. Bạn cần khai báo một 

biến  trong  phạm  vi  một  lớp.  Bạn  khai  báo  biến  nhƣ “public,”  “private,”  hoặc 

“protected”. Biến public có thế thấy đƣợc ở bất kỳ lớp nào, biến private chỉ thấy 

trong lớp của nó, biến protected thấy trong lớp của nó và bất kỳ lớp nào mà có 

dòng mở rộng ở đầu. Nó có thể đồng ý để giữ hầu hết các biến của bạn nhƣ public, 

ngoại trừ những cái nào chứa thông tin cá nhân. 

-  Để tạo đối tƣợng, sử dụng từ khóa new 

Ví dụ:  

$table1 = new Pizza(); 

Điều này giữ tất cả các thông tin về bánh pizza trong biến $table1 

Để đơn giản, bạn tạo một hàm trong lớp của bạn mà nó gọi tất cả những hàm khác 

theo thứ tự bạn muốn. Nếu bạn đƣợc “carb-conscious” và  tránh trộn bột lẫn vào nhau, 

quyết định không nƣớng bánh pizza. Bạn có thể vẫn sử dụng lớp pizza không? Tất nhiên 

là đƣợc. Đơn giản, bạn chỉ gọi cách thức addToppings thay vì gọi makePizza. 

2.13.2.  Vì sao sử dụng OOP 

Sử dụng OOP có một vài lợi ích bao gồm một file đơn giản với những hàm trên 

nó. Đầu tiên, với OOP bạn có thể giữ những bit thông tin có liên quan với nhau và trình 

bày những nhiệm vụ phức tạp với dữ liệu đó. Thứ hai, bạn có thể xử lý dữ liệu không giới 

hạn thời gian mà không lo lắng về biến quá dài. Thứ ba, bạn có thể có nhiều ví dụ của 

những lớp chạy trong cùng thời gian mà những biến này không bị sửa hoặc đè lên. 

  - 53 - 

Chƣơng  3:  SỬ DỤNG PHP VỚI MYSQL 

Ở chƣơng 2, chúng ta đã tạo đƣợc trang Web với việc sử dụng những hàm. Nhƣng 

chúng ta chƣa thực sự hiểu mối quan hệ giữa MySQL và PHP. Trong chƣơng này chúng 

ta sẽ xét kỹ điều này. 

Trong chƣơng này nói đến các vấn đề: 

  Hiểu biết về cơ sở dữ liệu MYSQL. 

  Những dữ liệu chứa trong MySQL. 

  Tác động những thông tin đặc biệt, quyền từ Web site. 

  Phần mềm quản lý bảng dễ dàng. 

  Có thể sửa chữa code theo ý muốn. 

3.1.  Tổng quan về cấu trúc và cú pháp của MySQL. 

MySQL là hệ thống cơ sở dữ liệu quan hệ. Ý nghĩa cơ bản của MySQL là nó có thể 

lƣƣ trữ thông tin ở những vùng khác nhau và liên kết chúng lại với nhau. Chúng ta có thể 

chứa bất cứ thứ gì trong một cơ sở dữ liệu. Ví dụ nhƣ những thông tin liên quan đến một 

ngƣời: chẳng hạn nhƣ first name, last name, address, phone…. 

MySQL cho phép bạn tạo những thông tin riêng lẻ trên bảng hoặc những khu vực 

chứa thông tin thích hợp. Trong MySQL mỗi bảng bao gồm những trƣờng dữ liệu (field) 

riêng lẻ. 

3.1.1.  Cấu trúc MySQL 

Bởi vì MySQL là hệ  quản lý dữ liệu quan hệ, nó cho phép chúng ta tạo 

những bảng thông tin riêng, hoặc những vùng thông tin thích hợp. Trong hệ thống 

cơ sở dữ liệu không quan hệ, tất cả những thông tin đƣợc lƣu trữ trong một bảng lớn  

tạo nên những khó khăn trong việc sắp xếp và chỉ có thể chép dữ liệu mà bạn muốn. 

Trong SQL, mỗi bảng bao gồm những phần  riêng biệt, biễu diễn mỗi thông tin. 

Bạn có thể tạo ra cơ sở dựa trên những loại thông tin mà bạn lƣu trữ. Những 

bảng riêng biệt của MySQL liên kết với nhau nơi mà giá trị của vùng phổ biến là 

nhƣ nhau. 

Ví dụ: Cho rằng bảng bao gồm tên khách hàng, địa chỉ và số ID, bảng khác 

bao gồm số ID, nơi ở, ….Vùng chung là số ID, thông tin đƣợc lƣu trữ trong hai 

  - 54 - 

bảng riêng biệt sẽ liên kết với nhau nơi mà số ID là nhƣ nhau. Điều này cho chúng 

ta thông tin về khách hàng cùng lúc. 

3.1.2.  Các kiểu  dữ liệu 

Khi bạn tạo một bảng ban đầu, bạn cần nói với MySQL server kiểu nào của 

thông tin sẽ lƣu trữ trong mỗi bảng. Các kiểu khác nhau đƣợc cho trong bảng sau: 

Loại MySQL   Diễn tả  Ví dụ 

Char(length)  Mọi ký tự đều có thể là loại này, 

nhƣng có chiều dài cố định 

Trạng thái của khách hàng 

có 2 ký tự 

Varchar(length)  Mỗi ký tự đều có thể trong loại 

này,  dữ  liệu  có  thể  thay  đổi 

chiều dài từ 0 đến 255 ký tự. 

Địa chỉ của khách hàng có 

chữ  và  số,  thay  đổi  trong 

chiều dài 

Int(length)  Có  chiều  dài  từ -2147483648 

đến 2147483647. 

Số sản phẩm trao tay 

Int(length) 

unsigned 

 Lƣu  trữ  số  từ  0  đến 

4294967295. 

ID khách hàng 

Text  Kích thƣớc dữ liệu là 65536 ký 

tự. 

Cho  phép  đoạn  text  dài 

hơn  đƣợc  lƣu  trữ,  không 

có loại giới hạn đến 255 ký 

tự. 

Decimal(length, 

dec) 

Có thể lƣu trữ số thập phân  Giá cả 

Enum(“option1”,  

“option2”,.. 

Lƣu  trữ  giá  trị  chắc  chắn  nhƣ 

đúng hoặc sai 

Giới  tính  của  ngƣời  dùng 

nam hoặc nữ 

Date  Lƣu trữ ngày nhƣ yyyy-mm-dd  Ngày sinh nhật,… 

Time  Lƣu trữ giờ nhƣ hh:mm:ss  Giờ  một  hoạt  động  mới 

đƣợc đƣa vào trang Web 

Datetime  Lƣu trữ ngày và giờ nhƣ yyyy-mm-dd hh:mm:ss 

Ngày và giờ sau khi ngƣời 

đến thăm trang Web 

  - 55 - 

Mặc dù những loại trên đáp ứng đƣợc nhu cầu cần thiết, một bảng các kiểu 

cho dƣới đây cũng thƣờng gặp. 

Loại MySQL  Diễn giải 

tinyint(length)  Lƣu trữ số nguyên từ -128 đến 127 (thêm tham số unsigned 

thì cho phép lƣu trữ từ 0 đến 255) 

smallint(length)  Lƣu  trữ  số  nguyên  từ -32768  đến  32767  (thêm  tham  số 

unsigned thì cho phép lƣu trữ từ 0 đến 65535) 

loại MySQL  Diễn giải 

mediumint(length)  Lƣu  trữ  số  từ -8388608  đến  8388607  (thêm  tham  số 

unsigned cho phép lƣu trữ từ 0 đến 16777215) 

bigint(length)  Lƣu  trữ  số  từ  -9223372036854775808  đến  -9223372036854775807  (nếu  thêm  tham  số  unsigned  cho 

phép lƣu trữ từ 0 đến 184467440709551615) 

Tinytext  Cho phép lƣu trữ trên 255 ký tự 

mediumtext  Cho phép lƣu trữ trên 1677215 ký tự 

longtext  Cho phép lƣu trữ trên 4294967295 ký tự 

Blob  Bằng với kiểu text, trừ trƣờng hợp dƣơng khi sắp xếp và so 

sánh, cho phép lƣu trữ trên 65535 ký tự 

tinyblob  Bằng với kiểu tinytext, trừ trƣờng hợp dƣơng khi sắp xếp 

và so sánh 

mediumblob  Bằng với kiểu mediumtext, trừ trƣờng hợp dƣơng khi sắp 

xếp và so sánh 

longblob  Bằng với kiểu longtext, trừ trƣờng hợp dƣơng khi sắp xếp 

và so sánh 

year(length)  Lƣu trữ một năm trong 4 ký tự mặc định. 

3.1.3.  Lựa chọn kiểu cho đúng  

Trƣớc tiên, trƣờng sẽ chứa cả chữ và số? 

  - 56 - 

Nếu trả lời có nhƣ varchar, text, char, tinytext, mediumtext, longtext, blob, 

tinyblob,  mediumblolb,  longblob. Sau đó cần quan tâm có bao nhiêu ký tự đƣợc 

lƣu trữ? Nó sẽ biến đổi thế nào? 

  Có bao nhiêu ký tự đƣợc lƣu trữ? Thay đổi thế nào? 

  0 đến 255 ký tự, chiều dài thay đổi: sử dụng varchar nếu bạn muốn xóa 

tất cả những khoảng trắng, giá trị mặc định. Sử dụng longtext nếu bạn 

thay đổi về chiều dài. Sử dụng blob nếu bạn không giữ về khoảng cách. 

  256->65536 ký tự: Sử dụng text nếu bạn không cần trƣờng hợp dƣơng 

trong tìm kiếm, sắp xếp, so sánh. Dùng blob nếu cần trƣờng hợp dƣơng. 

  65537->1677215 ký tự: Sử dụng mediumtext nếu bạn không cần trƣờng 

hợp dƣơng trong tìm kiếm, sắp xếp, so sánh. Dùng mediumblob nếu cần 

trƣờng hợp dƣơng. 

  1677216->4294967295  ký  tự:  Sử  dụng  longtext  nếu  bạn  không  cần 

trƣờng hợp dƣơng trong tìm kiếm, sắp xếp, so sánh. Dùng longblob nếu 

cần trƣờng hợp dƣơng 

Nếu trả lời có thì có lẽ chứa chữ cái và số, nhƣng phải một trong số có giới 

hạn về giá trị enum 

Nếu trả lời không, nó bao gồm thời gian, ngày tháng 

3.1.4.  NULL/NOT NULL 

My SQL server của bạn muốn biết vùng dữ liệu của bạn có rỗng hay không, 

bạn dùng NULL hoặc NOT NULL. Nếu vùng dữ liệu đƣợc định nghĩa là NOT 

NULL thì ngƣời dùng bắt buộc phải nhập dữ liệu vào. Nếu dùng NULL thì vùng dữ 

liệu sẽ không chứa giá trị gì hết. 

3.1.5.  INDEXES 

MySQl sử dụng INDEXES để giải quyết việc nghiên cứu dòng thông tin. 

INDEXES làm việc thế nào? Bạn tƣởng tƣợng bạn có một cái phòng đầy ắp, toàn 

những thứ bạn có đƣợc mà chƣa bao giờ bạn đụng đến. Bạn muốn tìm lại thông tin 

gì đó, bạn phải mất khá nhiều thời gian để làm việc này. Bạn cảm thấy khó chịu và 

bạn bắt đầu sắp xếp chúng, tổ chức lại chúng. 

  - 57 - 

Bạn thử tƣởng tƣợng lƣợng thông tin đƣợc lƣu trữ trong bảng, vào thời gian 

nào đó bạn cần tìm vài thứ, bạn bắt đầu tìm tất cả những dòng, bạn sẽ làm gì nếu 

có 10000 dòng? Chuyện gì sẽ xảy ra? 

Bằng cách sử dụng hệ thống chọn lọc bên trong, MySQl sẽ giúp bạn tìm 

nhanh chóng và chính xác, nó làm đƣợc điều này nhờ sử dụng INDEXES, cũng 

đƣợc biết nhƣ một khóa. 

MySQL yêu cầu INDEX trong mỗi bảng, vì thế có vài thứ đƣợc đến. Thông 

thƣờng, bạn sử dụng khóa chính, hoặc tạo ra sự duy nhất để giữ dữ liệu riêng lẻ. 

Trƣờng này phải “not null” và “unique” 

3.1.6.  UNIQUE 

Chúng ta có thể sử dụng UNIQUE để thể hiện tính độc quyền, không thể 

chèn thêm dữ liệu, khi thêm vào chƣơng trình sẽ báo lỗi. 

3.1.7.  Tăng tự động(auto Increment) 

Bạn  có    thể  thiết  kế  vùng  tăng  tự  động    bằng  cách  dùng  lệnh 

Auto_Increment, ta có thể đặt lệnh cho bất cứ vùng nào  trong bảng. 

3.1.8.  Những tham số khác 

Bạn có thể làm những chí định khác khi tạo cơ sở dữ liệu, nhƣng tốt hơn cho 

ngƣời sử dụng. Để biết thêm về danh sách những tham số, bạn có thể tham khảo 

thêm :www.mysql.com 

3.1.9.  Các kiểu bảng của My SQl và kỹ thuật lƣu trữ 

Những phiên bản mới gần đây của My SQL thƣờng sử dụng 5 loại chính 

      . MyISAM 

. MERGE 

. MEMORY  

. InnoDB 

. BDB 

3.1.10.  Lệnh và cú pháp trong My SQL 

Các lệnh và cấu trúc của MySQL thƣờng dùng: 

  . CREATE: Tạo mới một cơ sở dữ liệu hoặc một bảng 

  . ALTER: Thay đổi bảng 

  - 58 - 

  . SELECT: Chọn dữ liệu 

  . DELETE: Xóa dữ liệu từ bảng 

  . DESCRIBE: Cho biết cấu trúc và chi tiết của bảng 

  . INSERT INTO tablename VALUES: Đặt giá trị vào  bảng 

  . UPDATE: Sửa đổi dữ liệu trong bảng 

  . DROP: Xóa toàn bộ bàng hoặc cơ sở dữ liệu 

3.2.  Bắt đầu với My SQL và PHP nhƣ thế nào? 

  Một vài hàm thƣờng dùng là: 

   mysql_connect ("hostname", "user", "pass"): Kết nối đến MY SQL 

server. 

   mysql_select_db("database  name"):  Tƣơng  đƣơng  với  lệnh  USE 

trong My SQL, làm cho cơ sở dữ liệu đƣợc chọn hoạt động 

   mysql_query("query"): Gởi bất kỳ câu lệnh của My SQL đến server 

   mysql_fetch_rows("biến kết quả từ truy vấn"): Trả về một dòng kết 

quả trong một dữ liệu truy vấn 

   mysql_fetch_array("biến kết quả từ truy vấn"): Trả về nhiều dòng 

kết quả của truy vấn 

   mysql_error(): Đƣa ra lỗi đƣợc trả về từ My SQL server 

  Bạn có thể gởi bất kỳ My SQL nào đến server thông qua câu lệnh PHP hoặc câu 

lệnh Mysql_query. 

Ví dụ: 

  $query = “SELECT * from TABLE”; 

$results = mysql_query($query); 

Bạn cũng có thể dùng nhƣ sau: 

$results = mysql_query(“SELECT * from TABLE”); 

3.3.  Kết nối MY SQL Server 

  Lệnh kết nối với hàm PHP là mysql_connect, với cú pháp nhƣ sau: 

    $host = “localhost”; 

$user = “bp5am”; 

$pass = “bp5ampass”; 

  - 59 - 

$connect = mysql_connect($host, $user, $pass); 

  Trong đó : 

     $host là tên của máy chủ 

             $user:tên của máy ngƣời dùng 

    $pass:mật khẩu truy cập của ngƣời dùng 

3.4.  Đọc, tạo cơ sở dữ liệu 

  Để tạo một cơ sở dữ liệu cho bạn cần 3 bảng: 

  Một bảng movie: Ta sẽ lƣu trữ tên và thông tin của movie. 

  Một bảng movietype: Nơi lƣu trữ những catalog của movie. 

  Một bảng people: Ta sẽ lƣu trữ tên của các diễn viên và đạo diễn. 

Ví dụ tạo cơ sở dữ liệu và bảng 

  Tạo trang php với tên: createmovie.php 

<?php 

//connect to MySQL; note we‟ve used our own parameters- 

you should use 

//your own for hostname, user, and password 

$connect = mysql_connect(“localhost”, “root”, “”) or 

die (“Hey loser, check your server connection.”); 

//create the main database if it doesn‟t already exist 

$create  =  mysql_query(“CREATE  DATABASE  IF  NOT 

EXISTS moviesite”) or die(mysql_error()); 

//make sure our recently created database is the active one 

mysql_select_db(“moviesite”); 

//create “movie” table 

$movie = “CREATE TABLE movie ( 

movie_id int(11) NOT NULL auto_increment, 

movie_name varchar(255) NOT NULL, 

movie_type tinyint(2) NOT NULL default 0, 

movie_year int(4) NOT NULL default 0, 

movie_leadactor int(11) NOT NULL default 0, 

movie_director int(11) NOT NULL default 0, 

  - 60 - 

PRIMARY KEY (movie_id), 

KEY movie_type (movie_type,movie_year))”; 

$results = mysql_query($movie) 

or die (mysql_error()); 

//create “movietype” table 

$movietype = “CREATE TABLE movietype ( 

movietype_id int(11) NOT NULL auto_increment, 

movietype_label varchar(100) NOT NULL, 

PRIMARY KEY (movietype_id))”; 

$results = mysql_query($movietype) 

or die(mysql_error()); 

//create “people” table 

$people = “CREATE TABLE people ( 

people_id int(11) NOT NULL auto_increment, 

people_fullname varchar(255) NOT NULL, 

people_isactor tinyint(1) NOT NULL default 0, 

people_isdirector tinyint(1) NOT NULL default 0, 

PRIMARY KEY (people_id))”; 

$results = mysql_query($people) 

or die(mysql_error()); 

echo “Movie Database successfully created!”; 

?> 

Tiếp theo ta tạo trang php với tên: moviedata.php 

    <?php 

//connect to MySQL 

$connect = mysql_connect(“localhost”, “root”, “”) 

or die (“Hey loser, check your server connection.”); 

//make sure we‟re using the right database 

mysql_select_db(“moviesite”); 

//insert data into “movie” table 

  - 61 - 

$insert  =  “INSERT  INTO  movie  (movie_id,  movie_name, 

movie_type, “ . 

“movie_year, movie_leadactor, movie_director) “ . 

“VALUES (1, „Bruce Almighty‟, 5, 2003, 1, 2), “ . 

“(2, „Office Space‟, 5, 1999, 5, 6), “ . 

“(3, „Grand Canyon‟, 2, 1991, 4, 3)”; 

$results = mysql_query($insert) 

or die(mysql_error()); 

//insert data into “movietype” table 

$type  =  “INSERT  INTO  movietype  (movietype_id, 

movietype_label) “ . 

“VALUES (1,‟Sci Fi‟), “ . 

“(2, „Drama‟), “ . 

“(3, „Adventure‟), “ . 

“(4, „War‟), “ . 

“(5, „Comedy‟), “ . 

“(6, „Horror‟), “ . 

“(7, „Action‟), “ . 

 “(8, „Kids‟)” ; 

$results = mysql_query($type) 

or die(mysql_error()); 

//insert data into “people” table 

$people =  “INSERT  INTO people (people_id, people_fullname,  “ 

.“people_isactor, people_isdirector) “ . 

“VALUES (1, „Jim Carrey‟, 1, 0), “ . 

“(2, „Tom Shadyac‟, 0, 1), “ . 

“(3, „Lawrence Kasdan‟, 0, 1), “ . 

“(4, „Kevin Kline‟, 1, 0), “ . 

“(5, „Ron Livingston‟, 1, 0), “ . 

“(6, „Mike Judge‟, 0, 1)”; 

$results = mysql_query($people) 

  - 62 - 

or die(mysql_error()); 

echo “Data inserted successfully!”; 

?> 

Chúng làm việc nhƣ thế nào? 

Đầu tiên ta thực hiện kết nối đến My SQL server, sau đó tạo lập cơ sở dữ 

liệu nếu không tạo đƣợc sẽ đƣa ra thông  báo lỗi. 

Sau đó bắt đầu tạo từng bảng riêng lẻ 

Đƣa dữ liệu vào các bảng 

3.5.  Truy vấn cơ sở dữ liệu 

  Chúng ta đã tạo ra cơ sở dữ liệu, bây giờ muốn nhận lại thông tin từ dữ liệu đó, 

dùng công thức nhƣ sau: 

SELECT [fieldnames] 

AS [alias] 

FROM [tablename] 

WHERE [criteria] 

ORDER BY [fieldname to sort on] [DESC] 

LIMIT [offset, maxrows] 

  SELECT [fieldnames]: Quyết định đầu tiên mà vùng chứa tên đặc biệt 

mà bạn muốn nhận lại. Nếu bạn muốn thấy tất cả thông tin bạn chỉ cần 

chọn dấu *  

  AS: Bạn có thể sử dụng bí danh để nhóm hai hoặc nhiều hơn hai vùng 

khác nhau mà có thể chuyển đến chúng * nhƣ là một biến lớn 

SELECT first_name, last_name AS full_name. . . ORDER BY full_name . . . 

Bạn không thể sử dụng tham số AS với tham số WHERE, bởi vì nó bị giới hạn trong 

MY SQL. Khi WHERE được thực thi thì cột giá trị không biết 

  FROM: Tên bảng cần truy xuất thông tin 

  WHERE: Danh sách điều kiện chọn lọc dữ liệu 

  ORDER BY: Để sắp xếp dữ liệu trong vùng 

  LIMIT: Giới hạn kết quả trả về 

  - 63 - 

3.5.1.  WHERE , oh WHERE 

  Đƣa ra điều kiện để hiển thị thông tin mà bạn cần   

    SELECT * FROM customers WHERE gender = “Male” 

Trả về tất cả các thông tin khách hàng có giới tính “Nam” 

Các phép toán so sánh trong câu lệnh WHERE: 

  =,<,>,>=,<=,!= 

  LINE và %: So sánh một phần của đoạn code với đoạn chứa nó, xuất ra tất 

cả những mẫu tin có liên quan đến nó. 

Ví dụ: 

    SELECT * FROM products WHERE description LIKE “%shirt%” 

Ở đây sẽ đƣa ra tất cả những phần có chứa „shirt‟. 

Ví dụ về sử dụng truy vấn SELECT: Mở trình soạn thảo nhập đoạn mă và lƣu lại 

với tên select.php. 

    <?php 

//connect to MySQL 

$connect = mysql_connect(“localhost”, “bp5am”, “bp5ampass”) 

or die(“Hey loser, check your server connection.”); 

//make sure we‟re using the right database 

mysql_select_db(“moviesite”); 

$query = “SELECT movie_name, movie_type “ . 

“FROM movie “ . 

“WHERE movie_year>1990 “ . 

“ORDER BY movie_type”; 

$results = mysql_query($query) 

or die(mysql_error()); 

while ($row = mysql_fetch_array($results))  

extract($row); 

echo $movie_name; 

echo “ - “; 

echo $movie_type; 

  - 64 - 

echo “<br>”; 

?> 

Sau khi chạy chƣơng trình ta sẽ thấy giao diện màn hình nhƣ Hinh 3.5.0.2 

Hinh 3.5.0.3 

Chúng làm việc nhƣ thế nào? 

Khi chúng ta muốn lấy thông tin tên, ta có: 

  SELECT *FROM 

Nhƣng thay vì bạn viết: 

  $query=”SELECT movie_name, movie_type” 

Kế đến, chúng ta muốn lấy thông tin từ bảng nào 

  “FROM movie” 

Sau đó, ta đƣa điều kiện muốn thấy thông tin từ năm 1990 trở lên: 

  WHERE movie_year>1990” 

Bạn cần kết quả xuất ra đƣợc sắp xếp theo thứ tự bạn muốn: 

  ORDER BY movie_type; 

Kế đó, chúng ta tập hợp tất cả những dòng theo yêu cầu đã đƣa ra của bạn: 

  $results mysql_query($query) 

    Ordie(mysql_error()); 

  - 65 - 

Sau đó, chúng ta  kết hợp đƣa ra kết quả với những dòng: 

  while ($row = mysql_fetch_array($results))  

extract($row); 

echo $movie_name; 

echo " - "; 

echo $movie_type; 

echo "<br>"; 

Ghi chú với mỗi dòng tìm thấy, bạn lƣu trữ bảng này trong một mảng $row, sử 

dụng hàm mysql_fetch_array(), sau đó giải các biến trong $row, sử dụng hàm extract, 

xuất ra những gì bạn cần. 

3.5.2.  Làm việc với PHP và mảng dữ liệu: foreach 

Hàm foreach tƣơng tự nhƣ hàm While, nếu sử dụng while kết hợp thông qua 

một danh sách kết quả từ truy vấn 

foreach ($row as $value)  

echo $value; 

echo “<br>”; 

Ví dụ về việc sử dụng foreach. Mở tập select.php sửa đổi lại nhƣ sau. 

<?php 

//connect to MySQL 

$connect = mysql_connect("localhost", "root", "") 

or die("Hey loser, check your server connection."); 

//make sure we're using the right database 

mysql_select_db("moviesite"); 

$query = "SELECT movie_name, movie_type " ."FROM movie "; 

$results = mysql_query($query) 

or die(mysql_error()); 

//while ($row = mysql_fetch_array($results,MYSQL_ASSOC)){ 

  - 66 - 

while ($row = mysql_fetch_assoc($results))  

foreach ($row as $val1) 

 { 

echo $val1; 

echo "     "; 

echo "<br>"; 

//extract($row); 

//echo $movietype_id; 

//echo " - "; 

//echo $movietype_label; 

?> 

Sau khi cho chạy chƣơng trình, giao diện nhƣ Hinh 3.5.2.1 

:       

Hinh 3.5.2.1 

Nó làm việc thế nào: 

Ghi chú:Ở đây có sử dụng 

  while ($row = mysql_fetch_assoc($results)) 

 { 

foreach ($row as $val1)  

  - 67 - 

echo $val1; 

echo “ “; 

So với phần trƣớc, dùng hàm  

while ($row = mysql_fetch_array($results))  

extract($row); 

echo $movie_name; 

echo “ - “; 

echo $movie_type; 

echo “<br>”; 

Dùng hàm foreach ta thấy ngắn gọn hơn , nó xuất tất cả thông tin liên quan 

mà khôn cần dùng lệnh echo để chỉ định. 

Một  điều  cần  chú  ý  nữa  là  nếu  ta  sử  dụng  lệnh:  while  ($row  = 

mysql_fetch_array($results))  thay  cho  câu  lệnh  :while  ($row  = 

mysql_fetch_assoc($results)) thì kết quả sẽ xuất ra 2 lần. 

Để  khắc  phục  tình  trạng  này  ta  dùng: 

mysql_fetch_array($results,MYSQL_ASSOC) hoặc mysql_fetch_assoc 

  Sử dụng fereach để tạo một mảng 

    Ví dụ. select2.php  

'      <?php 

//connect to MySQL 

$connect = mysql_connect("localhost", "root", "") 

or die("Hey loser, check your server connection."); 

//make sure we‟re using the right database 

mysql_select_db("moviesite"); 

$query = "SELECT * " . 

"FROM movie " . 

  - 68 - 

"WHERE movie_year>1990 " . 

"ORDER BY movie_type"; 

$results = mysql_query($query) 

or die(mysql_error()); 

echo "<table border=\"1\">

"; 

while ($row = mysql_fetch_assoc($results))  

echo "<tr>

"; 

foreach($row as $value) 

 { 

echo "<td>

"; 

echo $value; 

echo "</td>

"; 

echo "</tr>

"; 

echo "</table>

"; 

?> 

Kết quả sau khi chạy nhƣ Hinh 3.5.2.2 

Hinh 3.5.2.2 

Ở đây làm việc thế nào? 

  - 69 - 

Bạn  sử  dụng  mệnh  mysql_query  và  while  để  phục  hồi  lại  lĩnh  vực  của 

bạn.Sau đó, với mỗi giá trị bạn nhận lại, bạn đặt nó ở mỗi ô phân cách và kết 

chúng lại trong html và echo 

3.5.3.  Liên hệ giữa 2 bảng 

Bạn có thể lấy thông tin từ nhiều bảng theo hai cách: 

-  Chuyển  đến  những  bảng  riêng  biệt  trong  truy  vấn  của  bảng  và  liên  kết 

chúng ttrong một vùng chung tạm thời. 

-  Sử dụng công thức JOIN trong truy vấn của bạn đối với những bảng riêng 

biệt. 

Dùng câu lệnh SELECT để phân biệt giữa hai bảng trong dữ liệu của bạn, kết nối 

chúng trong một bảng mới. 

$query = “SELECT customers.name, orders.order_total 

FROM customers, orders 

WHERE customers.cust_ID = orders.cust_ID”; 

//trả về tên khách hàng từ bảng khách hàng và order_total từ bảng order nơi mà 

cust_ID trong bảng customers bằng với cust_ID trong bảng order. 

Ví dụ : select21.php 

  <?php 

//connect to MySQL 

$connect = mysql_connect("localhost", "root", "") 

or die ("Hey loser, check your server connection."); 

//make sure we‟re using the right database 

mysql_select_db("moviesite"); 

$query  =  "SELECT  movie.movie_name, 

movietype.movietype_label " . 

"FROM movie, movietype " . 

"WHERE movie.movie_type = movietype.movietype_id " . 

"AND movie.movie_year>1990 " . 

"ORDER BY movie_type"; 

$results = mysql_query($query) 

or die(mysql_error()); 

  - 70 - 

echo "<table border=\"1\">

"; 

while ($row = mysql_fetch_assoc($results)) 

 { 

echo "<tr>

"; 

foreach($row as $value) 

 { 

echo "<td>

"; 

echo $value; 

echo "</td>

"; 

echo "</tr>

"; 

echo "</table>

"; 

?> 

Kết quả nhƣ Hinh 3.5.3 

:       

Hinh 3.53  

Ghi chú: 

Ở đây có hai vùng đƣợc liên kết với nhau thông qua WHERE, những số id 

từ hai bảng khác nhau (movie_type trong bảng movie và movietype_id trong bảng 

movietype) đƣợc liên kết với nhau . 

3.5.4.  Kết nối hai bảng (Join two tables) 

Cũng  giống  nhƣ  phần  kết  hợp  hai  bảng ở  trên, nhƣng  ở  đây    câu  lệnh 

SELECT  là: 

    SELECT movie_name, movietype_label. 

  - 71 - 

Bạn muốn cập nhật dữ liệu loại nào dùng câu lệnh: 

    FROM movie 

LEFT JOIN movietype 

Dùng câu lệnh trên có nghĩa đơn giản là movietype phụ thuộc vào movie. 

Sau đó bạn gửi đến server vùng nào cần kết nối nhƣ sau: 

    ON movie_type = movietype_id. 

Ví dụ : select22.php 

<?php 

//connect to MySQL 

$connect = mysql_connect("localhost", "root", "") 

or die ("Hey loser, check your server connection."); 

//make sure we‟re using the right database 

mysql_select_db("moviesite"); 

$query = "SELECT movie_name, movietype_label ". 

"FROM movie ". 

"LEFT JOIN movietype ". 

"ON movie_type = movietype_id ". 

"WHERE movie.movie_year>1990 ". 

"ORDER BY movie_type"; 

$results = mysql_query($query) 

or die(mysql_error()); 

echo "<table border=\"1\">

"; 

while ($row = mysql_fetch_assoc($results)) 

 { 

echo "<tr>

"; 

foreach($row as $value) 

 { 

echo "<td>

"; 

echo $value; 

echo "</td>

"; 

  - 72 - 

echo "</tr>

"; 

echo "</table>

"; 

?> 

Kết quả nhƣ Hinh 3.5.4 : 

Hinh 3.5.4   

Bạn thấy kết quả giống nhƣ phần trên.Bạn làm điều này trong dòng đầu tiên 

của mệnh đề SELECT: 

    SELECT movie_name, movietpe_label 

Sau đó bạn gọi đến Mysql những bảng nào ban muốn cập nhật và loại nào 

bạn muốn kết hợp với nhau trong mệnh đề sau: 

    FROM movie 

LEFT JOIN movietype 

Bạn dùng  LEFT  kết hợp những  mệnh đề  trong trƣờng hợp này.Bạn lấy 

trông tin chính từ movie và tham chiếu thông tin từ movietype 

3.6.  Help Tips và Suggestions 

3.6.1.  Việc cung cấp tài liệu 

3.6.2.  Việc sử dụng PHPMyAdmin 

Nó dễ dàng cho làm những công việc sau: 

-  Cắt và tạo CSDL 

-  Tạo , xóa bảng. 

-  Tạo, xóa vùng. 

  - 73 - 

-  Nhập bất kỳ câu lệnh MySQL nào. 

-  Xem và in câu trúc bảng. 

-  Mã PHP tổng quát. 

-  Xem dữ liệu trong bảng. 

  - 74 - 

Chƣơng  4:  SỬ DỤNG BẢNG ĐỂ TRÌNH BÀY DỮ LIỆU 

  Chúng ta có thể thành công trong việc kết hợp PHP và MySQL để tạo ra trang 

web động, khi có nhiều dòng dữ liệu cần trình bày, chúng ta cần phải có cơ chế để ngƣời 

xem dễ dàng đọc dữ liệu và cần phải đẹp, ngắn gọn, trình bày rõ ràng. Phƣơng pháp dễ 

nhất là sử dụng bảng. 

  Trong chƣơng này chúng ta sẽ biết: 

-  Tạo bảng để tổ chức dữ liệu từ cơ sở dữ liệu. 

-  Tạo tiêu đề cột tự động. 

-  Bảng thông dụng với kết quả truy vấn MySQL cơ bản. 

-  Bảng thông dụng với kết quả truy vấn MySQL phức tạp. 

-  Tạo trang thân thiện cho ngƣời dùng 

4.1.  Tạo bảng 

Khi có một danh sách dữ liệu, cần phải đặt cấu trúc, tiêu đề cột, định dạng bảng. 

Ví dụ: định nghĩa tiêu đề bảng:Mở trinh soạn thảo nhập đoạn mã và lƣu với tên 

table.php. 

<?php 

$movie=<<<EOD 

<h2><center>Movie Review Database</center></h2> 

<table 

cellspacing="2"> 

<tr> 

<th>Movie Title</th> 

<th>Year of Release</th> 

<th>Movie Director</th> 

<th>Movie Lead Actor</th> 

<th>Movie Type</th> 

</tr> 

</table> 

EOD; 

  - 75 - 

echo $movie; 

?> 

  Kết quả nhƣ Hình 4.1.1 

Hình 4-1.1 

Tất cả đoạn mã nằm bên trong<<<EOD và EOD thì chứa trong biến $table vì thế, 

thay vì in mỗi thành phần của bảng HTML thì nên thêm biến $table. Nhân tiện nó thêm 

vào khung cho bảng  để tiện việc trình bày. 

Sau đó xuất nội dung đơn giản của biến $table. Cuối cùng chúng ta đóng PHP bằng 

thẻ đóng ?>. 

Bằng việc sử dụng 2 thẻ ta có thể sử dụng mã HTML đơn giản. 

Nhƣ đã đề cập ở chƣơng 2 về việc sử dụng heredoc ta có thể thay thế thẻ <<<EOD 

bằng bất cứ chuỗi nào mà ta muốn nhƣng bắt đầu và kết thúc phải phù hợp. 

Chú ý: 

Ở đây không có khoảng cách sau =<<<EOD và thẻ EOD, không có khoảng cách 

nào giữa các dòng, thục lề hoặc bất kỳ ký tự nào trong dòng thẻ đóng heredoc. Nếu có bất 

kỳ khoảng trống nào thì nó sẽ báo lỗi. Do đó luôn luôn nhớ rằng phải xóa tất cả các 

khoảng cách sau các thẻ đó. 

4.2.  Bảng thƣờng dùng 

Ví dụ: Điền dữ liệu vào bảng: 

Bởi vì đây là một đoạn mã lớn nên tất những thay đổi đều có đƣợc thể hiện rõ rệt. 

Một vài thứ đƣợc lấy ra từ tập lệnh gốc. 

  - 76 - 

Mở file table1.php và sửa lại mã. Chúng ta sử dụng lại dữ liệu ở chƣơng 3 cho ví dụ 

này. Phải nhớ tên server, tên ngƣời dùng, mật khẩu, tên cơ sở dữ liệu với những giá trị 

của bạn: 

  <?php 

$link = mysql_connect(“localhost”,”root”,””) 

or die(mysql_error()); 

mysql_select_db(“moviesite”) 

or die (mysql_error()); 

Bắt đầu kết nối cơ sở dữ liệu: 

$query = “SELECT movie_name, movie_director, movie_leadactor “ . 

“FROM movie”; 

$result = mysql_query($query, $link) 

or die(mysql_error()); 

$num_movies = mysql_num_rows($result); 

  Chạy một truy vấn SQL dựa vào cơ sở dữ liệu và lấy kết quả. Và trong lúc đó xem 

có bao nhiêu mẫu tin đƣợc trả về từ truy vấn. 

  Nhƣ đã thảo luận ở chƣơng 3 ta đặt SQL là chữ hoa. Điều này dễ thực hiện bởi vì 

nó cho phép bạn dễ dàng nhận biết tên cột và từ khóa SQL. Nó cũng thực hiện tốt việc 

tạo truy vấn SQL dễ đọc hơn. Nó cũng giải thích tại sao chúng ta đƣợc viết truy vấn SQL 

trên dòng server. 

$movie_header =<<<EOD 

<h2><center>Movie Review Database</center></h2> 

<table width=”70%” border=”1” cellpadding=”2” 

cellspacing=”2” align=”center”> 

<tr> 

<th>Movie Title</th> 

<th>Movie Director</th> 

<th>Movie Lead Actor</th> 

</tr> 

EOD; 

  - 77 - 

Sau đó nhập đoạn mã vào gốc(trừ mệnh đề echo) 

Chú ý nó thật sự đã gọi là $movie_header không phải là $movie 

$movie_details = „‟; 

while ($row = mysql_fetch_array($result)) 

 { 

$movie_name = $row[„movie_name‟]; 

$movie_director = $row[„movie_director‟]; 

$movie_leadactor = $row[„movie_leadactor‟]; 

$movie_details .=<<<EOD 

<tr> 

<td>$movie_name</td> 

<td>$movie_director</td> 

<td>$movie_leadactor</td> 

</tr> 

EOD; 

$movie_details .=<<<EOD 

<tr> 

<td>&nbsp;</td> 

</tr> 

<tr> 

<td>Total :$num_movies Movies</td> 

</tr> 

EOD; 

Hoạt động: 

Trong đoạn mã trƣớc nó làm việc khá nhiều, vì vậy chúng ta xem xét chi tiết hơn. 

Bạn biết rằng, dòng lặp của mệnh đề while thông qua những mẫu tin đã đƣợc trả về, 

đối với mỗi mẫu tin nó thực hiện một khối đoạn mã trong dấu ngoặc. Đừng lo lắng PHP 

đủ thông minh để biết có bao nhiêu mẫu tin và số mẫu tin hiện hành trong trƣờng hợp 

này. Ở đây không có sự nguy hiểm cho việc ấn định giá trị sai cho mẫu tin. 

  - 78 - 

Dòng đầu tiên của vòng lặp while, nói rằng các tập lệnh đƣợc viết ra là giá trị của 

cột movie_name trong mẫu tin hiện hành và đặt vào một biến là $movie_name. Bốn dòng 

tiếp theo làm những việc tƣơng tự, chúng đơn giản ấn định giá trị tên của cột khác cho 

những tên biến khác. Sau đó, bạn đến thẻ tƣơng tự nhƣ cái bạn đã thấy khi bắt đầu 

chƣơng  này.  Nó không  hoàn  toàn  giống  nhƣ  trƣớc  bởi  vì  nó  có  .=<<<EOD  thay  vì 

=<<<EOD. Vì vậy, thay vì chỉ có một giá trị mẫu tin, $movie_details chứa tất cả các giá 

trị mẫu tin đƣợc trả về, sau đó kết thúc là tổng số của những  hình ảnh trong dữ liệu của 

bạn. 

Bằng việc thêm vào dấu chấm (.) trƣớc dấu =<<<EOD là bạn đang thêm giá trị 

„existing‟ với giá trị „current‟ của biến $movie_details. Nếu bạn quên thêm dấu chấm (.), 

sau đó bạn thay thế giá trị „existing‟ với giá trị „current‟. Bởi vì trong PHP $var=”1” có 

nghĩa là gán cho $var có giá trị là 1 và $var.=”1” có nghĩa là”lấy giá trị hiện hành của 

$var và thêm 1 cho nó”. Trong ví dụ trƣớc chú ý rằng bạn đã ấn định tên của phim cho 

$movie_name và sau đó sử dụng $movie_name  thay vì làm nhƣ sau: 

while ($row = mysql_fetch_row($result)) 

 { 

$movie_details .=<<<EOD 

<tr> 

<td>$row[„movie_name‟]</td> 

</tr> 

EOD; 

Trong đoạn trƣớc, mọi thứ chính xác nhƣ nhau nhƣng nó sẽ giới hạn  nếu bạn muốn 

định dạng bất kỳ giá trị biến nào.  

  Thực hành, gôm nó tất cả lại với nhau. 

  Dữ liệu đƣợc nhận lại bây giờ nhƣng bạn cần gửi đến tất cả các trình duyệt vì vậy 

nó sẽ đƣợc trình bày trong bảng. 

  Bạn ấn định $movie_footer bằng cách nhập dòng sau: 

$movie_footer =”</table>”; 

$movie =<<<MOVIE 

$movie_header 

  - 79 - 

$movie_details 

$movie_footer 

MOVIE; 

echo “There are $num_movies movies in our database”; 

echo $movie; 

?> 

  Trong đoạn mã trƣớc bạn lƣu file này với tên table1.php, sau đó load lên server 

  Sau đó bạn sẽ thấy nhƣ Hình 4.2.1. 

Hình 4.2.1. 

  Cách thức hoạt động: 

  Đầu  tiên  đoạn  mã  của  bạn  lấy  thông  tin  lƣu  trữ  trong  $movie_header, 

$movie_footer, và cuộn tất cả lên và đặt nó trong $movie với việc sử dụng heredoc. Sau 

đó có những dòng sau: 

  echo “There are $num_movies movies in our database”; 

echo $movie; 

  Bạn in ra câu lệnh có bao nhiêu phim trong cơ sở dữ liệu và sau đó gửi tất cả các 

biến $movie_header, $movie_details, and $movie_footer với dòng tiếp theo 

  Bảng này nhìn trông cũng đẹp, nhƣng trong chƣơng 3 nó không làm cho ngƣời 

dùng tốt nếu họ không có ngƣời giải mã bí mật để hƣớng dẫn cho họ biết mối liên hệ giữa 

diễn viên và đạo diễn trong phim. Bạn cần liên kết những bảng của bạn để điền đầy đủ 

thông tin. 

  Ví dụ: Phát triển bảng 

  - 80 - 

  Trong bài tập này bạn liên kết các bảng lại với nhau nhƣ bạn thấy trong chƣơng 3, 

bạn có thể xuất đầy đủ thông tin dữ liệu. 

  Sửa file table1.php nhƣ sau lƣu lại với tên table2.php 

<?php 

$link = mysql_connect(“localhost”,”root”,””) 

or die(mysql_error()); 

mysql_select_db(“moviesite”) 

or die (mysql_error()); 

$query = “SELECT movie_name, movie_director, movie_leadactor “ . 

“FROM movie”; 

$result = mysql_query($query, $link) 

or die(mysql_error()); 

$num_movies = mysql_num_rows($result); 

$movie_header=<<<EOD 

<h2><center>Movie Review Database</center></h2> 

<table width=”100%” border=”1” cellpadding=”2” 

cellspacing=”2” align=”center”> 

<tr> 

<th>Movie Title</th> 

<th>Movie Director</th> 

<th>Movie Lead Actor</th> 

</tr> 

EOD; 

function get_director() 

 { 

global $movie_director; 

global $director; 

$query_d = “SELECT people_fullname “ . 

“FROM people “ . 

“WHERE people_id=‟$movie_director‟”; 

$results_d = mysql_query($query_d) 

  - 81 - 

or die(mysql_error()); 

$row_d = mysql_fetch_array($results_d); 

extract($row_d); 

$director = $people_fullname; 

function get_leadactor()  

global $movie_leadactor; 

global $leadactor; 

$query_a = “SELECT people_fullname “ . 

“FROM people “ . 

“WHERE people_id=‟$movie_leadactor‟”; 

$results_a = mysql_query($query_a) 

or die(mysql_error()); 

$row_a = mysql_fetch_array($results_a); 

extract($row_a); 

$leadactor = $people_fullname; 

while ($row = mysql_fetch_array($result))  

$movie_name = $row[„movie_name‟]; 

$movie_director = $row[„movie_director‟]; 

$movie_leadactor = $row[„movie_leadactor‟]; 

//get director‟s name from people table 

get_director(); 

//get lead actor‟s name from people table 

get_leadactor(); 

$movie_details .=<<<EOD 

<tr> 

<td>$movie_name</td> 

<td>$director</td> 

  - 82 - 

<td>$leadactor</td> 

</tr> 

EOD; 

$movie_details .=<<<EOD 

<tr> 

<td>Total :$num_movies Movies</td> 

</tr> 

EOD; 

$movie_footer =”</table>”; 

$movie =<<<MOVIE 

$movie_header 

$movie_details 

$movie_footer 

MOVIE; 

echo “There are $num_movies movies in our database”; 

echo $movie; 

?> 

Kết quả nhƣ Hình 4.2.2. 

Hình 4.2.2.  

Cách thức hoạt động: 

Với việc thêm vào hàm get_director và get_leadactor tập lệnh yêu cầu những thông 

tin đặt biệt từ server cho mỗi dòng trên bảng. Điều này có thể cho bạn điền đầy đủ thông 

  - 83 - 

tin từ một đống hỗn độn trong truy vấn gốc, bạn có thể làm sạch những định dạng trong 2 

dòng trƣớc với sự thay đổi trong đoạn mã gần kết kết thúc của tập lệnh. 

Cấu hình: Bạn đã thành công trong việc phát triển sức mạnh về tập lệnh, nó sẽ là cơ 

sở dữ liệu truy vấn và đặt nội dung vào bảng HTML. Cho chính bạn thấy ánh sáng trong 

bóng tối, nhƣng giống tất cả những trình duyệt tốt , chúng ta phải đi về phía trƣớc. 

4.3.  Master là ai? 

Bây giờ chúng ta hãy xây dựng một công việc tốt mà bạn đã làm nhiều và thêm 

nhiều thông tin và hàm hơn vào bảng của bạn. Phƣơng tiện quan hệ giữa cha và con trong 

trang web của bạn cho phép ngƣời dùng có thể click vào tiêu đề của bộ phim để biết 

thông tin về bộ phim. Dĩ nhiên là ở đây tất cả sẽ trở thành trang web động chung, vì thế 

chúng ta tìm nhƣ thế nào để làm và quan hệ cha con có nghĩa. 

Ví dụ: Thêm liên kết trong table 

Mở trang table2.php trong bài và thêm vào những dòng mã mà xuất hiện nổi bật. 

$query = “SELECT movie_id, movie_name, “ . 

“movie_director, movie_leadactor “ . 

“FROM movie”; 

$result = mysql_query($query, $link) 

or die(mysql_error()); 

$num_movies = mysql_num_rows($result); 

$movie_details = „‟; 

while ($row = mysql_fetch_array($result))  

$movie_id = $row[„movie_id‟]; 

$movie_name = $row[„movie_name‟]; 

$movie_director = $row[„movie_director‟]; 

$movie_leadactor = $row[„movie_leadactor‟]; 

//get director‟s name from people table 

get_director(); 

//get lead actor‟s name from people table 

get_leadactor(); 

$movie_details .=<<<EOD 

  - 84 - 

<tr> 

<td><a href=”movie_details.php?movie_id=$movie_id” 

title=”Find out more about $movie_name”>$movie_name</td> 

<td>$director</td> 

<td>$leadactor</td> 

</tr> 

EOD; 

Lƣu file với tên table3.php, sau đó load lên server, mở lại trình duyệt.  

Bạn sẽ thấy nhƣ Hình 4.3.1 

Hình 4.3.1 

Cách thức hoạt động: 

Bạn sẽ chú ý một sự thay đổi giữa hình table2.php và table3.php. Bạn có nhiều liên 

kết cho nhiều thông tin đến mỗi movie cho ngƣời viếng thăm trang web của bạn. 

Thay đổi đầu tiên so với phần trƣớc truy vấn MySQL là biến $movie_id 

Sau đó bạn thêm vùng mới cho kết quả trả về từ truy vấn. 

Thay đổi cuối cùng tạo mã HTML mà đƣa ra liên kết trong tên movie. 

Bây giờ việc thay đổi đã hoàn thành,  thực tế nó làm gì? Nơi bạn đặt con chuột trên 

dòng liên kết, bạn sẽ thấy mỗi liên kết là duy nhất và tạo ra trang web động. Trang này 

đƣợc coi nhƣ trang chủ, trang sẽ liên kết tới nhƣ trang con 

Tốt, ồ? Không  có nhiều loại liên kết khác nhau 

Trƣớc khi bạn đi xa hơn, bạn cần thêm một vài dữ liệu cho cơ sở hiện hành của bạn. 

Nếu bạn gọi lại từ chƣơng 3, cho mỗi phim, bạn có tên phim, ngƣời lãnh đạo và năm.  

  - 85 - 

Vì dụ: Thêm dữ liệu vào bảng 

Trong bài này, bạn sẽ thêm dữ liệu về mỗi movie đến cơ sở dữ liệu 

Mở trình soạn thảo của bạn và gõ đoạn mã sau: 

<?php 

$link = mysql_connect(“localhost”,”root”,””) 

or die(mysql_error()); 

mysql_select_db(“moviesite”) 

or die (mysql_error()); 

//alter “movie” table to include running time/cost/takings fields 

$add = “ALTER TABLE movie ADD COLUMN ( “ . 

“movie_running_time int NULL, “ . 

“movie_cost int NULL, “ . 

“movie_takings int NULL)”; 

$results = mysql_query($add) 

or die(mysql_error()); 

//insert new data into “movie” table for each movie 

$update = “UPDATE movie SET “ . 

“movie_running_time=102, “ . 

“movie_cost=10, “ . 

“movie_takings=15 “ . 

“WHERE movie_id = 1”; 

$results = mysql_query($update) 

or die(mysql_error()); 

$update = “UPDATE movie SET “ . 

“movie_running_time=90, “ . 

“movie_cost=3, “ . 

“movie_takings=90 “ . 

“WHERE movie_id = 2”; 

$results = mysql_query($update) 

or die(mysql_error()); 

$update = “UPDATE movie SET “ . 

  - 86 - 

“movie_running_time=134, “ . 

“movie_cost=15, “ . 

“movie_takings=10 “ . 

“WHERE movie_id = 3”; 

$results = mysql_query($update) 

or die(mysql_error()); 

?> 

Bạn lƣu với tên alter_movie.php, sau đó mở file trong trình duyệt. Không lo lắng, 

bạn sẽ thấy một màn hình trống, nhƣng bảng của bạn đã đƣợc thay đổi và thông tin đã 

đƣa vào tự động 

Cách thức làm việc: 

Trƣớc tiên, tập lệnh dùng lệnh ALTER TABLE để thêm vào những vùng tƣơng 

thích trong bảng hiện hành, sau đó sử dụng lệnh UPDATE để chèn dữ liệu mới  vào 

những vùng đó. 

Bây giờ bạn có dữ liệu, bạn cần tạo một trang mới mà bạn sẽ hiển thị thêm thông 

tin(movie_details.php) 

Ví dụ: Trong bài tập này, bạn sẽ tạo một trang mới để hiển thị dữ liệu mà bạn thêm 

vào bài trƣớc. 

Mở trình soạn thảo và gõ vào chƣơng trình sau: 

<?php 

$link = mysql_connect(“localhost”,”root”,””) 

or die(mysql_error()); 

mysql_select_db(“moviesite”) 

or die (mysql_error()); 

/* Function to calculate if a movie made a profit, 

loss or broke even */ 

function calculate_differences($takings, $cost)  

$difference = $takings - $cost; 

if ($difference < 0) 

 { 

  - 87 - 

$difference = substr($difference, 1); 

$font_color = „red‟; 

$profit_or_loss = “$” . $difference . “m”; 

}  

elseif ($difference > 0) 

 { 

$font_color =‟green‟; 

$profit_or_loss = “$” . $difference . “m”; 

}  

else  

$font_color = „blue‟; 

$profit_or_loss = “Broke even”; 

return “<font color=\”$font_color\”>” . $profit_or_loss . “</font>”; 

?> 

Lƣu file này nhƣ movie_details.php 

Cách thức làm việc: 

Dòng chứa mã substr thì đặt trƣớc dòng $profit_or_loss bởi vì sẽ có sự trả về số âm 

và không có thực. 

Điều quan trọng cần nhớ là trong PHP bạn có thể dễ dàng tạo biến mới bằng một 

hoạt động. Bạn không tổ chức thông tin trong dữ liệu không có nghĩa là bạn không tạo 

đƣợc nó. 

Ví dụ: Trình bày thông tin mới 

Trong bài này bạn sẽ thay đổi bảng trang chủ với dữ liệu mới và điều này tƣơng ứng 

nhƣ bảng con mới của bạn 

Thêm đoạn mã dƣới đây vào movie_details.php: 

/* Function to get the director‟s name from the people table */ 

function get_director() 

 { 

  - 88 - 

global $movie_director; 

global $director; 

$query_d = “SELECT people_fullname “ . 

“FROM people “ . 

“WHERE people_id=‟$movie_director‟”; 

$results_d = mysql_query($query_d) 

or die(mysql_error()); 

$row_d = mysql_fetch_array($results_d); 

extract($row_d); 

$director = $people_fullname; 

/* Function to get the lead actor‟s name from the people table */ 

function get_leadactor()  

global $movie_leadactor; 

global $leadactor; 

$query_a = “SELECT people_fullname “ . 

“FROM people “ . 

“WHERE people_id=‟$movie_leadactor‟”; 

$results_a = mysql_query($query_a) 

or die(mysql_error()); 

$row_a = mysql_fetch_array($results_a); 

extract($row_a); 

$leadactor = $people_fullname; 

$query = “SELECT * FROM movie “ . 

“WHERE movie_id =‟” . $_GET[„movie_id‟] . “„“; 

$result = mysql_query($query, $link) 

or die(mysql_error()); 

$movie_table_headings=<<<EOD 

<tr> 

  - 89 - 

<th>Movie Title</th> 

<th>Year of Release</th> 

<th>Movie Director</th> 

<th>Movie Lead Actor</th> 

<th>Movie Running Time</th> 

<th>Movie Health</th> 

</tr> 

EOD; 

while ($row = mysql_fetch_array($result))  

$movie_name = $row[„movie_name‟]; 

$movie_director = $row[„movie_director‟]; 

$movie_leadactor = $row[„movie_leadactor‟]; 

$movie_year = $row[„movie_year‟]; 

$movie_running_time = $row[„movie_running_time‟].” mins”; 

$movie_takings = $row[„movie_takings‟]; 

$movie_cost = $row[„movie_cost‟]; 

//get director‟s name from people table 

get_director(); 

//get lead actor‟s name from people table 

get_leadactor(); 

Cách thức hoạt động:  

Bởi vì bạn đã đƣợc viết lại hàm để tạo tên đạo diễn và tên diễn viên, bạn “mƣợn” 

mã này từ bài table2.php. Sau đó bạn chuyển truy vấn để trả về mỗi thứ trong mỗi mẫu 

tin, nhƣ tƣơng phản (opposed) một vài trƣờng. Nó có nghĩa là bạn trả về một trƣờng mà 

bạn không thực sự sử dụng. Câu truy vấn chứa mệnh đề WHERE. Mẫu tin bạn sẽ lấy lại 

dữ liệu từ quyết định này  

Mệnh đề WHERE 

  - 90 - 

  Bạn dùng $_GET[„movie_id‟] trong mệnh đề WHERE. Đây là ID của movie 

mà đƣợc liên kết từ tabl3.php 

  Bạn cũng tạo một biến khác $movie_table_headings chứa phần đầu bạn sẽ sử 

dụng. 

  Sự dừng lại của đoạn mã thì rất giống đoạn mã trong table3.php. Bạn thêm 

vào nhiều hơn 4 trƣờng để WHILE kiểm soát vòng lặp. 

Chúng tôi có nói phần trƣớc là những vùng trả về mà bạn không cần thì hoạt động 

không tốt?  Vâng, đúng nhƣ vậy. Tuy nhiên, trƣờng hợp này bạn chỉ có nhiều hơn một 

trƣờng bạn cần, nhƣ tƣơng phản để trả về nhiều trƣờng dƣ thừa. Vì thế, chúng tôi sẽ đƣa 

ra lời khuyên? Chính xác 100%. Tuy nhiên, bởi vì bạn sử dụng nhiều trƣờng trong mỗi 

mẫu tin, PHP sẽ không chứa từ cân bằng này, và nó có giá trị. Bạn sẽ không muốn làm 

điều này khi mà bạn muốn những giá trị của 5 trƣờng và cấu trúc mẫu tin chứa 50 trƣờng. 

Nếu bạn làm điều này, PHP sẽ hao mòn về tài nguyên để trả về 45 trƣờng khác.  

Ví dụ: Trình bày chi tiết phim ảnh 

Trong bài tập này, bạn sẽ tăng cƣờng trang movie_details với dữ liệu mới. 

Thêm vào những dòng mã sau vào cuối movie_details.php 

    $movie_health = calculate_differences($movie_takings, $movie_cost); 

$page_start =<<<EOD 

<html> 

<head> 

<title>Details and Reviews for: $movie_name</title> 

</head> 

<body> 

EOD; 

$movie_details =<<<EOD 

<table width=”70%” border=”0” cellspacing=”2” 

cellpadding=”2” align=”center”> 

<tr> 

<th colspan=”6”><u><h2>$movie_name: Details</h2></u></th> 

</tr> 

$movie_table_headings 

  - 91 - 

<tr> 

<td width=”33%” align=”center”>$movie_name</td> 

<td align=”center”>$movie_year</td> 

<td align=”center”>$director</td> 

<td align=”center”>$leadactor</td> 

<td align=”center”>$movie_running_time</td> 

<td align=”center”>$movie_health</td> 

</tr> 

</table> 

<br> 

<br> 

EOD; 

$page_end =<<<EOD 

</body> 

</html> 

EOD; 

$detailed_movie_info =<<<EOD 

$page_start 

$movie_details 

$page_end 

EOD; 

echo $detailed_movie_info; 

mysql_close(); 

Lƣu file nhƣ movie_details.php, đƣa lên server, mở trình duyệt tabl3.php, click vào 

tên movie, bạn sẽ thấy nhƣ Hình 4.3.2 

  - 92 - 

Hình 4.3.2 

Cách thức hoạt động: 

Bạn nhớ hàm bạn tạo ở trên? Khi bạn thêm dòng trong bƣớc 1 ở phần ví dụ trƣớc, 

bạn  gọi  hàm  và  yêu  cầu  nó  thi  hành.  Bất  cứ  giá  trị  nào  đƣợc  trả  về  từ  hàm 

calculate_difference  sẽ  là  nơi  biến  $movie_health.  Thông  qua  biến  $movie_taking  và 

$movie_costs để hàm đƣa ra kết quả chính xác. 

Khi bạn định nghĩa biến $page_start, bạn bắt đầu sắp xếp cấu trúc trang thực sự. 

Bằng cách thêm vào biến $movie_name, bạn có thể thiết lập tựa đề trình duyệt . Bạn có 

thể thấy cú pháp =<<<EOD tiện lợi thế nào? 

Kế đến, bạn định nghĩa biến $movie_details. Điều này hoàn toàn giải thích giải 

thích đƣợc. Nhớ biến $movie_table_headings bạn đã tạo trƣớc. Tất cả bạn làm trong biến 

$movie_details và nó xuất hiện. 

Cuối cùng, bạn định nghĩa biến $page_end. 

4.4.  Quan hệ lâu dài 

Bạn muốn tìm gì từ những cái đƣợc thấy lại? Bạn cần tạo một truy vấn SQL mới 

trong trang movie_details.php và thi hành nó khi nó đƣợc nạp, nó sẽ làm tổng 2 truy vấn 

trong một trang. Nó sẽ làm việc, nhƣng nó thuận lợi. 

Đó là thời gian để trả lời câu hỏi, quan hệ là gì? 

Một quan hệ là một cách của việc kết hợp nhiều bảng vì thế bạn có thể cập nhật dữ 

liệu trong tất cả những bảng. Lợi ích của MySQL là cơ sở dữ liệu quan hệ, hỗ trợ cho 

việc tạo lập các bảng. Khi sử dụng những quan hệ chính xác có thể rất hữu ích và có thể 

dùng để lấy lại dữ liệu từ nhiều bảng trong truy vấn SQL. 

 Ví dụ:Tạo và điền một bảng hình ảnh xem lại 

  - 93 - 

Trƣớc tiên bạn có thể cập nhật những bảng xem lại, bạn cần tạo bảng và điền dữ liệu vào. 

Mở trình soạn thảo và gõ vào đoạn mã sau: 

<?php 

//connect to MySQL 

$connect = mysql_connect(“localhost”, “root”, “”) 

or die (“Hey loser, check your server connection.”); 

mysql_select_db(“moviesite”); 

//create “reviews” table 

$reviews = “CREATE TABLE reviews ( 

review_movie_id int(11) NOT NULL, 

review_date date NOT NULL, 

review_name varchar(255) NOT NULL, 

review_reviewer_name varchar(255) NOT NULL, 

review_comment varchar(255) NOT NULL, 

review_rating int(11) NOT NULL default 0, 

KEY (review_movie_id))”; 

$results = mysql_query($reviews) 

or die (mysql_error()); 

//populate the “reviews” table 

$insert = “INSERT INTO reviews 

(review_movie_id, review_date, review_name, 

review_reviewer_name, review_comment, review_rating) 

VALUES 

(„1‟, „2003-08-02‟, „This movie rocks!‟, 

„John Doe‟,‟I thought this was a great movie even though 

my girlfriend made me see it against my will.‟ ,‟4‟), 

(„1‟,‟2003-08-01‟,‟An okay movie‟, 

„Billy Bob‟,‟This was an okay movie. I liked Eraserhead 

better.‟,‟2‟), 

(„1‟,‟2003-08-10‟,‟Woo hoo!‟, 

„Peppermint Patty‟,‟Wish I\‟d have seen it sooner!‟,‟5‟), 

  - 94 - 

(„2‟,‟2003-08-01‟,‟My favorite movie‟, 

„Marvin Marian‟,‟I didn\‟t wear my flair to the movie but 

I loved it anyway.‟,‟5‟), 

(„3‟,‟2003-08-01‟,‟An awesome time‟, 

„George B.‟,‟I liked this movie, even though I thought it 

was an informational video from our travel agent.‟,‟3‟)”; 

$insert_results = mysql_query($insert) 

or die(mysql_error()); 

?> 

Lƣu file nhƣ createreviews.php, đƣa lên server, mở trình duyệt, chúng ta sẽ thấy bảng 

đƣợc tạo và điền đầy đủ. 

Cách thức hoạt động: 

Chúng ta làm nhƣ tạo bảng với PHP và MySQl 

Ví dụ:Truy vấn những cái đƣợc xem lại 

Trong ví dụ này, chúng ta sẽ liên kết 2 bảng (movies và review) để xem lại. Những 

yêu cầu này có nhiều thay đổi đến trong movies_details.php, vì thế cách tốt nhất là bạn 

copy file. Sau đó làm những bƣớc sau: 

  Mở trình soạn thảo movies_detail.php 

  Thay đổi đoạn mã dƣới đây: 

$movie_query = “SELECT * FROM movie “ . 

“WHERE movie_id =‟” . $_GET[„movie_id‟] . “„“; 

$movie_result = mysql_query($movie_query, $link) 

or die(mysql_error()); 

Và sau đoạn mã, thay đổi: 

while ($row = mysql_fetch_array($movie_result)) { 

$movie_name = $row[„movie_name‟]; 

$movie_director = $row[„movie_director‟]; 

Và thêm những dòng sau dấu ngoặc “đóng” trong lệnh While 

$review_query = “SELECT * FROM reviews “ . 

“WHERE review_movie_id =‟” . $_GET[„movie_id‟] . “„ “ . 

“ORDER BY review_date DESC”; 

  - 95 - 

$review_result = mysql_query($review_query, $link) 

or die(mysql_error()); 

Cách thức hoạt động: 

Bạn  thay  đổi  tên  của  biến  $query  cho  biến  $movie_query,  thay  $result  cho 

$movie_result. Làm việc này bảo đảm không làm bạn cảm thấy rắc rối khi bạn cập nhật 

những kết quả liên quan đến sự trả về của truy vấn. Đây cũng là mệnh đề sắp xếp, mà 

chắc rằng những cái xem lại gần đây nhất ở trên đầu trang. 

Một lỗi chủ yếu là nhiều ngƣời bắt đầu làm thì dùng tên biến nhƣ nhau khi tạo truy 

vấn SQL. Thừa nhận rằng bạn copy và dán đơn giản làm nhẹ bớt movie query và movie 

result khi query đƣợc gọi. Bạn có hai truy vấn SQL đƣợc gọi truy vấn, và hai kết quả gọi 

là $result. Khi kết quả đầu tiên chạy nó sẽ xuất ra những kết quả mong đợi. Tuy nhiên 

nếu bạn muốn chuyển đến những kết quả đƣợc trả về từ SQL đầu tiên bạn sẽ gặp vấn đề 

lớn. 

Tại sao nhƣ vậy? Kết quả đầu tiên sẽ đè lên kết quả truy vấn lần thứ 2, với lý do này 

bạn phải luôn cẩn trọng khi dùng nhiều tên khác nhau cho truy vấn SQL và trả về kết quả 

từ truy vấn. 

Ví dụ:Trình bày những  review 

Thêm dòng sau: 

function generate_ratings($review_rating) 

 { 

$movie_rating = „‟; 

for($i=0; $i<$review_rating; $i++) 

 { 

$movie_rating .= “<img src=\”thumbsup.gif\”>&nbsp;”; 

  } 

return $movie_rating; 

Thêm những đoạn mã trong những dòng sau: 

$review_table_headings=<<<EOD 

<tr> 

  - 96 - 

<th>Date of Review</th> 

<th>Review Title</th> 

<th>Reviewer Name</th> 

<th>Movie Review Comments</th> 

<th>Rating</th> 

</tr> 

EOD; 

Bạn cần thêm vài dòng tiếp theo sau phần đầu bảng: 

while($review_row = mysql_fetch_array($review_result))  

$review_flag =1; 

$review_title[] = $review_row[„review_name‟]; 

$reviewer_name[]  = 

ucwords($review_row[„review_reviewer_name‟]); 

$review[] = $review_row[„review_comment‟]; 

$review_date[] = $review_row[„review_date‟]; 

$review_rating[]  = 

generate_ratings($review_row[„review_rating‟]); 

Tiếp theo bạn thêm những dòng sau: 

$i = 0; 

$review_details = „‟; 

while ($i<sizeof($review))  

$review_details .=<<<EOD 

<tr> 

<td width=”15%” valign=”top” align=”center”>$review_date[$i]</td> 

<td width=”15%” valign=”top”>$review_title[$i]</td> 

<td width=”10%” valign=”top”>$reviewer_name[$i]</td> 

<td width=”50%” valign=”top”>$review[$i]</td> 

<td width=”10%” valign=”top” align=”center”>$review_rating[$i]</td> 

  - 97 - 

</tr> 

EOD; 

$i++; 

Thay đổi nhƣ dƣới đây, làm cẩn thận và chính xác: 

<td>$movie_health</td> 

</tr> 

</table> 

<br> 

<br> 

EOD; 

if ($review_flag) 

 { 

$movie_details .=<<<EOD 

<table width=”95%” border=”0” cellspacing=”2” 

cellpadding=”20” align=”center”> 

$review_table_headings 

$review_details 

</table> 

EOD; 

Lƣu file movie_details.php 

Đƣa lên server, mở trình duyệt table3.php và click vào movie 

Bạn sẽ thấy nhƣ Hinh 4.4  

  - 98 - 

Hinh 4.4 

Cách thức hoạt động: 

Hàm  generate_ratings  là  hàm  dễ  hiểu.  Bạn gởi  nó  cho  biến  là  trƣờng  không  tự 

chủ(rating) cho movie và nó tạo một hình “rating”, trả về nó. Chú ý rằng bạn đang sử 

dụng .=(nhƣ .=<<<). Đảm bảo rằng những hình ảnh với một “rating” nhiều hơn 1 sẽ tạo 

những hình thêm vào hình rating đơn giản. 

Biến $review_table_headings chứa những phần đầu bảng cho việc xem lại mà bạn 

vừa lấp đầy qua truy vấn SQL trƣớc.  

Biến $review_table_headings chứa những phần đầu của bảng cho review mà bạn 

vừa điền đầy đủ trong truy vấn trƣớc. Điều này sử dụng chính xác khái niệm nhƣ phần 

đầu bảng movie trong ví dụ trƣớc. Vì thế bạn review tất cả những phần đầu bảng . 

Tập lệnh WHILE là những dòng tổ chức của những review, nếu có bất kỳ những 

review nào cho movie, bạn thiết lập một cờ cho biết sử dụng biến $review_flag. Mã này 

tạo mảng tổ chức những giá trị sẽ trả về. Tại sao lại đặt chúng trong mảng và không hoàn 

toàn là biến bình thƣờng? Điều này cho phép biến tổ chức dữ liệu nhiều hơn một review 

cho hình ảnh. Sau tất cả những điều này, bạn mong rằng sẽ có nhiều “review”cho mỗi 

hình ảnh. Nếu bạn không tạo biến review nhƣ mảng, sau đó bạn trả về review cuối cho 

hình ảnh. Trong phần thảo luận trƣớc, chúng ta thấy là tại sao chúng ta ƣu tiên đặt những 

giá trị vào hơn là xuất ra những giá trị.  Nhìn vào dòng review_name bạn chú ý rằng 

chúng ta đặt dòng $review_row bên trong hàm ucwords PHP. Điều này cho phép bạn 

thực hiện hàm ucwords tự động trong giá trị trả về từ trƣờng đó. 

  - 99 - 

Mã sau vòng lặp thông qua mảng và gán những giá trị cho mỗi trƣờng mà bạn sẽ 

trình bày cho ngƣời xem. Bạn sử dụng hàm sizeof PHP để tính toán có bao nhiêu mẫu tin 

đƣợc trả về . 

Cuối cùng, bạn chia biến $movie_details thành đoạn nhỏ và thêm chúng qua việc 

sử dụng .=<<<. Nhƣ bạn làm trƣớc, bạn sử dụng định nghĩa biến và  đặt nơi chính xác. 

Nếu cờ review đƣợc thiết lập, bạn sẽ thấy những mục tạo thành những review 

Bạn có thay đổi trong phần này nhƣng bạn thấy là việc thay đổi đƣợc đánh giá 

cao. Bây giờ bạn biết sử dụng MySQL nhƣ thế nào để tạo quan hệ giữa các bảng. Bạn 

thành công trong việc lấy lại những review từ bảng review phụ thuộc vào biến movie_id. 

Bạn cũng sử dụng $_GET bao trùm qua giá trị từ một trang . 

  - 100 - 

Chƣơng  5:  NHỮNG THÀNH PHẦN CỦA FORM: CHO 

PHÉP NGƢỜI DÙNG LÀM VIỆC VỚI DỮ LIỆU 

Trong ứng dụng Web, ngƣời sử dụng nhập nội dung, nhấn submit để sử lý. Một tiến 

trình thì không đƣợc hoàn thành bởi lệnh PHP, vì thế mã lệnh yêu cầu phải “thông minh”. 

HTML sẽ gởi đến một vị trí đặc biệt và xử lý vì khi bạn điền trông tin vào form, để 

biết một địa chỉ email, mail,… bạn cần một phƣơng tiện để đọc nội dung. 

  Form trong HTML thì đơn giản hơn, nó chỉ vị trí và cách thức gửi nhƣ thế nào. 

Tại điểm này PHP đƣợc ứng dụng hơn. Tập lệnh PHP nhận dữ liệu từ form và sử dụng nó 

để hoàn thành hoạt động, nhƣ cập nhật những nội dung của cơ sở dữ liệu, gửi một email, 

định dạng dữ liệu và hơn thế nữa. 

  PHP sử dụng một tập đơn giản mà mạnh, một sự kết hợp, cung cấp phƣơng tiện để 

làm mọi thứ ảo khi chúng ta cần. 

  Trong chƣơng này bạn bắt đầu xây dựng một ứng dụng đơn giản cho phép bạn 

thêm, bớt, xóa thành phần của dữ liệu. Chúng ta sẽ đƣợc đến với PHP/MySQL nhƣ:  

-  Tạo những form sử dụng nút, hộp soạn thảo và những thành phần khác. 

-  Tạo tập lệnh PHP để xử lý những form HTML. 

-  Nhận dữ liệu từ hai biến chính là: $_POST và $_GET. 

-  Qua thông tin ẩn để xử lý tập lệnh form với những điều khiển form ẩn và một 

chuỗi truy vấn URL. 

5.1.  Form đầu tiên 

Bắt đầu là một form đơn giản chỉ có vùng soạn thảo và nút submit, tập lệnh xử lý sẽ 

hiển thị giá trị nhập vào vùng soạn thảo 

Ví dụ: Trong bài tập này bạn sẽ điền tên vào form. Đây là một biến đơn giản trong 

chƣơng trình “Hello Word”.  

1/Mở trình soạn thảo nhập đoạn mã sau và lƣu với tên form1.html 

<html> 

<head> 

<title>Say My Name</title> 

<style> 

TD{color:#353535;font-family:verdana} 

  - 101 - 

TH{color:#FFFFFF;font-family:verdana;background-color:#336699} 

</style> 

</head> 

<body> 

<form> 

<table 

bgcolor="#353535"> 

<tr> 

<td>Name</td> 

<td> 

<input><br></td> 

</tr> 

<tr> 

<td> 

<input> 

</td> 

</tr> 

</table> 

</form> 

</body> 

</html> 

2/ Mở trình soạn thảo mới nhập đoạn mã sau và lƣu với tên formprocess1.php: 

<html> 

<head> 

<title>Say My Name</title> 

</head> 

<body> 

<?php 

echo "Hello " . $_POST['Name']; 

?> 

<pre> 

  - 102 - 

DEBUG : 

<?php 

print_r($_POST); 

?> 

</pre> 

</body> 

</html> 

3/Mở trình duyệt với file form1.html sẽ cho kết quả nhƣ Hình 5.1.1 

Hình 5.1 

    Nhập vào khung Name nội dung bất kỳ(ví dụ Test) và click nút Submit bạn 

sẽ thấy kết quả nhƣ sau: 

Hello Test 

DEBUG : 

Array 

    [Name] => Test 

    [SUBMIT] => Submit 

  Cách thức hoạt động : 

  Để hiểu về cách thức hoạt động, chúng ta phải tìm hiểu về những thành phần của 

form và vài hàm PHP mới. 

5.1.1.  Thành phần form 

Thành phần mà bạn cần biết trƣớc tiên là FORM. Nó giới hạn vùng form trong 

trang và tổ chức những vùng mà bạn cần từ trang web: 

      <form action=”formprocess1.php” method=”post”> 

  - 103 - 

<!--form controls here--> 

</form>  

Chú ý: Thành phần Form có một thẻ kết thúc và hai thuộc tính.  

1.  Action: là cách thức chỉ đến đƣờng dẫn.  

2.  Method: là cách thức mà bạn sẽ gửi dữ liệu đến ngƣời nhận. Gởi 

có hai phƣơng pháp. Đó là POST và GET. 

Phƣơng pháp POST lấy dữ liệu từ trƣờng form và gửi nó thông qua phần đầu 

HTTP. Trong trƣờng hợp này dữ liệu không thể thấy qua URL 

Phƣơng thức GET lấy dữ liệu từ trƣờng form, mã hóa nó, và thêm nó để gửi 

tới URL nhƣ trình bày dƣới đây: 

http://localhost/formprocess1.php?field1=valuea&field2=value%20b 

Bạn có thể thấy, tên trƣờng và giá trị của chúng thì dễ dàng đọc trong tập lệnh 

URL. Những tham số của tập lệnh trong URL cho phép ngƣời dùng có thể thay đổi, 

điều khiển chúng. Điều này có thể dẫn đến lỗi trong quá trình xử lý tập lệnh hoặc 

cập nhật dữ liệu( không phải là lần cập nhật đầu tiên.) 

5.1.2.  Phần tử nhập (INPUT) 

Phần tử HTML mới thứ hai là INPUT. Đây  là hình thức cơ bản và có thể sử 

dụng trong nhiều phƣơng pháp khác nhau để tập hợp nhiều loại thông tin khác nhau. 

Trong  trƣờng  hợp  này  bạn  có  thể  sử  dụng  kiểu  INPUT  khác  nhau:  kiểu  văn 

bản(text) và kiểu submit. 

http://localhost/bar.php 

Foo.php 

<form action = “bar.php” method =  “POST”> 

<input type = “text” name = “movie_name”> 

</form> 

Bar.php 

The movie is called<?=$_POST[“movie_name”]?>. 

  - 104 - 

  Kiểu INPUT văn bản: 

<input type=”text” name=”Name”> 

Kiểu INPUT văn bản là một tiêu chuẩn, hộp văn bản chỉ có những dòng 

đơn. Nó sẽ cập nhật nội dugn thông qua cú pháp: 

<?php 

echo $_POST[„Name‟]; // sẽ hiển thị một kiểu giá trị 

?> 

  Kiểu INPUT submit: 

<input type=”submit” name=”SUBMIT” value=”Submit”> 

Tên của nó phải gợi ý khéo léo, phần tử submit hiển thị bằng một nút. 

Nút văn bản đƣợc đặt thông qua thuộc tính giá trị. Nhƣ phƣơng pháp cho INPUT 

văn bản, điều khiển form này cần có tên cho tiến trình chuyển đến. 

5.1.3.  Xử lý Form 

Trong lệnh, chúng ta phải chú ý đến hàm và cú pháp mới để tìm hiểu về chúng 

Tập lệnh xử lý Form đầu tiên là một biến tƣơng tác của “hello world” phổ 

biến, nhƣng trong trƣờng hợp này nó hiển thị “hello” và tên của bạn trong hộp text. 

Để điều này xảy ra, bạn cần in giá trị của trƣờng văn bản mà bạn điền trong form. 

Bạn  biết  lệnh  xuất,  vì  thế  chúng  ta  hãy  di  chuyển  đến  một  bộ  phận, 

$_POST[„tên‟]. 

Mảng toàn cục $_POST chứa tất cả các form dữ liệu submit với phƣơng pháp 

POST. Danh mục mảng của trƣờng là tên của nó. Trong thời điểm này bạn sẽ thấy 

cách kiểm tra nội dung  mảng $_POST sử dụng hàm print_r() nhƣ thế nào. 

<?php 

echo “Hello “ . $_POST[„Name‟]; 

?> 

Trong  ví dụ này, $_POST[„name‟] hiển thị cái gì bạn nhập vào trong hộp 

“Name.”Hello test”. Ở đây print_r($_POST) kết xuất đơn giản nội dung chung của 

mảng toàn cục $_POST để xuất ra. Đây là cách tốt nhất để biên dịch form. Nên sử 

dụng $_POST để kiểm tra, trình bày trạng thài đối tƣợng khi xây dựng tập lệnh. 

  - 105 - 

Trong tập lệnh formprocess1.php xuất ra một vài thứ tƣơng tự nhƣ sau  

Hello test 

DEBUG : 

Array 

[Name] => test 

[SUBMIT] => Submit 

Khi nhận form submit, PHP đặt mảng POST với dữ liệu mà form gửi tới. Nhƣ 

với bất kì mảng nào, bạn có thể cập nhật chính xác bất kì danh mục nào bằng tên. 

Trong ví dụ này, bạn có thể thấy rõ danh mục tên chứa giá trị test. Cách này làm 

việc với tất cả các form, ngay cả với những form phức tạp nhất. 

Chúng ta hãy đi tiếp để thấy việc sử dụng những phần tử HTML trong suốt 

quá trình nhập form với giao diện ngƣời dùng. 

5.2.  Driving the User Input  

Form trong ví dụ này, hƣớng dẫn ngƣời dùng chọn những giá trị từ một tập hợp giá 

trị mà đƣợc cung cấp. 

Tập hợp giá trị thông qua việc sử dụng những phần tử HTML đặc biệt: list boxes, 

radio buttons và checkboxes. 

Có 2 loại trong form: 

  Loại cho phép ngƣời dùng chọn một mục từ những chọn lựa có sẵn. 

  Loại cho phép chọn nhiều mục. 

Hộp danh sách xổ xuống và nút radio chỉ chọn một.  Những checkbox và những hộp 

danh sách cung cấp nhiều lựa chọn 

Ví dụ: Giới hạn của việc chọn lựa 

Chúng ta hãy bắt đầu với một kiểu nhập đơn giản. Những bƣớc sau là để tạo một 

danh sách đơn giản: 

1 Tạo một file form2.html  và mở nó trong trình soạn thảo của bạn  

2. Nhập đoạn mã sau: 

<html> 

  - 106 - 

<head> 

<title>Greetings Earthling</title> 

<style type=”text/css”> 

TD{color:#353535;font-family:verdana} 

TH{color:#FFFFFF;font-family:verdana;background-color:#336699} 

</style> 

</head> 

<body> 

<form action=”formprocess2.php” method=”post”> 

<table border=”0” cellspacing=”1” cellpadding=”3” 

bgcolor=”#353535” align=”center”> 

<tr> 

<td bgcolor=”#FFFFFF” width=”50%”>Name</td> 

<td bgcolor=”#FFFFFF” width=”50%”> 

<input type=”text” name=”Name”> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Greetings</td> 

<td bgcolor=”#FFFFFF”> 

<select name=”Greeting”> 

<option value=”Hello”>Hello</option> 

<option value=”Hola”>Hola</option> 

<option value=”Bonjour”>Bonjour</option> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF” width=”50%”>Display Debug info</td> 

<td bgcolor=”#FFFFFF” width=”50%”> 

<input type=”checkbox” name=”Debug” checked> 

  - 107 - 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF” colspan=2 align=”center”> 

<input type=”submit” name=”SUBMIT” value=”Submit”> 

</td> 

</tr> 

</table> 

</form> 

</body> 

</html> 

3.Tạo một file mới với tên formprocess2.php và nhập đoạn mã sau: 

<html> 

<head> 

<title>Greetings Earthling</title> 

<style type=”text/css”> 

TD{color:#353535;font-family:verdana} 

TH{color:#FFFFFF;font-family:verdana;background-color:#336699} 

</style> 

</head> 

<body> 

<?php 

if (isset($_POST[„Debug‟]) and $_POST[„Debug‟] == “on”) { 

?> 

<pre> 

<?php 

print_r($_POST); 

?> 

</pre> 

<?php 

  - 108 - 

?> 

<p align=”center”><?php echo $_POST[„Greeting‟]; ?> 

<?php echo $_POST[„Name‟]; ?></p> 

</body> 

</html> 

4. Lƣu formprocess2.php và tải nó lên thƣ mục làm việc của bạn. 

5. Gọi trang trình duyệt của bạn. Bạn có thể thấy kết quả nhƣ hinh 5.2.1  

Hình 5.2.1 

6. nhập tên của bạn và ấn nút submit .Kết quả nhƣ hinh 5.2.2 

Hình 5.2.2 

Cách thức hoạt động: 

  Nhƣ  bạn  thấy    đoạn  mã  này,  trình tự  giống  nhƣ  trong formprocess1.php. Hai 

trƣờng  có  thêm  một  hợp  xổ  xuống  và  một  checkbox.  formprocess2.php  giống  nhƣ 

formprocess1.php nhƣng thêm một hộp cuộn.Trình bày thông tin biên dịch chỉ khi hợp 

kiểm Debug đƣợc chọn và bạn dùng bất kì chọn lựa nào trong danh sách xổ xuống . 

5.2.1.  Kiểu nhập hộp checkbox  

Checkbox có thể đƣợc trình bày ở hai vị trí: Khi đƣợc kiểm tra, nó thông qua giá trị 

trên  mảng $_POST, nhƣng mặc khác nó không gửi đi mọi thứ. Đây là phƣơng pháp hay 

để trình bày kiểu dữ liệu Boolean. 

  - 109 - 

* SELECT element 

<select name=”Greeting”> 

<option value=”Hello”>Hello</option> 

<option value=”Hola”>Hola</option> 

<option value=”Bonjour”>Bonjour</option> 

</select> 

Phần tử SELECT cho phép bạn trình bày một danh sách chọn lựa cố định mà ngƣời 

dùng có thể chọn một phần tử. Mục chọn sẽ không đƣợc gửi nhƣ hiển thị nhƣng sẽ gửi 

giá trị của nó. Trong ví dụ này, giá trị và hiển thị là giống nhau,  nhƣng trong một hệ 

thống ràng buộc cơ sở dữ liệu, bạn có thể thấy ID của mẫu tin nhƣ những giá trị và  nhãn 

văn bản của chúng là danh sách chọn.  

Khi sử dụng danh sách, phải thiết lập những phần giá trị mục chọn OPTION. Nếu ở 

đây không thiết lập tƣơng tự nhƣ thấy trong danh sách, nhƣng hoàn toàn không sử dụng 

bởi vì tất cả chọn lựa  sẽ gửi nhƣ giá trị rỗng. 

5.2.2.  Một form đa tiến trình 

    Form luôn luôn tác động lại theo một phƣơng thức xác định trƣớc, dựa vào 

việc mã hóa tập lệnh để chỉ định dữ liệu mà ngƣời dùng gửi tới hệ thống nhƣ thế nào. 

Một form đơn giản có thể có nhiều định nghĩa hoạt động bằng việc sử dụng những nút 

submit khác nhau. 

Ví dụ: Radio Button, Multiline List Boxes 

  Trong ví dụ sau, bạn tạo ra một form để chuẩn bị một nghiên cứu và tạo một giao 

diện film/diễn viên/đạo diễn. 

1. tạo một file form3.php và nhập đoạn mã sau: 

<html> 

<head> 

<title>Add/Search Entry</title> 

<style type=”text/css”> 

TD{color:#353535;font-family:verdana} 

TH{color:#FFFFFF;font-family:verdana;background-color:#336699} 

</style> 

</head> 

  - 110 - 

<body> 

<form action=”formprocess3.php” method=”post”> 

<table border=”0” cellspacing=”1” cellpadding=”3” 

bgcolor=”#353535” align=”center”> 

<tr> 

<td bgcolor=”#FFFFFF” width=”50%”>Name</td> 

<td bgcolor=”#FFFFFF” width=”50%”> 

<input type=”text” name=”Name”> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>What you are looking for</td> 

<td bgcolor=”#FFFFFF”> 

<select name=”MovieType”> 

<option value=”” selected>Select a movie type...</option> 

<option value=”Action”>Action</option> 

<option value=”Drama”>Drama</option> 

<option value=”Comedy”>Comedy</option> 

<option value=”Sci-Fi”>Sci-Fi</option> 

<option value=”War”>War</option> 

<option value=”Other”>Other...</option> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Add what?</td> 

<td bgcolor=”#FFFFFF”> 

<input type=”radio” name=”type” value=”Movie” checked> 

Movie<br> 

<input type=”radio” name=”type” value=”Actor”> 

Actor<br> 

  - 111 - 

<input type=”radio” name=”type” value=”Director”> 

Director<br> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF” width=”50%”>Display Debug info</td> 

<td bgcolor=”#FFFFFF” width=”50%”> 

<input type=”checkbox” name=”Debug” checked> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF” colspan=2 align=”center”> 

<input type=”submit” name=”Submit” value=”Search”> 

<input type=”submit” name=”Submit” value=”Add”> 

</td> 

</tr> 

</table> 

</form> 

</body> 

</html> 

2. Tạo file khác tên formprocess3.php và nhập đoạn mã sau: 

<?php 

if ($_POST[„type‟] == “Movie” && $_POST[„MovieType‟] == “”) 

 { 

header(“Location:form3.php”); 

$title = $_POST[„Submit‟] . “ “ . 

$_POST[„type‟] . “ : “ . 

$_POST[„Name‟]; 

?> 

<html> 

  - 112 - 

<head> 

<title><?php echo $title; ?></title> 

</head> 

<body> 

<?php 

if ($_POST[„Debug‟] == “on”) { 

?> 

<pre> 

<?php 

print_r($_POST); 

?> 

</pre> 

<?php 

$name = $_POST[„Name‟]; 

$name[0] = strtoupper($name[0]); 

if ($_POST[„type‟] == “Movie”)  

$foo = $_POST[„MovieType‟] . “ “ . $_POST[„type‟]; 

} else 

 { 

$foo = $_POST[„type‟]; 

?> 

<p align=”center”> 

You are <?php echo $_POST[„Submit‟]; ?>ing 

<?php echo $_POST[„Submit‟] == “Search” ? “for “ : “”; ?> 

a <?php echo $foo ?> 

named “<?php echo $name; ?>” 

</p> 

</body> 

  - 113 - 

</html> 

3. Mở http://localhost/form3.php. Kết quả nhƣ Hình 5.2.2.1 

Hinh 5.2.2.1 

Chú ý ở  đây có 2 nút Search và nút Add 

4. Nhập  Kevin Kline trong trƣờng Name. 

5. Chọn loại film. 

6. Xóa hiển thị Debug Dump checkbox nếu bạn thích; sau đó nhấn  nút Search .Kết 

quả nhƣ sau: 

Hình 5.2.2.2 

7. Bây giờ hãy thử thay đổi dữ liệu xem kết quả thế nào 

Cách thức hoạt động 

Bạn viết mã lệnh một form đơn giản với hai hoạt động. Phụ thuộc vào nút bạn 

nhấn  và dữ liệu bạn chọn để enter, mã này xuất ra những thông tin khác nhau. 

Một nhóm những nút radio và nút submit đƣợc thêm vào. Chúng ta hãy nhìn 

vào hình Hình 5.2.2.1 

  - 114 - 

5.2.3.  Những phần tử nhập nút Radio 

Nút radio là phần tử rất đơn giản. Bằng việc mặc định, nếu không có nút radio 

đặc biệt nhƣ CHECKED thì không có việc chọn mặc định. Nên nhớ, việc chọn giá 

trị mặc định là phần quan trọng của việc thiết lập form.  

Ngƣời sử dụng thƣờng để mặc định. 

<input type=”radio” name=”type” value=”Movie” checked> 

Movie<br> 

<input type=”radio” name=”type” value=”Actor”> 

Actor<br> 

<input type=”radio” name=”type” value=”Director”> 

Director<br> 

Cho nhiều nút radio phức tạp để liên kết các nhóm form với nhau và để xử lý 

một phần tử form đơn giản, chúng cần tên nhƣ nhau và những giá trị khác nhau, một 

cách hoàn toàn rõ ràng. Trong đoạn mã có trƣớc, tên luôn là chữ in. Điều này nói 

với trình duyệt web rằng chỉ có một nút đƣợc chọn.  

5.2.4.  Những nút submit phức tạp 

Nhƣ với nút radio, nút submit cũng có tên giống nhau với giá trị khác nhau. 

Nhấn vào một trong những nút đơn giản. 

<input type=”submit” name=”Submit” value=”Search”> 

<input type=”submit” name=”Submit” value=”Add”> 

Khi bạn thấy biên dịch trở ngại, nút submit gởi thông tin đến tập lệnh. Bạn có 

thể cập nhật giá trị nút submit thông qua mảng $_POST[„Submit‟]. 

5.2.5.  Việc kiểm tra nhập cơ bản 

Tập lệnh xử lý là gì? Có gì mới? 

Đoạn mã dƣới đây kiểm tra loại mục là Movie, nó kiểm tra ngƣời sử dụng đã 

chọn một loại giá trị movie từ danh sách chƣa. Nếu có hoặc không, anh ta hoặc cô ta 

đƣợc gởi một địa chỉ mới đến trang form. 

Việc kiểm tra đơn giản nếu với  một và toán tử. (Trong cách nói đơn giản 

Monopoly, nếu loại mục là movie và không đặc biệt, bạn trở lại một hình vuông và 

không thu đƣợc $200.)  

  - 115 - 

if ($_POST[„type‟] == “Movie” && $_POST[„MovieType‟] == “”)  

header(“Location:form3.php”); 

Phần đầu hàm cho phép bạn gởi đến phần đầu HTTP thô. Nó thì hữu ích cho 

vấn đề bảo mật địa chỉ và hạn chế cập nhật. Trong ví dụ này,  nó gửi một địa chỉ 

ngƣời dùng  mới đến trang lý thuyết. 

Chú ý: Một lỗi chung với ngƣời bắt đầu sử dụng PHP là hiểu sai một sự thật 

rất đơn giản. Một lần gửi những phần đầu không thể gửi một lần nữa. Điều này có 

nghĩa là bất kì việc xuất nào, bất kì khoảng trắng nào, bất kì sự trình bày bảng nào 

đúng, trƣớc khi gọi phần đầu hàm nó sẽ sinh ra một cảnh báo trong việc thực thi tập 

lệnh. Ở đây là một vài kiểu lỗi: 

<?php 

header(“Location:form3.php”); 

?> 

Đoạn mã này sẽ thất bại. Dòng bắt đầu tập lệnh rỗng sẽ gửi đến phần đầu với 

một điều khiển trả về và một đƣờng vận chuyển (phụ thuộc vào hệ điều hành). 

<?php 

echo “foobar”; 

header(“Location:form3.php”); 

?> 

Đoạn mã này sẽ thất bại. Hàm xuất ra sẽ gửi phần đầu với text “foobar” 

5.2.6.  Tiêu đề trang động 

Mã này thì dễ hiểu hơn: Bạn không bắt đầu xuất ra sớm nhƣ bắt đầu thực thi 

tập lệnh PHP. Điều gì sẽ xảy ra khi điểm bắt đầu tập lệnh sẽ kiểm tra sự xâm nhập 

và kiểm tra ngữ cảnh. Trong ví dụ này, bạn không sắp xếp mã ngữ cảnh phức tạp, 

nhƣng bạn cần đặt tiêu đề trang động sử dụng kiểu action và kiểu item, bạn sẽ sử 

dụng handle của trang. 

$title = $_POST[„Submit‟] . “ “ . 

$_POST[„type‟] . “ : “ . 

  - 116 - 

$_POST[„Name‟]; 

?> 

<html> 

<head> 

<title><?php echo $title; ?></title> 

5.2.7.  Điều khiển một chuỗi bằng tay nhƣ một mảng để đổi ký tự đầu 

tiên 

Chuỗi ký tự đơn giản có thể cập nhật thông qua cú pháp đơn giản giống nhƣ 

việc cập nhật chỉ mục của mảng. Chỉ mục đặc biệt của ký tự muốn cập nhật và 

voilà! Để đổi một ký tự hoặc toàn bộ chuỗi, sử dụng hàm: strtoupper(): 

$name = $_POST[„Name‟]; 

$name[0] = strtoupper( $name[0]);     

Bạn có thể dùng hàm ucfirst() 

5.2.8.  Toán tử tam nguyên 

Dòng dƣới đây chứa sự so sánh phép toán bậc ba. Toán tử tam nguyên không 

chỉ sử dụng trong PHP mà những ngôn ngữ khác cũng sử dụng (nhƣ C). 

<?php echo $_POST[„Submit‟] == “Search” ? “for “ : “”; ?> 

Việc này có thể so sánh nhƣ cấu trúc if-else,  

 [biểu thức]?[thực hiện nếu TRUE]: [thực hiện nếu FALSE]; 

Toán tử tam nguyên này thì đƣợc biết nhƣ mối nguy hiểm lâu dài. Việc sử 

dụng nó sẽ làm cho đoạn mã của bạn dễ đọc hơn và có thể gây ra lỗi trong thời gian 

dài. 

5.3.  Kết hợp những phần tử của form 

Bây giờ chúng ta tạo ra một khung cho một phim ứng dụng. Hệ thống sẽ thêm 

những mục mới hoặc tìm kiếm những cái có sẵn. 

Ví dụ: Liên kết tất cả chúng lại với nhau 

Trong ví dụ này, bạn sẽ tạo ra nhiều tập lệnh mới làm việc với nhau để tái tạo cho 

phép ngƣời dùng thêm thông tin vào dữ liệu.  

1.  Tạo một file tên form4.php  

Nhập đoạn code nhƣ sau: 

  - 117 - 

<?php 

// Hiển thị thông tin biên dịch 

function debugDisplay()  

?> 

<pre> 

$_POST 

<?php 

print_r($_POST); 

?> 

$_GET 

<?php 

print_r($_GET); 

?> 

</pre> 

<?php 

if (!isset($_GET[„step‟]))  

require(„startform.php‟); 

}  

else  

// Switch on search/add wizard step 

switch ($_GET[„step‟])  

// ################# 

// Search/Add form 

// ################# 

case “1”: 

$type = explode(“:”, $_POST[„type‟]); 

  - 118 - 

if ($_POST[„Submit‟] == “Add”)  

require($_POST[„Submit‟] . $type[0] . „.php‟); 

} else 

 { 

if ($_POST[„type‟] == “Movie:Movie” && 

$_POST[„MovieType‟] == “”) 

header(“Location:form4.php”); 

?> 

<h1>Search Results</h1> 

<p>You  are  looking  for  a  “<?php  echo  $type[1];  ?>” 

named 

“<?php echo $_POST[„Name‟]; ?>”</p> 

<?php 

if ($_POST[„Debug‟] == “on”) 

debugDisplay(); 

break; 

// ################# 

// Add Summary 

// ################# 

case “2”: 

$type = explode(“:”, $_POST[„type‟]); 

?> 

<h1>New  <?php  echo  $type[1];  ?>  :  <?php  echo 

$_POST[„Name‟]; ?></h1> 

<?php 

  - 119 - 

switch ($type[0]) 

 { 

case “Movie”: 

?> 

<p>Released  in  <?php  echo  $_POST[„MovieYear‟]; 

?></p> 

<p><?php  echo  nl2br(stripslashes($_POST[„Desc‟])); 

?></p> 

<?php 

break; 

default: 

?> 

<h2>Quick Bio</h2> 

<p><?php  echo  nl2br(stripslashes($_POST[„Bio‟])); 

?></p> 

<?php 

break; 

break; 

// ############### 

// Starting form 

// ############### 

default: 

require(„startform.php‟); 

break; 

?> 

2.  Tạo một file với tên startform.php và nhập mã sau 

<html> 

<head> 

  - 120 - 

<title>Multipurpose Form</title> 

<style type=”text/css”> 

TD{color:#353535;font-family:verdana} 

TH{color:#FFFFFF;font-family:verdana;background-color:#336699} 

</style> 

</head> 

<body> 

<form action=”form4.php?step=1” method=”post”> 

<table border=”0” width=”750” cellspacing=”1” cellpadding=”3” 

bgcolor=”#353535” align=”center”> 

<tr> 

<td bgcolor=”#FFFFFF” width=”30%”>Name</td> 

<td bgcolor=”#FFFFFF” width=”70%”> 

<input type=”TEXT” name=”Name”> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Item Type</td> 

<td bgcolor=”#FFFFFF”> 

<input type=”radio” name=”type” value=”Movie:Movie” checked> 

Movie<br> 

<input type=”radio” name=”type” value=”Person:Actor”> 

Actor<br> 

<input type=”radio” name=”type” value=”Person:Director”> 

Director<br> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Movie type (if applicable)</td> 

<td bgcolor=”#FFFFFF”> 

  - 121 - 

<select name=”MovieType”> 

<option value=”” selected>Movie type...</option> 

<option value=”Action”>Action</option> 

<option value=”Drama”>Drama</option> 

<option value=”Comedy”>Comedy</option> 

<option value=”Sci-Fi”>Sci-Fi</option> 

<option value=”War”>War</option> 

<option value=”Other”>Other...</option> 

</select> 

</td> 

</tr> 

<tr> 

<td  bgcolor=”#FFFFFF”  width=”50%”>Display  Debug 

Dump</td> 

<td bgcolor=”#FFFFFF” width=”50%”> 

<input type=”checkbox” name=”Debug” checked> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF” colspan=2 align=”center”> 

<input type=”submit” name=”Submit” value=”Search”> 

<input type=”submit” name=”Submit” value=”Add”> 

</td> 

</tr> 

</table> 

</form> 

</body> 

</html> 

4. Tạo một file mới với tên AddMovie.php: 

<?php 

if ($_POST[„type‟] == “Movie:Movie” && 

  - 122 - 

$_POST[„MovieType‟] == “”) { 

header(“Location:form4.php”); 

$title = $_POST[„Submit‟] . “ “ . 

$_POST[„type‟] . “ : “ . 

$_POST[„Name‟]; 

$name = $_POST[„Name‟]; 

$name[0] = strtoupper($name[0]); 

?> 

<html> 

<head> 

<title><?php echo $title; ?></title> 

<style type=”text/css”> 

TD{color:#353535;font-family:verdana} 

TH{color:#FFFFFF;font-family:verdana;background-color:#336699} 

</style> 

</head> 

<body> 

<form action=”form4.php?step=2” method=”post”> 

<input type=”hidden” name=”type” value=”<?php echo $type[1]; ?>”> 

<input type=”hidden” name=”action” 

value=”<?php echo $_POST[„Submit‟]; ?>”> 

<table border=”0” width=”750” cellspacing=”1” cellpadding=”3” 

bgcolor=”#353535” align=”center”> 

<tr> 

<td bgcolor=”#FFFFFF” width=”30%”>Movie Name</td> 

<td bgcolor=”#FFFFFF” width=”70%”> 

<?php echo $name; ?> 

<input type=”hidden” name=”Name” value=”<?php echo $name; ?>”> 

</td> 

</tr> 

  - 123 - 

<tr> 

<td bgcolor=”#FFFFFF”>Movie Type</td> 

<td bgcolor=”#FFFFFF”> 

<?php echo $_POST[„MovieType‟]?><br> 

<input type=”hidden” name=”type” 

value=”Movie: <?php echo $_POST[„MovieType‟]; ?>”> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Movie Year</td> 

<td bgcolor=”#FFFFFF”> 

<select name=”MovieYear”> 

<option value=”” selected>Select a year...</option> 

<?php 

for ($year=date(“Y”); $year >= 1970 ;$year--) { 

?> 

<option value=”<?php echo $year; ?>”><?php 

echo $year; ?></option> 

<?php 

?> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Movie Description</td> 

<td bgcolor=”#FFFFFF”> 

<textarea name=”Desc” rows=”5” cols=”60”></textarea> 

</td> 

</tr> 

<tr> 

  - 124 - 

<td bgcolor=”#FFFFFF” colspan=”2” align=”center”> 

<input type=”submit” name=”SUBMIT” value=”Add”> 

</td> 

</tr> 

</table> 

</form> 

</body> 

</html> 

5. Tạo một file mới với tên AddPerson.php và nhập đoạn mã sau 

<?php 

$title = $_POST[„Submit‟] . “ “ . 

$_POST[„type‟] . “ : “ . 

$_POST[„Name‟]; 

$name = $_POST[„Name‟]; 

$name[0] = strtoupper($name[0]); 

?> 

<html> 

<head> 

<title><?php echo $title; ?></title> 

<style type=”text/css”> 

TD{color:#353535;font-family:verdana} 

TH{color:#FFFFFF;font-family:verdana;background-color:#336699} 

</style> 

</head> 

<body> 

<form action=”form4.php?step=2” method=”post”> 

<input type=”hidden” name=”type” 

value=”Person: <?php echo $type[1]; ?>”> 

<input type=”hidden” name=”action” 

value=”<?php echo $_POST[„Submit‟]; ?>”> 

  - 125 - 

<table border=”0” width=”750” cellspacing=”1” cellpadding=”3” 

bgcolor=”#353535” align=”center”> 

<tr> 

<td bgcolor=”#FFFFFF” width=”30%”> 

<?php echo $type[1]; ?> Name 

</td> 

<td bgcolor=”#FFFFFF” width=”70%”> 

<?php echo $name?> 

<input  type=”hidden”  name=”Name”  value=”<?php  echo  $name; 

?>”> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Quick Bio</td> 

<td bgcolor=”#FFFFFF”> 

<textarea name=”Bio” rows=”5” cols=”60”></textarea> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF” colspan=”2” align=”center”> 

<input type=”submit” name=”SUBMIT” value=”Add”> 

</td> 

</tr> 

</table> 

</form> 

</body> 

</html> 

6. Cho chạy form4.php trên trình duyệt. Kết quả nhƣ sau: 

  - 126 - 

Hình  5.3.1 

7. Nhập tên phim: “Grand Canyon.” 

8. Click vào nút Add, cho bạn hình nhƣ sau: 

Hình  5.3.2 

9. Chọn một ngày trong năm sản xuất phim 

10. Chọn Drama trong danh sách loại phim. 

11. Hiển thị nhanh phim, nếu muốn nhập vào đâu, enter tại đó 

12. Click vào  nút Add và thấy thông tin hiển thị nhƣ sau: 

  - 127 - 

Hình  5.3.3 

Khi nhấn nút Add màn hình hiển thị: 

Hình  5.3.4 

Cách thức hoạt động 

Tập lệnh này thiết kế xung quanh  một ý tƣởng đơn giản: một tập lệnh khung 

(form4.php) và nhiều tập lệnh flesh-andmuscle trên URL với chuổi truy vấn. 

5.3.1.  Tập lệnh khung 

Khung ở dây là tập lệnh form4.php. Tất cả nó quay xung quanh việc sử dụng 

cấu trúc switch case. Nó bắt đầu với việc định nghĩa hàm  cho việc hiển thị trình 

biên dịch(cái mà chứa hiển thị củẩmng toàn cục $_GET ). 

Trong thực tế form sử dụng phƣơng thức POST và  vì vậy truyền thông tin đến 

mảng $_POST, phần nội dung chuyển đổi của trang sẽ qua chuổi truy vấn của mảng 

$GET 

  - 128 - 

Mỗi bƣớc trong quá trình xây dựng thì đƣợc hƣớng dẫn bởi giá trị chỉ mục 

$GET[„bƣớc‟]. Nó chứa thông tin qua phần ?step=1 của URL. 

Mỗi giá trị của tham số GET có một tập lệnh đặc biệt kèm theo. Tham số này 

cho tập lệnh chính(index.php) nơi mà một nhánh tiến trình dữ liệu đƣợc nhận. 

5.3.2.  Câu trả lời mặc định 

Điều gì sẽ xảy ra khi gọi trang đầu tiên và bƣớc tham số URL không đƣợc 

thiết lặp? tập lệnh đánh giá điều kiện switch và tìm các trƣờng hợp.Nếu không có sẽ 

thực thi mặc định. 

switch ($_GET[„step‟]) { 

... 

default: 

require(„startform.php‟); 

break; 

Hàm  require() lấy nội dung của file lý thuyết kể cả tập lệnh phiên dịch cùng 

lúc. Những khác biệt của hàm requere() với hàm include() là nó khởi tạo một lỗi lớn 

thay  vì  một  cảnh  báo  nếu  file  không  tìm  thấy.  Trong  ví  dụ  này,  tập  lệnh 

startform.php sẽ ít quy tụ trong hàm, vì thế mà bạn muốn biết nếu không tìm thấy 

file. 

5.3.3.  Thêm mục con 

Bạn cần hai form khác nhau để thêm vào mục con, vì thế cần nhánh thứ hai để 

quyết định form hiển thị. 

Bây giờ chúng ta gặp phải một phần lệnh mà có một ít mƣu mẹo. Danh sách 

giá trị mục con sử dụng lƣu trữ 2 giá trị thay vì một. Cách này dùng dấu phân cách 

và đƣa giá trị explode vào mảng, cập nhật phần bạn cần.(Hàm explode() lấy mỗi 

đơn vị văn bản bằng dấu ngăn cách và chèn nó nhƣ phần tử mới của mảng. 

Trong trƣờng hợp bạn có 3 kiểu mục(Actors, Directors, and Movies), mỗi kiểu 

yêu cầu  một form. Nhƣng bạn muốn mục Actor và mục Director cùng thông tin . 

Do đó, bạn không cần hai form khác nhau. Bạn làm điều này bằng việc thêm 

vào một cấu trúc cây bên trên mục Person hay Movie. Dƣới Person là  Actor và 

  - 129 - 

Director . Toàn bộ điểm có thể sử dụng mức độ tên của hệ đẳng cấp mới đến tên file 

và bạn có thể thêm một mức độ mới su đó 

Trong startform.php bạn có: 

<input type=”radio” name=”type” value=”Person:Actor”> 

Actor<br> 

Chú ý: phần giá trị của kiểu phần tử bao gồm 2 giá trị khác nhau ngăn cách bởi 

dấu chấm phẩy(;). 

Trong form4.php bạn có: 

... 

$type = explode(“:”, $_POST[„type‟]); 

if ($_POST[„Submit‟] == “Add”) { 

require($_POST[„Submit‟] . $type[0] . „.php‟); 

... 

Trong tập lệnh này, bạn lấy lại giá trị kiểu phần tử sử dụng chỉ mục mảng 

$_POST[„kiểu‟]  và  sau  đó  sử  dụng  hàm explode() trên  nội  dung  của  nó.Hàm 

explode() thì khá dễ sử dụng. Nó cần chuỗi giới hạn đặc biệt và chuỗi chứa văn bản 

để explode. 

Ví dụ, bạn có “Person:Actor” nhƣ giá trị để explode và dấu hai chấm (:)  nhƣ 

giới hạn. Kết quả của biến $type sẽ là một mảng chứa một phần của chuỗi cắt tại 

dấu(;) trong ví dụ 

Nếu bạn trình bày nó trong định dạng print_r, bạn có: 

Array 

[0] => Person 

[1] => Actor 

Mục tiêu của tên file đơn giản đƣợc hoàn thành. Bạn có hai tập lệnh Add 

và một tên:  

AddPerson.php and AddMovie.php. 

require($_POST[„Submit‟] . $type[0] . „.php‟); 

  - 130 - 

Dòng này tạo tên tự động. 

  - 131 - 

Chƣơng  6:  CHO PHÉP NGƢỜI SỬ DỤNG SOẠN THẢO 

CƠ SỞ DỮ LIỆU 

Nhận dữ liệu từ cơ sở dữ liệu khi cung cấp một vài dữ liệu cho cơ sở dữ liệu. 

Nhƣng cơ sở dữ liệu thì không tạo ra nội dung mà chỉ lấy dữ liệu từ hệ thống khác. Điều 

này có nghĩa là bạn phải tạo hệ thống dữ liệu từ PHP. 

Tất cả cơ sở dữ liệu tƣơng tác dựa trên SQL. Bạn biết là cú pháp SQL lấy dữ liệu 

từ mảng. 

Hầu hết mọi ngƣời dùng SQL  để chèn dữ liệu mà PHP sửa đổi hoặc tạo ra. 

  Chƣơng này đề cập đến soạn thảo cơ sở dữ liệu, bao gồm:. 

   Thêm: điều này thì đơn giản, nhƣng bạn sẽ tìm để thêm vào trong một cơ sở dữ liệu 

  Xóa: không sửa đổi lại cấu trúc cơ sở dữ liệu và có liên quan đến tính toàn vẹn. 

  Sữa đổi: thay thế một vài vùng soạn thảo với nội dung mới trong  một hồ sơ có 

sẵn. 

6.1.  Chuẩn bị Battlefield 

Điều này đầy đủ và hoàn chỉnh nhƣ 1 đơn vị Vulcan, nhƣng nếu muốn quản lý cơ 

sở dữ liệu thì biến toàn cục phải đƣợc tạo ra. Để lƣu trong cùng một thời gian thì chúng ta 

sử dụng cơ sở dữ liệu hiện có để tránh bất kì vấn đề gì xảy ra khi làm bài tập. Tạo ra một 

cơ sở dữ liệu mới rỗng trong phpMyAdmin với tên moviesite. Trong cơ sở dữ liệu mới 

đƣợc tạo ra, thực thi tập lệnh chap6.mysql script, chứa cơ sở dữ liệu và dữ liệu của nó 

đƣợc bắt đầu. 

  Ví dụ: 

  Trƣớc tiên , bạn cần một trang bắt đầu. Sau đây là những bƣớc tạo 

  1. Tạo thƣ mục mới tên chap6 trong htdocs 

  2. Tao 1 file index.php và nhập đoạn mã nhƣ sau 

<?php 

$link = mysql_connect(“localhost”, “root”, “”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(„moviesite‟, $link) 

or die(mysql_error()); 

?> 

  - 132 - 

<html> 

<head> 

<title>Movie database</title> 

<style type=”text/css”> 

TD{color:#353535;font-family:verdana} 

TH{color:#FFFFFF;font-family:verdana;background-color:#336699} 

</style> 

</head> 

<body> 

<table border=”0” width=”600” cellspacing=”1” cellpadding=”3” 

bgcolor=”#353535” align=”center”> 

<tr> 

<td bgcolor=”#FFFFFF” colspan=”2” align=”center”> 

Movies <a href=”movie.php?action=add&id=”>[ADD]</a> 

</td> 

</tr> 

<?php 

$moviesql = “SELECT * FROM movie”; 

$result = mysql_query($moviesql) 

or die(“Invalid query: “ . mysql_error()); 

while ($row = mysql_fetch_array($result)) { 

?> 

<tr> 

<td bgcolor=”#FFFFFF” width=”50%”> 

<?php echo $row[„movie_name‟]; ?> 

</td> 

<td bgcolor=”#FFFFFF” width=”50%” align=”right”> 

<a href=”movie.php?action=edit&id=<?php 

echo $row[„movie_id‟]; ?>”>[EDIT]</a> 

<a href=”delete.php?type=movie&id=<?php 

echo $row[„movie_id‟]?>”>[DELETE]</a> 

  - 133 - 

</td> 

</tr> 

<?php 

?> 

<tr> 

<td bgcolor=”#FFFFFF” colspan=”2” align=”center”> 

People <a href=”people.php?action=add&id=”>[ADD]</a> 

</td> 

</tr> 

<?php 

$moviesql = “SELECT * FROM people”; 

$result = mysql_query($moviesql) 

or die(“Invalid query: “ . mysql_error()); 

while ($row = mysql_fetch_array($result)) { 

?> 

<tr> 

<td bgcolor=”#FFFFFF” width=”50%”> 

<?php echo $row[„people_fullname‟]; ?> 

</td> 

<td bgcolor=”#FFFFFF” width=”50%” align=”right”> 

<a href=”people.php?action=edit&id=<?php 

echo $row[„people_id‟]; ?>”>[EDIT]</a> 

<a href=”delete.php?type=people&id=<?php 

echo $row[„people_id‟]; ?>”>[DELETE]</a> 

</td> 

</tr> 

<?php 

?> 

</table> 

  - 134 - 

</body> 

</html> 

3. Mở trinh duyệt http://localhost/chapter6/index.php  kết quả nhƣ sau: 

Hình  6.1-1 

Tất cả các liên kết tại thời điểm này đều không đƣợc thực hiện, chuyện này là bình 

thƣờng vì chƣa có các trang để liên kết. 

Cách thức làm việc 

Bạn phải có một giao diện quản lý trung tâm cho phép bạn thi hành những hoạt 

động trong cơ sở dữ liệu và dễ dàng thấy nội dung. Tập lệnh này là giao diện quản lý. Nó 

hiển thị và cho phép quản lý mọi thứ. 

6.2.  Chèn một mẫu tin đơn giản từ phpMyAdmin 

Chú ý rằng tập lệnh sử dụng là một quy tắc đơn giản có liên quan đến SQL: Phải cố 

gắng truy vấn trong MySQL trƣớc khi thử chèn nó trong đoạn mã. Lý do đơn giản là bạn 

có thể biên dịch ngôn ngữ tốt hơn trong mọi thời gian 

Ví dụ về chèn dữ liệu 

Trong bài tập này bạn sẽ chèn một vài dữ liệu vào bảng 

1.Mở cơ sở dữ liệu của bạn trong MyAddmin hoặc trong máy khách MySQL và nhập mã 

SQL sau: 

INSERT INTO movie (movie_name, movie_type, movie_year) 

VALUES („Bruce Almighty‟, „1‟, „2003) 

Nhƣ Hình 6.2.1 

  - 135 - 

Hình 6.2.1 

2.Thông báo sau xuất hiện nhƣ Hình 6.2.2 

You  have an error in your SQL syntax. Check the  manual that corresponds 

to your MySQL server version for the right syntax to use near „‟2003)‟ at line 

          Hình 6.2.2 

3. Đƣa lỗi nhƣ đề nghị này ( hoàn toàn đơn giản để làm với một số ký tự, phải nháy  đơn 

sau 2003) và chạy phpMyAdmin sau đó hiển thị thực thi SQL và hƣớng dẫn bạn về hiển 

thị nội dung của bảng nhƣ trong Hình 6.3.3 

  - 136 - 

Hình 6.2.3 

  Trƣớc  khi  truy  vấn  SQL  trong  PHP,  bạn  nên  kiểm  tra  câu  lệnh  SQL  trong 

phpMyAdmin. Nó có thể biên dịch SQL trƣớc khi chèn vào đoạn mã và ngăn chặn việc 

biên dịch hai ngôn ngữ khác nhau trong cùng thời gian. 

  Cách thức làm việc 

  Khi chèn một mẩu tin trong bảng, không cần chèn ID nếu bạn đặt ở vùng khóa 

chính tự động giảm. SQL sẽ dễ dàng. Điều này chắc chắn rằng không có những khóa 

giống nhau trong bảng. 

Để  lấy  id  tự  động  của  mẩu  tin  chèn  trong  PHP  phải  sử  dụng  hàm 

mysql_insert_id() sau đó gọi hàm mysql_query(). Hàm này trả về khóa chính khi chèn 1 

mẩu tin mới. 

Bởi vì bạn đã tạo truy vấn SQL nhiều hơn một dòng, bạn có thể thấy thông báo 

sau: 

You  have an error in your SQL syntax. Check the  manual that corresponds 

to your MySQL server version for the right syntax to use near „‟2003)‟ at line 

Dòng  này  tƣơng  ứng  với  một  phần  giá  trị  của  câu  lệnh  SQL,  nhƣ  hiển  thị  ở 

đây:VALUES („Bruce Almighty‟, „1‟, „2003) 

   Nếu truy vấn SQL ở trên một dòng thì chỉ có một thông báo “error in line 1”.  Bạn 

có thể thấy điểm sai là bạn quên đóng dấu nháy trong giá trị movie_year value. 

  Bây giờ bạn có thể thấy chúng ta đã bỏ sót trong vùng movie. movie _id. Chúng ta 

làm điều này có mục đích. (Không có một sức mạnh đặc biệt của giá trị khóa chính nào 

trong phƣơng tiện của MySQL để tự động quyết định giảm giá trị tự động). Bạn không 

cần biết khóa tiếp theo là gì  

  - 137 - 

6.3.  Chèn một mẩu tin trong cơ sở dữ liệu quan hệ 

Trong cơ sở dữ liệu thƣờng có nhiều bảng. Tất cả các bảng này có thể  hoàn toàn 

độc lập, nhƣng sẽ giống nhƣ việc sử dụng xe hơi của bạn để lƣu trữ một vài thứ trong 

thùng xe  nhƣng không bao giờ lái xe. 

  Trong hệ thống cũ của cơ sở dữ liệu quan hệ không tồn tại, mỗi dòng chứa tất cả 

các thông tin. Hệ thống đang chạy chỉ với một bảng chứa tất cả các thông tin. Bảng 

movie sẽ chứa tất cả các dữ liệu về diễn viên và đạo diễn và những loại khác trong phim. 

Giả sử rằng một ngày nào đó bạn quyết định một loại film nào đó sẽ đƣợc chuyển từ hành 

động sang thám hiểm (thay đổi mọi thứ). Bạn sẽ thông qua tất cả mẩu tin để thay đổi các 

nhãn film. 

  Trong hệ quản trị cơ sở dữ liệu mới(RDBMS), nó không hơn trƣờng hợp nào, bạn 

sẽ tạo ra một bảng movietype lƣu trữ tất cả các loại film đƣợc chuyển đến  và bạn sẽ liên 

kết những loại film đó với loại film có liên quan. 

  Để liên kết những bảng đó, bạn sử dụng một loại khóa chính/khóa ngoại. Khóa 

chính của bảng movietype là một số xác định cho mỗi loại film. Ví dụ trong cơ sở dữ liệu 

của bạn id 1 có liên quan đến film hài. Khóa ngoại là quan hệ giữa bảng movie đến  khóa 

chính của movietype.  

  Trong bài tập sau bạn sử dụng PHP và MySQL để chèn một bộ film vào cơ sở dữ 

liệu . Film này là một loại film từ bảng movietype. 

  Ví dụ : Chèn một bộ film với ngƣời và loại film đã biết. 

Trong thời gian này chúng ta sẽ làm một vài thứ phức tạp hơn. Bạn sẽ thêm một 

bộ film vào hệ thống, trong khi ghi rõ có sẵn loại film, diễn viên và đạo díễn.  

1. Tạo một file mới tên movie.php và nhập đoạn mã sau: 

<?php 

$link = mysql_connect(“localhost”, “bp5am”, “bp5ampass”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(„moviesite‟, $link) 

or die ( mysql_error()); 

$peoplesql = “SELECT * FROM people”; 

$result = mysql_query($peoplesql) 

or die(“Invalid query: “ . mysql_error()); 

  - 138 - 

while ($row = mysql_fetch_array($result))  

$people[$row[„people_id‟]] = $row[„people_fullname‟]; 

?> 

<html> 

<head> 

<title>Add movie</title> 

<style type=”text/css”> 

TD{color:#353535;font-family:verdana} 

TH{color:#FFFFFF;font-family:verdana;background-color:#336699} 

</style> 

</head> 

<body> 

<form action=”commit.php?action=add&type=movie” method=”post”> 

<table border=”0” width=”750” cellspacing=”1” cellpadding=”3” 

bgcolor=”#353535” align=”center”> 

<tr> 

<td bgcolor=”#FFFFFF” width=”30%”>Movie Name</td> 

<td bgcolor=”#FFFFFF” width=”70%”> 

<input type=”text” name=”movie_name”> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Movie Type</td> 

<td bgcolor=”#FFFFFF”> 

<select id=”game” name=”movie_type” style=”width:150px”> 

<?php 

$sql = “SELECT movietype_id, movietype_label “ . 

“FROM movietype ORDER BY movietype_label”; 

$result = mysql_query($sql) 

  - 139 - 

or die(“<font color=\”#FF0000\”>Query Error</font>” . 

mysql_error()); 

while ($row = mysql_fetch_array($result)) { 

echo „<option value=”‟ . $row[„movietype_id‟] . „“>‟ . 

$row[„movietype_label‟] . „</option>‟ . “

”; 

?> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Movie Year</td> 

<td bgcolor=”#FFFFFF”> 

<select name=”movie_year”> 

<option value=”” selected>Select a year...</option> 

<?php 

for ($year = date(“Y”); $year >= 1970; $year--) { 

?> 

<option value=”<?php echo $year; ?>”><?php 

echo $year; ?></option> 

<?php 

?> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Lead Actor</td> 

<td bgcolor=”#FFFFFF”> 

<select name=”movie_leadactor”> 

<option value=”” selected>Select an actor...</option> 

  - 140 - 

<?php 

foreach ($people as $people_id => $people_fullname) { 

?> 

<option value=”<?php echo $people_id; ?>” > 

<?php 

echo $people_fullname; ?></option> 

<?php 

?> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Director</td> 

<td bgcolor=”#FFFFFF”> 

<select name=”movie_director”> 

<option value=”” selected>Select a director...</option> 

<?php 

foreach ($people as $people_id => $people_fullname) { 

?> 

<option value=”<?php echo $people_id; ?>” > 

<?php 

echo $people_fullname; ?></option> 

<?php 

?> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF” colspan=”2” align=”center”> 

  - 141 - 

<input type=”submit” name=”SUBMIT” value=”Add”> 

</td> 

</tr> 

</table> 

</form> 

</body> 

</html> 

2. Lƣu file và đƣa lên server trong thƣ mục chap6. 

3. Tạo một file mới tên commit.php và nhập đoạn mã: 

<?php 

// COMMIT ADD 

$link = mysql_connect(“localhost”, “bp5am”, “bp5ampass”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(„moviesite‟, $link) 

or die ( mysql_error()); 

switch ($_GET[„action‟]) 

 { 

case “add”: 

switch ($_GET[„type‟]) 

 { 

case “movie”: 

$sql = “INSERT INTO movie 

(movie_name, 

movie_year, 

movie_type, 

movie_leadactor, 

movie_director) 

VALUES 

(„“ . $_POST[„movie_name‟] . “„, 

„“ . $_POST[„movie_year‟] . “„, 

„“ . $_POST[„movie_type‟] . “„, 

  - 142 - 

„“ . $_POST[„movie_leadactor‟] . “„, 

„“ . $_POST[„movie_director‟] . “„)”; 

break; 

break; 

if (isset($sql) && !empty($sql)) 

 { 

echo “<!--” . $sql . “-->”; 

$result = mysql_query($sql) 

or die(“Invalid query: “ . mysql_error()); 

?> 

<p align=”center” style=”color:#FF0000”> 

Done. <a href=”index.php”>Index</a> 

</p> 

<?php 

?> 

4. Lƣu file vào thƣ mục chap6. 

5. Mở trình duyệt trang index.php và click ADD tiếp theo phần đầu của bảng movie. Kết 

quả nhƣ Hình 6.3.1 

Hình 6.3.1 

6. Thêm 1 movie named “Test” với kiểu tự do, diễn viên, và đạo diễn nhƣ Hình 6.3.2 

  - 143 - 

Hình 6.3.2 

7.  Click vào nút “add” bạn sẽ thấy nhƣ Hình 6.3.3 

Hình 6.3.3 

Cách thức làm việc 

Form  HTML  cho phép bạn điều khiển cách ngƣời dùng nhập dữ liệu. Một  nút 

submit, form  gửi thông tin đến server  mà PHP có thể sử dụng chung và chạy câu lệnh 

SQL INSERT. 

Nhƣ bạn thấy trong việc chèn film trong movie.php, bạn có 4 combo boxes và  

một vùng Text. Nội dung vùng text đƣợc nhập tự do, nhƣng combox thì hoàn toàn theo 

chỉ dẫn. Chúng ta hãy xem lại nội dung của combox từ nội dung cơ sở dữ liệu.   

Trƣớc tiên, chúng ta hãy thử trong combox. Mỗi danh sách combox biểu diễn một 

ngƣời. 

<?php 

$link = mysql_connect(“localhost”, “root”, “”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(„moviesite‟, $link) 

  - 144 - 

or die ( mysql_error()); 

$peoplesql = “SELECT * FROM people”; 

$result = mysql_query($peoplesql) 

or die(“Invalid query: “ . mysql_error()); 

while ($row = mysql_fetch_array($result))  

$people[$row[„people_id‟]] = $row[„people_fullname‟]; 

?> 

  Vào lúc bắt đầu tập lệnh, bạn truy vấn bảng ngƣời và đặt nội dung của nó trong 

mảng. Dữ liệu ngƣời lƣu trữ trong bảng ngƣời. Danh sách chung của ngƣời, bạn truy vấn 

cơ sở dữ liệu đơn giản, lấy lại tất cả những gì liên quan đến ngƣời trong hệ thống  và hiển 

thị tên trong combox và chuyển đến khóa chính nhƣ giá trị mục.  

 Mỗi ngƣời đƣợc biết sẽ có một mục trong combox. 

<select name=”movie_director”> 

<option value=”” selected>Select a director...</option> 

<?php 

foreach ($people as $people_id => $people_fullname)  

?> 

<option value=”<?php echo $people_id; ?>” ><?php 

echo $people_fullname; ?></option> 

<?php 

?> 

</select> 

  Ở đây bạn sử dụng cú pháp foreach để đi đến tất cả các chọn lựa trong mảng. Loại 

phim tổng quan trong combobox, điều này thuận tiện hơn cho việc sử dụng nội dung 

SQL chung. Bạn dùng lại đoạn mã này để tạo ra một form có đặc điểm chung để thêm và 

chỉnh sửa, vì thế bạn cần phải hiểu chi tiết về việc này. 

<select id=”game” name=”movie_type” style=”width:150px”> 

  - 145 - 

<?php 

$sql = “SELECT movietype_id, movietype_label “ . 

“FROM movietype ORDER BY movietype_label”; 

$result = mysql_query($sql) 

or die(“<font color=\”#FF0000\”>Query Error</font>” . 

mysql_error()); 

while ($row = mysql_fetch_array($result))  

echo „<option value=”‟ . $row[„movietype_id‟] . „“>‟ . 

$row[„movietype_label‟] . „</option>‟ . “

”; 

?> 

</select> 

  Đoạn  mã  này  tạo  ra  những  lựa  chọn  trong  combobox  bằng  bảng  truy  vấn 

movietype để trích ra các loại phim có sẵn.  

  Mỗi lựa chọn sẽ có một kiểu id nhƣ một giá trị và loại phim mà tự  nó là một nhãn. 

  Form đã sẳn sàng, bạn cần có một tập lệnh để sử dụng cơ sở dữ liệu tạo ra các  

mẫu tin. Nhƣ bạn có thể thấy  switch case  on $_GET[„action‟] thì lúc này  hoàn toàn 

không sử dụng. Trong bài tập tiếp theo bạn thêm  vào nhiều đoạn  mã trong tập lệnh 

movie.php, vì vậy bạn có thể sử dụng nó để chỉnh sửa phim . 

6.4.  Xóa một mẩu tin 

Xóa một mẩu tin thì dễ dàng. Nhƣ đã đề cập từ trƣớc, luôn phải kiểm tra truy vấn 

trong cơ sở dữ liệu thử nghiệm. Việc xóa một mẩu tin trong cơ sở dữ liệu thử nghiệm 

không bao giờ là mối đe dọa cho hệ thống của bạn. Và việc kiểm tra truy vấn giúp bạn 

tìm ra những lỗi SQL trƣớc khi xóa tất cả các mẩu tin trong cơ sở dữ liệu  bởi vì bạn quên 

một vài thứ nhƣ câu lệnh WHERE. MySQL xóa những thứ thỏa câu lệnh SQL. 

Xóa có nghĩa là mất dữ liệu. Để xóa một mẩu tin bạn cần biết vị trí của mẩu tin 

trong cơ sở dữ liệu thông qua một tập hợp các câu lệnh điều kiện WHERE. Mỗi lần câu 

lệnh đƣợc thực thi mẩu tin sẽ bị xóa, không thể quay lại. Mẩu tin bị xóa không hy vọng 

trả lại. Đây là điều cần lƣu ý khi sử dụng câu lệnh DELETE. 

Ví dụ: Xóa mẩu tin đơn giản 

  - 146 - 

Trƣớc khi bảo PHP xóa mọi thứ, bạn nên thử xóa một mẩu tin từ phpMyAdmin với 

câu lệnh DELETE. 

1. Mở phpMyAdmin và nhập đoạn mã sau: 

DELETE FROM movie 

WHERE movie_id = 12 

LIMIT 1 

2. phpMyAdmin trả lại thông báo rằng bạn xóa một mẩu tin từ bảng  

  Cách thức hoạt động 

  Câu lệnh DELETE SQL sử dụng rất đơn giản, bạn sử dụng câu lệnh LIMIT 1 để 

giới hạn xóa một mẩu tin.  

  Một cơ sở dữ liệu thƣờng chứa những mẫu tin liên quan với nhau trong những 

bảng khác nhau. Xóa một vài mẫu tin không xem xét quan hệ của chúng, làm cho bạn 

khó hiểu. 

  Không may là MySQL không duy trì tính toàn vẹn.  

Để  tránh  vấn  đề  này  bạn  có  thể  dùng  form  phức  tạp  hơn  của  câu  lệnh 

DELETE,Cascade Delete, nhƣ đề cập trong phần sau 

   Ví dụ:Cascade Delete 

  Bây giờ bạn đã biết cách sử dụng DELETE, bạn sẽ thêm nó vào hệ thống để xóa 

thông tin một ngƣời từ hệ thống. Khi bạn lƣu trữ quan hệ một ngƣời trong bảng movie, 

bạn cần cập nhật nội dung của bảng, vì vậy bạn không cần xóa những gì liên quan tới 

ngƣời.  

  Xóa một ngƣời giống nhƣ cách mở khóa xe và mong đợi bãi giữ xe trống. Bạn cần 

để chắc chắn không liên quan đến việc xóa các mẩu tin còn lại. 

  Sau đây là những bƣớc thực thi Cascade Delete: 

1. Tạo một file mới với tên delete.php và nhập đoạn mã sau: 

<?php 

$link = mysql_connect(“localhost”, “bp5am”, “bp5ampass”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(„moviesite‟, $link) 

or die ( mysql_error()); 

// DELETE SCRIPT 

  - 147 - 

if (!isset($_GET[„do‟]) || $_GET[„do‟] != 1) { 

?> 

<p align=”center” style=”color:#FF0000”> 

Are you sure you want to delete this 

 <?php 

echo $_GET[„type‟]; ?>?<br> 

<a href=”<?php echo $_SERVER[„REQUEST_URI‟]; 

 ?>&do=1”>yes</a> 

or <a href=”index.php”>Index</a> 

</p> 

<?php 

} else  

if ($_GET[„type‟] == “people”) { 

// Xóa những gì liên quan đến ngƣời trong bảng movie 

// Xóa những gì liên quan đến lãnh đạo diễn viên 

$actor = “UPDATE movie 

SET movie_leadactor = „0‟ 

WHERE movie_leadactor = „“ . $_GET[„id‟] . “„“; 

$result = mysql_query($actor) 

or die(“Invalid query: “ . mysql_error()); 

// Xóa những gì liên quan đến đạo diễn 

$director = “UPDATE movie 

SET movie_director = „0‟ 

WHERE movie_director = „“ . $_GET[„id‟] . “„“; 

$result = mysql_query($director) 

or die(“Invalid query: “ . mysql_error()); 

// SQL chung 

$sql = “DELETE FROM “ . $_GET[„type‟] . “ 

WHERE “ . $_GET[„type‟] . “_id = „“ . $_GET[„id‟] . “„ 

  - 148 - 

LIMIT 1”; 

// xuất SQL cho mục đích 

echo “<!--” . $sql . “-->”; 

$result = mysql_query($sql) 

or die(“Invalid query: “ . mysql_error()); 

?> 

<p align=”center” style=”color:#FF0000”> 

Your <?php echo $_GET[„type‟]; ?> has been deleted. 

<a href=”index.php”>Index</a> 

</p> 

<?php 

?> 

2. Lƣu delete.php vào thƣ mục chap6. 

3.  Mở index.php trên trình duyệt. bạn sẽ thấy DELETE những liên kết tiếp sau mỗi film 

hoặc ngƣời nhƣ Hình 6.4.1 

Hình  6.4.1 

4. Thử  xóa  film mà bạn đã thêm  vào ở bài tập trƣớc bởi việc  click  vào liên  kết 

DELETE trên hàng “Test” movie name. Bạn sẽ thấy nhƣ Hình 6.4.2 . 

  - 149 - 

Hình  6.4.2 

5. Click vào liên kết “yes”  để xác nhân việc xóa và đợi thông báo xác nhận nhƣ Hình 

6.4.3 

Hình  6.4.3 

Cách thức hoạt động  

Ở đây là kế hoạch tiêu diệt 1 tập hợp vô tội của dữ liệu. Đặt nó sang một bên, 

chúng ta hay xem tập lệnh này hoạt động nhƣ thế nào.  

  Đầu tiên, bạn cần hiểu rằng bạn không thể xóa mẩu tin trong cơ sở dữ liệu và phải 

quên chúng đi. Việc xóa đƣợc xem xét cẩn thận. Ví dụ nếu xóa  một ngƣời từ bảng 

people, điều này ngăn cản bạn từ việc tìm ra một khả năng có liên quan đến ngƣời trong 

bảng movie. Nếu bạn xóa Jim Carrey từ bảng people, ai sẽ lãnh đạo diễn viên Bruce 

Almight? Nếu bạn không làm mọi thứ, id của Jim Carrey‟s sẽ còn lại trong mẩu tin và bạn 

sẽ có một cơ sở dữ liệu bị sữa đổi. Bạn không muốn điều này đúng không (câu trả lời là 

không) 

  - 150 - 

  Để giải quyết vấn đề này thì để chắc rằng bạn luôn có một khóa ngoại trong mẩu 

tin. Trong đoạn mã sau bạn cập nhật bảng film với giá trị 0 trƣớc khi xóa mẩu tin people. 

Điều này cũng cho phép bạn kiển tra cách hoạt động của câu lệnh UPDATE SQL. 

// xóa phần liên quan đến lãnh đạo diễn viên 

$actor = “UPDATE movie 

SET movie_leadactor = „0‟ 

WHERE movie_leadactor = „“ . $_GET[„id‟] . “„“; 

$result = mysql_query($actor) 

or die(“Invalid query: “ . mysql_error()); 

// xóa phần liên quan đến đạo diễn 

$director = “UPDATE movie 

SET movie_director = „0‟ 

WHERE movie_director = „“ . $_GET[„id‟] . “„“; 

$result = mysql_query($director) 

or die(“Invalid query: “ . mysql_error()); 

  Trong đoạn mã trƣớc, đặt bất kì một vùng nào trong bảng movie mà có thể chứa 

một điều rủi ro cho bạn, khi bạn xóa một ngƣời. Câu lệnh UPDATE làm việc một cách 

đơn giản. Nó đặt  những vùng lý thuyết với những giá trị lý thuyết mới  trong tất cả các 

mẩu tin theo nhu cầu của câu lệnh WHERE. 

Bạn có thể hỏi điều gì sẽ xảy ra nếu một ngƣời quên đi phần WHERE. Điều này sẽ 

cập nhật tất cả những mẩu tin trong bảng, mà có thể không có một thứ gì bạn muốn làm 

trong thực tế . 

  Thứ tự xóa 

// phát sinh SQL 

$sql = “DELETE FROM “ . $_GET[„type‟] . “ 

WHERE “ . $_GET[„type‟] . “_id = „“ . $_GET[„id‟] . “„ 

LIMIT 1”; 

// Xuất SQL cho mục đích biên dịch 

echo “<!--” . $sql . “-->”; 

$result = mysql_query($sql) 

or die(“Invalid query: “ . mysql_error()); 

  - 151 - 

  Truy vấn DELETE là một đơn vị động, nhƣng nó khá dễ hiểu. Bạn không muốn 

mã hóa câu lệnh SQL cho mỗi loại. Vì vậy bạn sử dụng thông tin thông qua việc truyền 

biến trong URL để phát sinh ra câu lệnh SQL. Bảng và vùng khóa chính đƣợc phát sinh 

linh hoạt từ loại mục để xóa. 

6.5.  Sửa dữ liệu trong mẩu tin 

Có dữ liệu trong cơ sở dữ liệu là một việc tốt, nhƣng dữ liệu có khả năng nhận rõ 

chính nó và có khuynh hƣớng cập nhật. Để cập nhật dữ liệu bạn cần nhận biết dữ liệu cập 

nhật và hệ thống ngƣời sử dụng hiện tại với giao diện tốt. Việc sử dụng giao diện tƣơng 

tự nhƣ việc tạo dữ liệu thƣờng là một thực tiễn tốt. 

Ví dụ:Sửa đổi một Movie 

Trong ví dụ này, bạn tạo ra một tập lệnh mà có thể sửa đổi một bộ phim. Bạn sẽ xây 

dụng trên movie.php . 

1.Mở movie.php và nhập mã lệnh 

<?php 

$link = mysql_connect(“localhost”, “root”, “”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(„moviesite‟, $link) 

or die ( mysql_error()); 

$peoplesql = “SELECT * FROM people”; 

$result = mysql_query($peoplesql) 

or die(“Invalid query: “ . mysql_error()); 

while ($row = mysql_fetch_array($result)) { 

$people[$row[„people_id‟]] = $row[„people_fullname‟]; 

switch ($_GET[„action‟])  

case “edit”: 

$moviesql = “SELECT * FROM movie 

WHERE movie_id = „“ . $_GET[„id‟] . “„“; 

$result = mysql_query($moviesql) 

or die(“Invalid query: “ . mysql_error()); 

  - 152 - 

$row = mysql_fetch_array($result); 

$movie_name = $row[„movie_name‟]; 

$movie_type = $row[„movie_type‟]; 

$movie_year = $row[„movie_year‟]; 

$movie_leadactor = $row[„movie_leadactor‟]; 

$movie_director = $row[„movie_director‟]; 

break; 

default: 

$movie_name = “”; 

$movie_type = “”; 

$movie_year = “”; 

$movie_leadactor = “”; 

$movie_director = “”; 

break; 

?> 

<html> 

<head> 

<title><?php echo $_GET[„action‟]; ?> movie</title> 

<style type=”text/css”> 

TD{color:#353535;font-family:verdana} 

TH{color:#FFFFFF;font-family:verdana;background-color:#336699} 

</style> 

</head> 

<body> 

<form action=”commit.php?action=<?php 

echo $_GET[„action‟]; ?>&type=movie&id=<?php 

echo $_GET[„id‟]; ?>” method=”post”> 

<table border=”0” width=”750” cellspacing=”1” cellpadding=”3” 

bgcolor=”#353535” align=”center”> 

<tr> 

  - 153 - 

<td bgcolor=”#FFFFFF” width=”30%”>Movie Name</td> 

<td bgcolor=”#FFFFFF” width=”70%”> 

<input type=”text” name=”movie_name” 

value=”<?php echo $movie_name; ?>”> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Movie Type</td> 

<td bgcolor=”#FFFFFF”> 

<select  id=”game”  name=”movie_type” 

style=”width:150px”> 

<?php 

$sql = “SELECT movietype_id, movietype_label “ . 

“FROM movietype ORDER BY movietype_label”; 

$result = mysql_query($sql)  

or die(“<font color=\”#FF0000\”>Query Error</font>” . 

mysql_error()); 

while ($row = mysql_fetch_array($result))  

if ($row[„movietype_id‟] == $movie_type)  

$selected = “ selected”; 

 else { 

$selected = “”; 

echo „<option value=”‟ . $row[„movietype_id‟] . „“„ . 

$selected.‟>‟ . $row[„movietype_label‟] . „</option>‟ . 

”; 

?> 

  - 154 - 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Movie Year</td> 

<td bgcolor=”#FFFFFF”> 

<select name=”movie_year”> 

<option value=”” selected>Select a year...</option> 

<?php 

for ($year = date(“Y”); $year >= 1970; $year--)  

if ($year == $movie_year) 

 { 

$selected = “ selected”; 

} else { 

$selected = “”; 

?> 

<option value=”<?php echo $year; ?>”<?php 

echo $selected; ?>><?php echo $year; ?></option> 

<?php 

?> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Lead Actor</td> 

<td bgcolor=”#FFFFFF”> 

<select name=”movie_leadactor”> 

<option value=”” selected>Select an actor...</option> 

  - 155 - 

<?php 

foreach ($people as $people_id => $people_fullname) { 

if ($people_id == $movie_leadactor)  

$selected = “ selected”; 

} else { 

$selected = “”; 

?> 

<option value=”<?php echo $people_id; ?>”<?php 

echo  $selected;  ?>><?php  echo  $people_fullname; 

?></option> 

<?php 

?> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Director</td> 

<td bgcolor=”#FFFFFF”> 

<select name=”movie_director”> 

<option value=”” selected>Select a director...</option> 

<?php 

foreach ($people as $people_id => $people_fullname) { 

if ($people_id == $movie_director) { 

$selected = “ selected”; 

} else { 

$selected = “”; 

?> 

  - 156 - 

<option value=”<?php echo $people_id; ?>”<?php 

echo  $selected;  ?>><?php  echo  $people_fullname; 

?></option> 

<?php 

?> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF” colspan=”2” align=”center”> 

<input type=”submit” name=”SUBMIT” value=”<?php 

echo $_GET[„action‟]; ?>”> 

</td> 

</tr> 

</table> 

</form> 

</body> 

</html> 

2. Mở tập lệnh commit.php và thay đổi nội dung nhƣ sau: 

<?php 

// COMMIT ADD AND EDITS 

$link = mysql_connect(“localhost”, “bp5am”, “bp5ampass”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(„moviesite‟, $link) 

or die ( mysql_error()); 

switch ($_GET[„action‟])  

case “edit”: 

switch ($_GET[„type‟]) 

 { 

  - 157 - 

case “movie”: 

$sql = “UPDATE movie SET 

movie_name = „“ . $_POST[„movie_name‟] . “„, 

movie_year = „“ . $_POST[„movie_year‟] . “„, 

movie_type = „“ . $_POST[„movie_type‟] . “„, 

movie_leadactor = „“ .$_POST[„movie_leadactor‟].”‟, 

movie_director = „“ . $_POST[„movie_director‟] . “„ 

WHERE movie_id = „“ . $_GET[„id‟] . “„“; 

break; 

break; 

case “add”: 

switch ($_GET[„type‟]) 

 { 

case “movie”: 

$sql = “INSERT INTO movie 

(movie_name, 

movie_year, 

movie_type, 

movie_leadactor, 

movie_director) 

VALUES 

(„“ . $_POST[„movie_name‟] . “„, 

„“ . $_POST[„movie_year‟] . “„, 

„“ . $_POST[„movie_type‟] . “„, 

„“ . $_POST[„movie_leadactor‟] . “„, 

„“ . $_POST[„movie_director‟] . “„)”; 

break; 

break; 

  - 158 - 

if (isset($sql) && !empty($sql))  

echo “<!--” . $sql . “-->”; 

$result = mysql_query($sql) 

or die(“Invalid query: “ . mysql_error()); 

?> 

<p align=”center” style=”color:#FF0000”> 

Done. <a href=”index.php”>Index</a> 

</p> 

<?php 

?> 

3. Bây giờ mở http://localhost/chapter6/index.php hiển thị nhƣ Hình 6.6.1 

Hình  6.6.1 

4. Thử click liên kết EDIT ở “Bruce Almighty” movie, thay đổi một vài thứ trong hộp và 

tên film, ấn nút “edit” sẽ hiển thị nhƣ Hình 6.6.2  

  - 159 - 

Hình  6.6.2 

5. Edit “Bruce Almighty” nhận lại với thủ tục trong bƣớc 4, và ấn định lại nhƣ cũ. 

Bây giờ liên kết EDIT cho film, bạn thấy rằng tập lệnh lƣu trữ giá trị và cho phép 

sửa đổi dữ liệu dễ dàng 

Cách thức làm việc  

Đoạn mã commit.php giống với những gì bạn thấy. Nhƣng có một phát triển cần 

quan tâm trong movie.php. Chúng ta hãy nhìn vào một vài chi tiết 

Đầu tiên hãy nhìn vào switch ở phần đầu của tập lệnh. Bạn định nghĩa một switch trên 

một chuổi truy vấn tham số tên action. Nếu action là edit, bạn truy vấn cơ sở dữ liệu  cho 

một mẩu tin tƣơng ứng đến id lý thuyết trong chuổi truy vấn tham số id và đặt một vài 

biến. Những biến này đƣợc đặt để tránh action không là edit.. 

switch ($_GET[„action‟])  

case “edit”: 

$moviesql = “SELECT * FROM movie 

WHERE movie_id = „“ . $_GET[„id‟] . “„“; 

$result = mysql_query($moviesql) 

or die(“Invalid query: “ . mysql_error()); 

$row = mysql_fetch_array($result); 

$movie_name = $row[„movie_name‟]; 

$movie_type = $row[„movie_type‟]; 

$movie_year = $row[„movie_year‟]; 

$movie_leadactor = $row[„movie_leadactor‟]; 

  - 160 - 

$movie_director = $row[„movie_director‟]; 

break; 

default: 

$movie_name = “”; 

$movie_type = “”; 

$movie_year = “”; 

$movie_leadactor = “”; 

$movie_director = “”; 

break; 

?> 

 Những biến đặt trong đoạn mã trƣớc thƣờng đặt giá trị mặc định của vùng form. 

Mỗi vùng có một giá trị nếu nhƣ bạn chỉnh sửa một mẩu tin và có một giá trị trống nếu 

nhƣ bạn tạo một mẩu tin. 

<tr> 

<td bgcolor=”#FFFFFF” width=”30%”>Movie Name</td> 

<td bgcolor=”#FFFFFF” width=”70%”> 

<input type=”text” name=”movie_name” 

value=”<?php echo $movie_name; ?>”> 

</td> 

</tr> 

Trong ví dụ này, vùng movie_name  lấy nội dung biến $movie_name  nhƣ một giá 

trị mặc. Điều này cho phép bạn nạp lại với mẩu tin đã đƣợc chỉnh sửa. 

 Việc sửa đổi văn bản thì dễ dàng. Sửa đổi giá trị trong một danh sách là một 

chuyện khác. Bạn không thể hiển thị danh sách và hi vọng ngƣời dùng sẽ đặt lại giá trị 

gốc khi anh ta hoặc cô ta sửa mẩu tin. 

Bạn cần phải nạp lại hoàn toàn danh sách và đặt giá trị trƣớc nhƣ mặc định trong 

danh sách, vì vậy ngƣời dùng có thể bỏ qua nó nếu không muốn thay đổi  nó. 

Làm điều này nhƣ thế nào?  

<tr> 

<td bgcolor=”#FFFFFF”>Movie Type</td> 

  - 161 - 

<td bgcolor=”#FFFFFF”> 

<select id=”game” name=”movie_type” style=”width:150px”> 

<?php 

$sql = “SELECT movietype_id, movietype_label “ . 

“FROM movietype ORDER BY movietype_label”; 

$result = mysql_query($sql) 

or die(“<font color=\”#FF0000\”>Query Error</FONT>” . 

mysql_error()); 

while ($row = mysql_fetch_array($result)) 

 { 

if ($row[„movietype_id‟] == $movie_type)  

$selected = “ selected”; 

} else { 

$selected = “”; 

echo „<option value=”‟ . $row[„movietype_id‟] . „“„ . 

$selected . „>‟ . $row[„movietype_label‟] . „</option>‟ . 

”; 

?> 

</select> 

</td> 

</tr> 

Bạn nạp vào danh sách nhƣ bạn sẽ làm nếu bạn thêm một mẩu tin, nhƣng bạn so 

sánh  giá  trị  hiện  hành  với  giá  trị  mặc  định.  Nếu  chúng  đúng  thì  thêm  cờ  đơn  giản 

SELECTED  để lựa chọn. Việc này đặt danh sách giá trị  mặc định đến  giá trị hiện hành 

trong bảng.  

if ($row[„movietype_id‟] == $movie_type) 

 { 

$selected = “ selected”; 

  - 162 - 

} else { 

$selected = “”; 

  - 163 - 

Chƣơng  7:  THAO TÁC VÀ TẠO HÌNH ẢNH VỚI PHP 

Chƣơng này bao gồm những phần sau: 

-  Có thể vài đặt PHP bao gồm cả thƣ viện GD. 

-  Cho phép ngƣời dùng đƣa hình ảnh của họ lên.  

-  Nhận lại thông tin về hình ảnh nhƣ loại, kích thƣớc. 

-  Tạo một hình ảnh mới. 

-  Sao chép một ảnh hoặc một phần của ảnh. 

-  Tạo thumbnails(phiên bản thu nhỏ của ảnh). 

-  Tạo một phiên bản ảnh trắng đen. 

-  Thêm hoa văn và tên cho hình. 

7.1.  Làm việc với thƣ viện GD 

GD đƣợc viết bằng C++ và cho phép thao tác với hình ảnh hiện tại. Bởi vì PHP 

không thể tự động xử lý hình ảnh với việc xây dựng hàm. Cần chắc chắn rằng bạn có thƣ 

viện GD. May thay, Trong tất cả các phiên bản của PHP gần đây có hổ trợ một gói thƣ 

viện này. Nếu bạn không có gói này bạn có thể tìm nó tại 188Hhttp://www.boutell.com/gd/. 

Tuy nhiên chúng tôi khuyên rằng : bạn sử dụng gói này tƣơng phản với những phiên bản 

có sẳn bên ngoài đƣợc tải về nếu có thể. 

7.1.1.  Tôi có thể sử dụng loại files gì với GD và PHP? 

GD có thể làm việc với vô số hình ảnh, nhƣng khi bạn sử dụng nó với PHP, bạn có thể 

định dạng hình ảnh với bất kỳ loại nào nhƣ GIF, JPG, PNG, SWF, SWC, PSD, TIFF, 

BMP, IFF, JP2, JPX, JB2, JPC, XBM hoặc WBMP. 

  Bạn có thể thao tác và tạo hình ảnh với định dạng GIF, JPG, PNG, WBMP, và 

XBM. GD cũng cho phép PHP tạo hình dạng nhƣ hình vuông, hình đa giác, hình elíp, tốt 

nhƣ những hộp văn bản sử dụng đúng kiểu Fonts. 

  Phụ thuộc vào phiên bản của GD, GIF có thể hoặc là không thể hỗ trợ. Nếu GIF có 

thể hỗ trợ  với việc sử dụng hàm gd_info diễn tả trong phần ví dụ “kiểm tra GD”. 

  - 164 - 

7.1.2.  Biên dịch PHP với GD 

Nếu bạn sử dụng một Web chủ, tình cờ chúng đã có sẳn GD trong cài đặt PHP. 

Nếu bạn chạy trong máy của bạn, có thể GD không sẳn sàng. Trong Window, dễ dàng 

tìm thấy dòng sau trong file php.ini;extension=php_gd2.dll 

Không chú ý giống với dòng:extension=php_gd2.dll 

  Bạn cần khởi động lại Apache để làm cho thay đổi có hiệu lực. 

  Trong Linux, bạn cần chọn cấu hình --with-gd cho GD. Mặc khác, bởi vì gói phiên 

bản của GD yêu cầu dùng với PHP, bạn không cần nhận dạng thƣ mục cài đặt GD. Nó 

đƣợc mặc định  

Ví dụ: Kiểm tra GD 

  Mở trình sọan thảo và nhập đoạn code 

<?php 

print_r(gd_info()); 

?> 

  Lƣu với tên gdtest.php (đƣa nó lên web server nếu cần). 

  Mở trình duyệt bạn sẽ thấy kết quả nhƣ sau:Hình 7.1 

Hình  7.1 

Cách thức hoạt động: 

Hàm gd_info thì hoàn toàn hữu ích, bởi vì phiển bản GD đƣợc đóng gói với PHP. 

Mục đích của nó là đặt tất cả các thông tin về phiên bản GD vào trong một mảng mà bạn 

có thể xem lại sau đó.Việc này không chỉ đáp ứng nhƣ kiểm tra để chắc chắn rằng PHP 

với GD thì vận hành tốt với mỗi thứ khác. Nhƣng nó cho phép bạn thấy giới hạn của bạn 

cho việc sử dụng GD trong PHP. Để đáp ứng mục đích trong ví dụ của chƣơng này bạn 

  - 165 - 

cần có hỗ trợ JPG,GIF và PNG. Nếu phiên bản của Gd không hỗ trợ bất cứ loại hình ảnh 

nào thì bạn cần nâng cấp. Bạn có thể tìm hƣớng dẫn nâng cấp dầy đủ và tập lệnh mãc 

nguồn tại 189Hhttp://www.boutell.com/gd. 

Hàm print_r() lấy tất cả các thông tin lƣu trữ trong một biến(bao gồm mảng) và 

xuất nó lên trình duyệt, do đó bạn có thể thấy nó. 

Bây giờ bạn biết GD thì làm việc tốt và loại hình ảnh nào sẽ đƣợc hỗ trợ  

7.2.  Cho phép ngƣời dùng đƣa hình ảnh lên 

PHP cho phép ngƣời dùng đƣa hình ảnh lên server. Bạn cần sự giúp đở của MySQL 

để lƣu trữ hình ảnh và tất cả các thông tin về hình ảnh. 

Ví dụ: Tạo một bảng hình ảnh: 

Trƣớc tiên bạn cần tạo một bảng lƣu trữ thông tin về những hình ảnh. Bạn sẽ lƣu trữ 

thông tin cơ bản về mỗi hinh nhƣ tên, tựa đề của hình. Sau đó, cho ngƣời sử dụng một 

form mà ngƣời dùng có thể submit một hình để hiển trên website. Bạn sẽ hỏi một vài 

thông tin cơ bản về hình. Sau đó bạn cho phép ngƣời sử dụng đƣa file trực tiếp từ tiện 

nghi trình duyệt hiếm có của họ, không cần sự viện trợ của bất cứ phầm mềm FPT nào. 

Nếu bạn không có một thƣ mục cho hình ảnh nhà của bạn. Bạn cần tạo một thƣ 

mục. trong bài tập này, hình ảnh sẽ đƣợc lƣu trữ. 

  Mở trình soạn thảo nhập đoạn mã sau: 

<?php 

//Kết nối cơ sở dữ liệu 

$link = mysql_connect(“localhost”, “root”, “”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(“moviesite”, $link) 

or die (mysql_error()); 

//Tạo bảng images 

$sql = “CREATE TABLE IF NOT EXISTS images ( 

image_id INT(11) NOT NULL AUTO_INCREMENT, 

image_caption VARCHAR(255) NOT NULL, 

image_username VARCHAR(255) NOT NULL, 

image_date DATE NOT NULL, 

PRIMARY KEY (image_id) 

  - 166 - 

)”; 

$results = mysql_query($sql) 

or die(mysql_error()); 

echo “Image table successfully created.”; 

?> 

Lƣu với tên create_images_table.php. Mở trình duyệt và bạn sẽ thấy thông báo 

“Image table successfully created.” 

Mở trình soạn thảo nhập đoạn mã sau: 

<html> 

<head> 

<title>Upload your pic to our site!</title> 

</head> 

<body> 

<form name=”form1” method=”post” action=”check_image.php” 

enctype=”multipart/form-data”> 

<table border=”0” cellpadding=”5”> 

<tr> 

<td>Image Title or Caption<br> 

<em>Example: You talkin‟ to me?</em></td> 

<td><input  name=”image_caption”  type=”text”  id=”item_caption” 

size=”55” 

ngth=”255”></td> 

</tr> 

<tr> 

<td>Your Username</td> 

<td><input  name=”image_username”  type=”text” 

id=”image_username” size=”15” 

maxlength=”255”></td> 

</tr> 

<td>Upload Image:</td> 

  - 167 - 

<td><input  name=”image_filename”  type=”file” 

id=”image_filename”></td> 

</tr> 

</table> 

<br> 

<em>Acceptable  image  formats  include:  GIF,  JPG/JPEG,  and 

PNG.</em> 

<p  align=”center”><input  type=”submit”  name=”Submit” 

value=”Submit”> 

&nbsp; 

<input type=”reset” name=”Submit2” value=”Clear Form”> 

</p> 

</form> 

</body> 

</html> 

  Lƣu file upload_image.htm. Trong ví dụ đơn giản này bạn không có một mã lệnh 

PHP nào trong form, vì vậy bạn không cần phần mở rộng là .php 

Tạo một file mới và nhập đoạn mã sau: 

<?php 

//Kết nối cơ sở dữ liệu 

$link = mysql_connect(“localhost”, “root”, “”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(“moviesite”, $link) 

or die (mysql_error()); 

//làm việc với biến có sẳn 

$image_caption = $_POST[„image_caption‟]; 

$image_username = $_POST[„image_username‟]; 

$image_tempname = $_FILES[„image_filename‟][„name‟]; 

$today = date(“Y-m-d”); 

//Đƣa hình ảnh lên và kiểm tra loại hình ảnh 

//Thay đổi đƣờng dẫn đến thƣ mục hình ảnh 

  - 168 - 

$ImageDir  =”c:/Program  Files/Apache 

Group/Apache2/test/images/”; 

$ImageName = $ImageDir . $image_tempname; 

if(move_uploaded_file($_FILES[„image_filename‟][„tmp_name‟], 

$ImageName))  

//lấy thông tin về hình ảnh đang đƣa lên 

list($width,  $height,  $type,  $attr)  = 

getimagesize($ImageName); 

switch ($type) 

 { 

case 1: 

$ext = “.gif”; 

break; 

case 2: 

$ext = “.jpg”; 

break; 

case 3: 

$ext = “.png”; 

break; 

default: 

echo “Sorry, but the file you uploaded was not a GIF, JPG, or 

“ . 

“PNG file.<br>”; 

echo “Please hit your browser‟s „back‟ button and try again.”; 

//insert info into image table 

$insert = “INSERT INTO images 

(image_caption, image_username, image_date) 

VALUES 

(„$image_caption‟, „$image_username‟, „$today‟)”; 

  - 169 - 

$insertresults = mysql_query($insert) 

or die(mysql_error()); 

$lastpicid = mysql_insert_id(); 

$newfilename = $ImageDir . $lastpicid . $ext; 

rename($ImageName, $newfilename); 

?> 

<html> 

<head> 

<title>Here is your pic!</title> 

</head> 

<body> 

<h1>So how does it feel to be famous?</h1><br><br> 

<p>Here is the picture you just uploaded to our servers:</p> 

<img src=”images/<?php echo $lastpicid . $ext; ?>” align=”left”> 

<strong><?php echo $image_name; ?></strong><br> 

This image is a <?php echo $ext; ?> image.<br> 

It is <?php echo $width; ?> pixels wide 

and <?php echo $height; ?> pixels high.<br> 

It was uploaded on <?php echo $today; ?>. 

</body> 

</html> 

  Lƣu file với tên check_image.php. Mở upload_image.htm trên trình duyệt. Kết quả 

nhƣ hình 7.2.2  

  - 170 - 

Hình  7.2.2 

    Đƣa hình ảnh lên, bạn sẽ thấy nhƣ Hình 7.2.3       

Hình  7.2.3 

Cách thức làm việc 

Trong  upload_image.htm, bạn cho HTML một sức mạnh để tìm vùng đĩa của ngƣời dùng 

với nút “Browse”, đơn giản bằng cách thêm enctype đến thuộc tính form: 

   <form name=”form1” method=”post” action=”check_image.php” 

enctype=”multipart/form-data”> 

  Sau đó bạn có một vài vùng nhập, bao gồm vùng nhập “file”,lấy file và gửi nó đến 

server, trong một vùng tạm thời. 

  Sau đó, trong check_image.php, bạn có nhiều thứ khác nhau để tiếp tục. Đầu tiên 

bạn kết nối cở sở dữ liệu và tạo những biến dễ dàng cập nhật trong tập lệnh của bạn. Tiếp 

theo bạn định nghĩa thƣ mục chứa tất cả các hình và tên hình. Chúng nhìn vào dòng đặc 

biệt này 

$image_tempname = $_FILES[„image_filename‟][„name‟]; 

  - 171 - 

  Bạn có thể sử dụng nhiều phƣơng pháp khác nhau khi xử lý hình ảnh. Nếu bạn 

nghĩ bạn sẽ có một số file cho mỗi ngƣời dùng. Bạn có thể tạo thƣ mục cho mỗi ngƣời, 

sau đó chuyển hình ảnh cho mỗi thƣ mục. Trong ví dụ này, bạn giữ tất cả hình ảnh trong 

một thƣ mục lớn. Không quan tâm đến cấu trúc thƣ mục bạn chọn, bạn nên áp dụng một 

vài kiểm tra cho những tên file giống nhau. 

  Trong trƣờng hợp này, bạn đổi tên những tên file giống nhau nhƣ gán cho nó một 

ID duy nhất. bảo đảm là mỗi file sẽ có một tên duy nhất, không có vấn đề gì nếu hai 

ngƣời đƣa vào một tên file photo1.jpg. Do đó bạn sẽ lấy tên file tạm thời mà nó đƣợc đƣa 

lên bằng cách sử dụng biến $image_tempname, và đổi tên nó một lần nữa, nó đã đƣợc 

đƣa lên thành công  và đƣợc chèn vào bảng của bạn, sử dụng biến $newfilename mà bạn 

thấy trong tập lệnh. 

  Kế tiếp bạn kiểm tra để chắc rằng file đã đƣợc đƣa lên thành công với dòng sau. 

if (move_uploaded_file($_FILES[„image_filename‟][„tmp_name‟], 

$ImageName)) 

  Hàm  move_uploaded_file  chuyển một file uploaded từ hình gốc đƣợc cung cấp 

bởi ngƣời dùng, gán „tmp_name‟ bởi máy chủ để đến đích cuối cùng, $ImageName. Nó 

thì quan trọng bao gồm bƣớc „tmp_name‟ trong tập lệnh của bạn, chú ý rằng bạn không 

làm bất kì một cái gì với giá trị trong biến này, nó đƣợc đƣa ra bởi máy chủ. Giá trị thì ẩn 

từ bạn nhƣng nó quan trọng, bạn không đạt tên nó và sau đó biến đƣợc chuyển đến. 

Bƣớc tiếp theo là lấy thông tin về file đƣợc đƣa lên. Trong ví dụ bạn chỉ cho phép nhiều 

file hoạt động với phiên bản hiện hành của PHP/GD. Bao gồm file GIF, JPG, và PNG. 

Tất cả các file này thì dễ dàng thao tác trong PHP cũng nhƣ WPMP. 

  WBMP  không  giống  nhƣ  một  file  trong  Window  Bitmap,  Nó  là  file  Wireless 

Bitmap, sử dụng trong Palm Pilots. Vào lúc viết PHP/GD không đƣợc thao tác trên file 

BMP. Bạn cần một ứng dụng khác nhƣ ImageMagick để đổi file BMP thành GIF, JPG, or 

PNG. Nếu bạn muốn làm việc với chúng mà dùng PHP/GD. 

  Hàm getimagesize cho bạn thông tin về chiều dài, chiều rộng và loại hình ảnh và 

cho những file JPG, nó có thể cho bạn số kênh và số đơn vị. Nó đƣa ra thông tin trong 

một mảng mà bạn cập nhật dùng hàm list: 

list($width, $height, $type, $attr) = getimagesize($ImageName); 

  - 172 - 

Chiều rộng và chiều cao của hình ảnh thì trả về số nguyên. Loại file thì trả về một 

số nguyên với khóa dƣới đây 

1 GIF          9 JPC 

2 JPG         10 JP2 

3 PNG        11 JPX 

4 SWF        12 JB2 

5 PSD         13 SWC 

6 BMP         14 IFF 

7 TIFF (Intel byte order)     15 WBMP 

8 TIFF (Motorola byte order)   16 XBM 

Biến $attr chứa chiều rộng và chiều cao mà bạn sử dụng trong thẻ hình HTML 

Ví dụ   

width=”640” height=”480 

Trở về tập lệnh sử dụng switch để lộc ra những loại hình ảnh không sử dụng 

switch ($type)  

case 1: 

$ext = “.gif”; 

break; 

case 2: 

$ext = “.jpg”; 

break; 

case 3: 

$ext = “.png”; 

break; 

default: 

echo “Sorry, but the file you uploaded was not a GIF, JPG, or “ . 

“PNG file.<br>”; 

echo “Please hit your browser‟s „back‟ button and try again.”; 

  - 173 - 

  Bạn gán file mở rộng dựa vào loại file và bạn sẽ cần có những thông tin có sẵn khi 

bạn đổi tên file. Nếu file đƣa lên không thích hợp với bất kì trƣờng hợp nào của bạn thì 

áp dụng mặc định. Và ngƣời đọc sẽ thấy  câu “Sorry, but the file you uploaded was not a 

GIF, JPG or PNG file”. Với cách này bạn có thể lộc ra những file không đƣợc chấp nhận 

mà vẫn đƣa lên. 

  Sau đó bạn chèn thông tin vào bảng nhƣ đoạn mã dƣới đây; 

//chèn thông tin vào bảng 

$insert = “INSERT INTO images 

(image_caption, image_username, image_date) 

VALUES 

(„$image_caption‟, „$image_username‟, „$today‟)”; 

$insertresults = mysql_query($insert) 

or die(mysql_error()); 

$lastpicid = mysql_insert_id(); 

Sau đó bạn đặt lại tên file để tránh xung đột trong tƣơng lai sử dụng ID tăng tự 

động của hình ảnh; 

$newfilename = $ImageDir . $lastpicid . $ext; 

rename($ImageName, $newfilename); 

7.3.  Chuyển đổi loại file hình ảnh 

Có một vài chú ý về cách chèn hình ảnh của bạn khi dƣa nó đến với ngƣời dùng. 

Hãy nhìn vào dòng sau: 

<img src=”images/<?php echo $lastpicid . $ext; ?>” align=”left”> 

  bạn sử dụng hai biến $lastpicid và $ext để điều chỉnh tên hình ảnh của bạn. Bạn có 

chú ý rằng, thông tin không đƣợc lƣu trữ ở bất cứ nơi nào trong bảng hình ảnh không? 

Bạn sẽ cập nhật lại hình ảnh nhƣ thế nào khi thông tin trong biến đã hết hiệu lực. Bạn có 

thể cập nhật phần đầu tiên của tên file, bởi vì nó giống nhƣ image_id. Bạn biết về phần 

mở rộng của file nhƣ thế nào, nếu nó khác nhau cho mỗi hình. Bạn có thể làm một trong 

3 biện pháp cứu chữa này: 

1.Thêm vào một vùng trong bảng hình ảnh cho phép lƣu trữ đầy đủ tên hình ảnh. 

2. Thêm vào một vùng trong bảng hình ảnh cho phép lƣu trữ phần mở rộng. 

  - 174 - 

3. Chuyển đổi tất cả hình ảnh đƣa vào thành những loại file giống nhau và có phần 

mở rộng giống nhau. 

Chúng ta sẽ chọn cách thứ 3. Ở đây, chúng ta sẽ thay đổi file check_image.php một cách 

hợp lý. Bằng cách tạo ra một bản sao loại .jpg(trong 3 loại GIF, JPG, PNG) chứ không 

thay đổi bản. 

  Để chuyển đổi loại file bạn làm 4 bƣớc sau: 

  1.Tạo một hình ảnh GD-thân thiện  mới từ hình ảnh gốc để làm  một hình ảnh 

nguồn tạm. 

  2. Tạo một hình ảnh GD-thân thiện rỗng để làm một hình ảnh đích tạm. 

  3. Sao chép hình ảnh nguồn mới đến hình ảnh đích mới. 

  4. Lƣu hoặc xuất ra hình ảnh đích đã đƣợc thay đổi. 

  5. (Tùy ý, nhƣng khuyên dùng) xóa hình ảnh nguồn tạm và hình ảnh đích tạm. 

  PHP  có  những  hàm  cho  các  file  loại  đặc  biệt  cho  bƣớc  1  và  4(ví  dụ 

imagecreatefromgif, imagecreatefromjpg), vì vậy, điều quan trọng là bạn biết loại file nào 

mà bạn đang làm việc với nó. 

Ví dụ: sắp xếp hợp lý tiến trình 

  Để xử lý file của bạn cần thay đổi check_image.php nhƣ sau: 

<?php 

//kết nối cở sở dữ liệu 

$link = mysql_connect(“localhost”, “root”, “”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(“moviesite”, $link) 

or die (mysql_error()); 

//thêm biến có sẳn 

$image_caption = $_POST[„image_caption‟]; 

$image_username = $_POST[„image_username‟]; 

$image_tempname = $_FILES[„image_filename‟][„name‟]; 

$today = date(“Y-m-d”); 

//đƣa hình ảnh và kiểm tra loại hình ảnh 

$ImageDir =”c:/Program Files/Apache  

Group/Apache2/test/images/”; 

  - 175 - 

$ImageName = $ImageDir . $image_tempname; 

if (move_uploaded_file($_FILES[„image_filename‟][„tmp_name‟], 

$ImageName)) 

 { 

//Lấy thông tin về hình ảnh đƣa lên 

list($width, $height, $type, $attr) =  

getimagesize($ImageName); 

//**Xóa từ dòng này 

switch ($type) 

 { 

case 1: 

$ext = “.gif”; 

break; 

case 2: 

$ext = “.jpg”; 

break; 

case 3: 

$ext = “.png”; 

break; 

default: 

echo “Sorry, but the file you uploaded was not a GIF, JPG, or “ . 

“PNG file.<br>”; 

echo “Please hit your browser‟s „back‟ button and try again.”; 

//**kết thúc xóa  

//**thêm những dòng mới này 

if ($type > 3)  

echo “Sorry, but the file you uploaded was not a GIF, JPG, or “ . 

“PNG file.<br>”; 

echo “Please hit your browser‟s „back‟ button and try again.”; 

  - 176 - 

} else  

//Hìng ảnh có thể chấp nhận 

//**kết thúc việc chèn 

//chèn thông tin về bảng hình ảnh  

$insert = “INSERT INTO images 

(image_caption, image_username, image_date) 

VALUES 

(„$image_caption‟, „$image_username‟, „$today‟)”; 

$insertresults = mysql_query($insert) 

or die(mysql_error()); 

$lastpicid = mysql_insert_id(); 

//thay đổi dòng này: 

$newfilename = $ImageDir . $lastpicid . “.jpg”; 

//**chèn dòng này 

if ($type = = 2)  

rename($ImageName, $newfilename); 

} else  

if ($type = = 1)  

$image_old = imagecreatefromgif($ImageName); 

} elseif ($type = = 3)  

$image_old = imagecreatefrompng($ImageName); 

//chuyển đổi hình ảnh thành  jpg 

$image_jpg = imagecreatetruecolor($width, $height); 

imagecopyresampled($image_jpg, $image_old, 0, 0, 0, 0, 

$width, $height, $width, $height); 

  - 177 - 

imagejpeg($image_jpg, $newfilename); 

imagedestroy($image_old); 

imagedestroy($image_jpg); 

$url = “location: showimage.php?id=” . $lastpicid; 

header($url); 

//**kết thúc dòng chèn 

?> 

<!-- DELETE THESE LINES 

<html> 

<head> 

<title>Here is your pic!</title> 

</head> 

<body> 

<h1>So how does it feel to be famous?</h1><br><br> 

<p>Here is the picture you just uploaded to our servers:</p> 

<img src=”images/<?php echo $lastpicid . $ext; ?>” align=”left”> 

<strong><?php echo $image_caption; ?></strong><br> 

This image is a <?php echo $ext; ?> image.<br> 

It is <?php echo $width; ?> pixels wide 

and <?php echo $height; ?> pixels high.<br> 

It was uploaded on <?php echo $today; ?>. 

</body> 

</html> 

END OF DELETED LINES--> 

  Mở trình soạn thảo và nhập đoạn mã lƣu với tên Showimage.php 

<?php 

//kết nối cở sở dữ liệu 

$link = mysql_connect(“localhost”, “root”, “”) 

or die(“Could not connect: “ . mysql_error()); 

  - 178 - 

mysql_select_db(“moviesite”, $link) 

or die (mysql_error()); 

//make variables available 

$id = $_REQUEST[„id‟]; 

//get info on the pic we want 

$getpic = mysql_query(“SELECT * FROM images WHERE image_id = 

„$id‟”) 

or die(mysql_error()); 

$rows = mysql_fetch_array($getpic); 

extract($rows); 

$image_filename = “images/” . $image_id . “.jpg”; 

list($width, $height, $type, $attr) = getimagesize($image_filename); 

?> 

<html> 

<head> 

<title>Here is your pic!</title> 

</head> 

<body> 

<h1>So how does it feel to be famous?</h1><br><br> 

<p>Here is the picture you just uploaded to our servers:</p> 

<img src=”<?php echo $image_filename; ?>” align=”left” 

<?php echo $attr; ?> > 

<strong><?php echo $image_caption; ?></strong><br> 

It is <?php echo $width; ?> pixels wide a 

nd <?php echo $height; ?> pixels high.<br> 

It was uploaded on <?php echo $image_date; ?> 

by <?php echo $image_username; ?>. 

</body> 

</html> 

3.Nếu bạn lƣu file, đƣa lên trình duyệt, và đƣa hình ảnh của bạn, bạn sẽ chú ý rằng về cơ 

bản giống nhƣ màn hình trƣớc. 

  - 179 - 

  Cách thức làm việc  

  Hãy nhìn vào phần chính mà bạn thêm trong chƣơng trình của bạn. Đầu tiên chúng 

ta sẽ xử lý với file JPG bởi vì chúng sẳn sàn trong định dạng mà bạn muốn. 

if ($type == 2) { 

rename($ImageName, $newfilename); 

Ở đây, nếu file là file JPG, bạn sẽ đổi tên nó thành ID hình ảnh của bạn cộng với 

phần mở rộng ”.jpg”. 

Mặc khác, nếu file là GIF hoặc PNG  bạn sử dụng hàm thích hợp để xử lý chúng. 

Bạn kiểm tra để thấy nếu file la JPG 

} else { 

if ($type = = 1) { 

$image_old = imagecreatefromgif($ImageName); 

imagecreatefromgif() là hàm hợp lý, bởi vì hình gốc có đuôi GIF. Nếu hình là PNG thì 

bạn sử dụng hàm imagecreatefrompng : 

} elseif ($type = = 3) { 

$image_old = imagecreatefrompng($ImageName); 

Bây giờ bạn có hình gốc GD thân thiện, bạn cần đến bƣớc 2 để tạo hình ảnh đích tạm. 

Bạn làm điều này trong dòng tiếp theo 

$image_jpg = imagecreatetruecolor($width, $height); 

Bạn sử dụng hàm imagecreatetruecolor() để tạo màu cho hình. Bạn muốn kích thƣớc của 

hình thay đổi bạn sử dụng biến $width và $height đƣợc chứa trong hàm getimagesize. 

  Bây giờ bạn chuyển sang bƣớc 3 trong dòng tiếp theo: 

imagecopyresampled($image_jpg, $image_old, 0, 0, 0, 0, 

$width, $height, $width, $height); 

Bạn sử dụng hàm imagecopyresampled để quyết định thuộc tính cho hình. Ở đây hình 

gốc và hình đích đều bắt đầu với tọa độ x,y với chiều dài và chiều rông của mỗi hình. 

Nếu bạn chỉ muốn sao chep vị trí của hình gốc vào hình đích bạn co thể dùng tọa độ và 

các biến $width/$height. 

  Tiếp theo, bạn lƣu hình ảnh bằng dòng sau: 

imagejpeg($image_jpg, $newfilename); 

  - 180 - 

Đây là nơi thật sự chuyển đổi, trƣớc dòng này hình tạm có đặc điểm chung. 

Bạn quyết định làm file đích JPG với hàm imagejpeg. Bạn cũng có thể sử dụng imagepng 

hoặc imagegif, nhƣng một lần nữa, bạn muốn làm việc với JPG vì phần lớn những file 

bạn load lên sẽ đƣợc sao chép. Trong hàm này bạn đặt ten file nguồn tạm và file đích lâu 

dài. Quan trọng bạn cần có phần tên dùng biến $newfilename, bạn cũng có thể xóa những 

hình tạm nhƣ dƣới đây 

imagedestroy($image_old); 

imagedestroy($image_jpg); 

Trong bảng tóm tắt, bạn đổi tên file JPG thành image_id.jpg, Hoặc tạo một bản sao và 

lƣu với và lƣu file JPG với tên image_id.jpg. 

  Tập lệnh cũng xây dựng  lại một file mới showimage.php  mà chủ yếu là điền 

thông tin mà bạn đã nhập vào cở sở dữ liệu. Điều khác biệt là bạn có thể cập nhật mọi lúc 

mọi nơi, và cho phép ngƣời dùng có thể sửa đổi. 

7.4.  Màu trắng và đen 

  Bây giờ bạn đã có thƣ mục với nhiều hình ảnh. Nếu muốn cho phép ngƣời dùng 

làm những hình ảnh thành màu trắng và đen. Chúng ta hãy thêm tùy chọn đó vào trang  

showimage, nhƣ vậy ngƣời dùng có thể chọn là thấy hay không thấy hình ảnh trong 

“grayscale”.Banj sẽ sử dụng hàm imagefilter(), để chuyển hình ảnh tới grayscale. Hàm  

này  cũng  có  thể  làm  ảnh  ngƣợc,  độ  chói,  làm  nổi,  mờ,  làm  nhẵn  và  màu  của  hình 

ảnh…Có thể dùng hàm này để làm sạch hoặc tạo ra những phiên bản mới nhất của những 

bức ảnh uploaded. 

Ví dụ:Thêm Grayscale 

Trong bài tập này, chúng ta chỉ thêm những đặc tính imagefilter() vào vị trí, cho 

phép ngƣời dùng tùy chọn để thấy hình ảnh trong graycale 

1.Mỡ file showimage.php và thay đổi nhƣ sau: 

<?php 

//Kết nối cở sở dữ liệu  

$link = mysql_connect(“localhost”, “root”, “”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(“moviesite”, $link) 

or die (mysql_error()); 

  - 181 - 

//Làm những biến có sẵn 

$id = $_REQUEST[„id‟]; 

//**Những dòng chèn thêm 

if (isset($_REQUEST[„mode‟]))  

$mode = $_REQUEST[„mode‟]; 

} else  

$mode = „‟; 

//**Kết thúc dòng chèn 

//Tạo thông tin chúng ta muốn 

$getpic = mysql_query(“SELECT * FROM images WHERE image_id = 

„$id‟”) 

or die(mysql_error()); 

$rows = mysql_fetch_array($getpic); 

extract($rows); 

$image_filename = “images/” . $image_id . “.jpg”; 

list($width, $height, $type, $attr) = getimagesize($image_filename); 

?> 

<html> 

<head> 

<title>Here is your pic!</title> 

</head> 

<body> 

<h1>So how does it feel to be famous?</h1><br><br> 

<!--INSERT THE FOLLOWING LINES: --> 

<?php 

if ($mode == „change‟) { 

echo “<font color=\”CC0000\”><em><strong>Your image has been 

modified.</strong></em></font>”; 

  - 182 - 

echo “<img src=\”” . $image_filename . “\” align=\”left\” “ . 

$attr . “>”; 

} else { 

?> 

<!--END OF INSERTED LINES--> 

<p>Here is the picture you just uploaded to our servers:</p> 

<img src=”<?php echo $image_filename; ?>” align=”left” 

<?php echo $attr; ?> > 

<strong><?php echo $image_caption; ?></strong><br> 

It is <?php echo $width; ?> pixels wide 

and <?php echo $height; ?> pixels high.<br> 

It was uploaded on <?php echo $image_date; ?> 

by <?php echo $image_username; ?>. 

<!--INSERT THE FOLLOWING LINES:--> 

<?php 

//end the else 

?> 

<hr> 

<p><em><strong>Modifying Your Image</strong></em></p> 

<form action=”modifyimage.php” method=”post”> 

<p> 

Please choose if you would like to modify your image with any of 

the following options. If you would like to preview the image 

before saving, you will need to hit your browser‟s „back‟ button 

to return to this page. Saving an image with any of the 

modifications listed below <em>cannot be undone.</em> 

</p> 

<input  name=”id”  type=”hidden”  value=”<?php  echo  $image_id; 

?>”> 

<input name=”bw” type=”checkbox”>black &amp; white<br> 

  - 183 - 

<p align=”center”> 

<input type=”submit” name=”action” value=”preview”> 

<input type=”submit” name=”action” value=”save”> 

</p> 

</form> 

<!--END OF INSERTED LINES--> 

</body> 

</html> 

2. Kế đến, ta tạo hồ sơ mới để sửa đổi hình ảnh, lƣu với file modify.php 

<?php 

//kết nối cở sở dữ liệu 

$link = mysql_connect(“localhost”, “root”, “”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(“moviesite”, $link) 

or die (mysql_error()); 

//làm những biến có sẵn 

$id = $_POST[„id‟]; 

if (isset($_POST[„bw‟])) 

$bw = $_POST[„bw‟]; 

} else  

$bw = „‟; 

$action = $_POST[„action‟]; 

//tạo thông tin bạn muốn 

$getpic  =  mysql_query(“SELECT  *  FROM  images  WHERE 

image_id = „$id‟”) 

or die(mysql_error()); 

$rows = mysql_fetch_array($getpic); 

  - 184 - 

extract($rows); 

$image_filename = “images/” . $image_id . “.jpg”; 

list($width, $height, $type, $attr) =  

getimagesize($image_filename); 

$image = imagecreatefromjpeg(“$image_filename”); 

if ($bw == „on‟)  

imagefilter($image, IMG_FILTER_GRAYSCALE); 

if ($action == “preview”) 

header(“Content-type:image/jpeg”); 

imagejpeg($image); 

if ($action == “save”) 

 { 

imagejpeg($image, $image_filename); 

$url  =  “location:showimage.php?id=”.  $id  . 

“&mode=change”; 

header($url); 

?> 

3.  Chúng ta không cần nạp dữ liệu vào hình khác, bởi vì chúng ta không thay đổi gì 

trong  các  bƣớc  của  tiến  trình.  Chúng  ta  hãy  vào  http:  //  Localhost  / 

showimage.php?id = 1 , bạn sẽ thấy nhƣ hình dƣới đây 

  - 185 - 

Hình 7.4.1  

Nếu xem trƣớc hình ảnh trắng đen, bạn sẽ thấy màn hình không có gì. Cố gắng 

quay lại và lƣu file trong màu trắng đen cùng lúc. 

Hình 7.4.2 

Nó làm việc thế nào? 

Nếu bạn nhìn những dòng bạn thêm trong showiamge.php, bạn thấy những dòng 

này trƣớc tiên: 

//**Những dòng chèn thêm 

if (isset($_REQUEST[„mode‟])) 

 { 

$mode = $_REQUEST[„mode‟]; 

} else 

 { 

$mode = „‟; 

  - 186 - 

//**Kết thúc dòng chèn 

  Bạn thêm biến vì trong modifyimage.php, bạn gởi đến ngƣời dùng quay lại trang 

này để thấy hình ảnh của họ mới đƣợc sửa. Bạn muốn gởi cho họ vài thông tin mà cho 

phép họ cất giữ thành công. 

<!--INSERT THE FOLLOWING LINES: --> 

<?php 

if ($mode == change) { 

echo “<font color=\”CC0000\”><em><strong>Your image has been 

modified.</strong></em></font>”; 

echo “<img src=\”” . $image_filename . “\” align=\”left\” “ . 

$attr . “>”; 

} else { 

  Bạn thấy : “Your image has been modified” . Bạn thấy hình ảnh lần nữa, vì thế họ 

thấy hoạt động thay đổi. Ngƣời dùng nhìn thấy thông tin khi upload lần đầu tiên. Những 

dòng sau, cho phép ngƣời dùng tùy chọn trắng đen. 

<hr> 

<p><em><strong>Modifying Your Image</strong></em></p> 

<form action=”modifyimage.php” method=”post”> 

<p> 

Please choose if you would like to modify your image with any of 

the following options. If you would like to preview the image 

before saving, you will need to hit your browser‟s „back‟ button 

to return to this page. Saving an image with any of the 

modifications listed below <em>cannot be undone.</em> 

</p> 

<input name=”id” type=”hidden” value=”<?php echo $image_id; ?>”> 

<input name=”bw” type=”checkbox”>black &amp; white<br> 

<p align=”center”> 

<input type=”submit” name=”action” value=”preview”> 

<input type=”submit” name=”action” value=”save”> 

</p> 

  - 187 - 

</form> 

<!--END OF INSERTED LINES--> 

  Chúng ta mới tạo file modifileimage.php, cho đến hàng này thì mọi thứ đã khá 

chuẩn 

$image = imagecreatefromjpeg(“$image_filename”); 

  Bạn đã có quá trình 5 bƣớc chuyển đổi, bạn tạo ra một GD_bản sao hình ảnh thân 

thiện của hình ảnh nguồn, tiếp theo bạn muốn làm tất cả những gì tạo ra hình ảnh thân 

thiện nhƣ thấy dƣới đây 

if ($bw == „on‟) { 

imagefilter($image, IMG_FILTER_GRAYSCALE); 

Bạn quyết định là giữ hay không giữ những thay đổi, bằng những dòng code sau: 

if ($action == “preview”) { 

header(“Content-type:image/jpeg”); 

imagejpeg($image); 

  Nếu bạn chỉ xem trƣớc hình ảnh, bạn gởi trực tiếp đến trình duyệt(đƣợc sử dụng 

bởi hàm iamgejpeg()). Nhƣng tại sao lại gởi đầu mục cho trình duyệt và tại sao lại không 

có HTML? Một lần nữa vì bạn gởi hình ảnh  trực tiếp, bạn không cần( và thật sự không 

thể gởi) bất kỳ văn bản nào với hình ảnh. Bạn chỉ gởi đon thuần hình ảnh. Nếu bạn chỉ rõ 

kiểu nội dung trong trang thì trình duyệt sẽ hiểu là văn bản và bạn có một trang đầy rác. 

Bạn phải thêm vào đầu mục để trình duyệt giải thích dòng hình ảnh chính xác. 

Vì trình duyệt đang chờ một hình ảnh, nếu gởi bất kỳ một văn bản kèm theo hình 

ảnh nào, cũng gởi thêm đầu mục thì bạn sẽ nhận đƣợc lỗi. 

Nếu ngƣời dùng muốn  lƣu những thay đổi hình ảnh và click vào “save” khi đang 

submit, bạn phải thực hiện những dòng sau: 

if ($action == “save”) { 

imagejpeg($image, $image_filename); 

$url = “location:showimage.php?id=”. $id . “&mode=change”; 

header($url); 

  - 188 - 

  Chú ý việc sử dụng kiểu biến( ngƣời sử dụng sẽ thấy thông tin văn bản khi trang 

đƣa lên) và filename chỉ rõ trong hàm imagejpeg(). Chỉ rõ filename đến lƣu hình ảnh tạm 

trong thời gian dài. Trong trƣờng hợp này, nó ghi đè lên file có sẵn, làm cho sự chuyển 

đổi lâu. 

7.5.  Thêm những dấu đề 

Một nhóm hàm đặc biệt cho phép bạn thêm những dấu đề( hoặc chú thích một bản 

quyền , một văn bản khác). PHP/GD cho phép bạn thay đổi kiểu phông và kích thƣớc sử 

dụng, thậm chí cho phép bạn tải phông theo yêu cầu. 

Ví dụ về việc thêm văn bản trong hình ảnh 

Bạn thay đổi file showimage.php và file modifyimage.php để thấy những dấu đề 

kèm theo hình ảnh. 

1. Xác định vị trí mục sau trong file showimage.php và thêm những dòng sau: 

<hr> 

<p><em><strong>Modifying Your Image</strong></em></p> 

<form action=”modifyimage.php” method=”post”> 

<p> 

Hãy chọn nếu bạn muốn thay đổi hình ảnh với bất kỳ lựa chọn nào dƣới 

đây. Nếu muốn xem hình ảnh trƣớc khi cất giữ, bận cần đánh nút “back” để trả về 

trang này. Lƣu hình ảnh với danh sách:<em>Không thế hủy.</em> 

</p> 

<input name=”id” type=”hidden” value=”<?php echo $image_id; ?>”> 

<input name=”bw” type=”checkbox”>black & white<br> 

<!--INSERT THE FOLLOWING LINE--> 

<input name=”text” type=”checkbox”>embedded caption<br> 

<!--END OF INSERTED LINES--> 

<p align=”center”> 

<input type=”submit” name=”action” value=”preview”> 

<input type=”submit” name=”action” value=”save”> 

</p> 

</form> 

  - 189 - 

2. Phông “arial.ttf” đƣợc dùng trong bài tập này, nhƣng bạn nên dùng phông đƣợc 

cài đặt trong máy chủ. Nếu thử chạy phiên bản mà không cài đặt phông trên máy chủ, sẽ 

báo lỗi. Trong file modifyimage.php, thêm những dòng sau: 

<?php 

//Kết nối cở sở dữ liệu 

$link = mysql_connect(“localhost”, “bp5am”, “bp5ampass”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(“moviesite”, $link) 

or die (mysql_error()); 

//Làm những biến có sẵn 

$id = $_POST[„id‟]; 

if (isset($_POST[„bw‟])) { 

$bw = $_POST[„bw‟]; 

} else { 

$bw = „‟; 

$action = $_POST[„action‟]; 

//**INSERT THE FOLLOWING LINES: 

if (isset($_POST[„text‟])) { 

$text = $_POST[„text‟]; 

} else { 

$text = „‟; 

//**END OF INSERT 

//get info on the pic we want 

$getpic = mysql_query(“SELECT * FROM images  WHERE  image_id  = 

„$id‟”) 

or die(mysql_error()); 

$rows = mysql_fetch_array($getpic); 

extract($rows); 

$image_filename = “images/” . $image_id . “.jpg”; 

  - 190 - 

list($width, $height, $type, $attr) = getimagesize($image_filename); 

$image = imagecreatefromjpeg(“$image_filename”); 

if ($bw == „on‟) { 

imagefilter($image, IMG_FILTER_GRAYSCALE); 

//**INSERT THE FOLLOWING LINES: 

if ($text == „on‟) { 

imagettftext($image, 12, 0, 20, 20, 0, “arial.ttf”, $image_caption); 

//**END OF INSERT 

if ($action == “preview”) { 

header(“Content-type:image/jpeg”); 

imagejpeg($image); 

if ($action == “save”) { 

imagejpeg($image, $image_filename); 

$url = “location:showimage.php?id=”. $id . “&mode=change”; 

header($url); 

?> 

4.  Quay  lại  trang 190Hhttp://localhost/showimage.php?id=1  và  xem  trƣớc  ảnh  với 

việc”nhúng dấu đề” có đặc tính kiểm tra. Sẽ thấy nhƣ Hình 7.5. 

Hình 7.5 

  - 191 - 

5.   Bạn có thể dễ dàng thêm tự động những chú thích bản quyền hay bất kỳ một văn 

bản nào trong ảnh. 

Cách thức hoạt động. 

Trƣớc tiên, thêm lựa chọn”nhúng dấu đề” trong showimage.php. Sau đó, thêm 

hàm imagettftext trong file modifyimage nhƣ sau: 

//**Bắt đầu chèn: 

if ($text == „on‟) { 

imagettftext($image, 12, 0, 20, 20, 0, “arial.ttf”, $image_caption); 

//**Kết thúc chèn 

Hàm imagettftext() là một trong nhiều  hàm văn bản/chuỗi có sẵn trong 

PHP/GD. Hàm tạo 8 giá trị: 

1.  Hình ảnh nơi chèn văn bản ($image trong ví dụ) 

2.  Cỡ phông văn bản(trong ví dụ là 12) 

3.  Sự luân phiên văn bản( trong ví dụ là 0) 

4.  Tọa độ X là vị trí bắt đầu của văn bản, với 0 là ranh giới( trong ví dụ là 20) 

5.  Tọa độ y là vị trí bắt đầu của văn bản, với 0 là ranh giới trên của hình ảnh( trong ví 

dụ này là 20) 

6.  Màu sử dụng (trong ví dụ là 0, màu đen) 

7.  Tên phông, đƣợc định vị tự động trong thƣ mục phông mặc định( Trong ví dụ này 

là phông arial.ttf) 

8.  Chuỗi văn bản đƣợc cho thấy( Trong ví dụ là biến image_option) 

Trong quá trình làm nhớ phải điền đây đủ 8 giá trị, nếu không sẽ gặp lỗi) 

7.6.  Thêm hình mờ và kết hợp hình ảnh 

Bởi vì bạn đang thấy những hình ảnh trong Movie review Site, bạn muốn làm biểu 

tƣợng đằng sau mỗi hình, nhƣ một loại hình mờ. Chúng ta có thể làm điều này với biểu 

tƣợng của mình để bảo vệ bất kỳ hình ảnh copy nào. Trong ví dụ này, chúng ta sẽ hòa 

trộn 2 hình (hình nguồn và hình biểu tƣợng) để tạo hiệu ứng. Chúng ta thay đổi nhƣ sau: 

Ví dụ : Trộn 2 hình 

Trộn 2 hình, bạn cần thay đổi trong showimage.php và trong modifyimage.php 

  - 192 - 

1. Thêm vào những dòng sau trong showimage.php, trong phần nhƣ trƣớc 

<input  name=”watermark”  type=”checkbox”>include  Movie  Review  Site 

watermark<br> 

2. Thêm vào những dòng sau trong modifyimage.php, nhƣ trƣớc 

//**Chèn gần đỉnh của file 

if (isset($_POST[„watermark‟])) 

$watermark = $_POST[„watermark‟]; 

} else  

$watermark = „‟; 

Sau đó thêm vào những dòng dƣới đây vào sau tập lệnh 

if ($watermark == „on‟) { 

$image2 = imagecreatefromgif(“images/logo.gif”); 

imagecopymerge($image, $image2, 0,0,0, 0, $width, $height, 15); 

3.Mặc dù không có file logo.gif nhƣng bạn có thể sử dụng bất kỳ file nào bạn 

thích, chắc chắn rằng tập lệnh có thể tìm thấy. Bạn sẽ thấy nhƣ hình 7.6 sau: 

Hình 7.6 

Cách thức hoạt động: 

  - 193 - 

Bạn thêm tùy chọn khác cho ngƣời dùng,  bạn sử dụng hàm imagecopymerge() 

trong modifyimage.php. Chú ý là trƣớc khi hòa trộn hai hình, phải làm hình “GD thân 

thiện” thứ hai bằng việc tạo một bản sao chép. Vì hình ảnh của bạn là hình GIF nên sử 

dụng hàm imagecreatefromgif() 

Nguyên bản của hàm: 

imagecopymerge($image, $image2, 0,0,0, 0, $width, $height, 15); 

  Những tham số trong hàm imagecopymerge nhƣ sau: 

1. Tên của hình ảnh tới( Trong ví dụ này, dùng biến $image, file $image thay đổi tất cả 

và sẽ thấy ở cuối của nguyên bản) 

2. Tên của hình “lần hai‟ hoặc hình nguồn( Trong ví dụ này là $iamge) 

3. Tọa độ X của hình đến( Trong ví dụ này là 0, đại diện cho ranh giới dƣới) 

4. Tọa độ Y của hình ảnh đến ( Trong ví dụ này là 0, đại diên cho ranh giới trên) 

5. Toạ độ X của hình thứ hai( Trong ví dụ này là 0) 

6. Tọa độ Y của hình thứ hai ( Trong ví dụ này là 0) 

7. Chiều rộng của phần hình thứ hai đƣợc trộn(Trong ví dụ này dùng biến $width, đại 

diện cho hình thứ hai phù hợp với hình đến) 

8. Chiều cao của phần hình ảnh thứ hai đƣợc hòa trộn( Trong ví dụ này,  dùng biến 

$height, đại diện cho hình thứ hai phù hợp với hình đến) 

9. Phần trăm của hai hình, với 100 nghĩa là hình thứ hai hoàn toàn  đè lên hình thứ nhất 

(Trong ví dụ này là 15) 

Chúng ta hãy nói về số 7 và số 8. Vì hàm imagecopymerge() có thể hòa trộn một 

phần hình với hình khác, bạn phải chỉ rõ bao nhiêu hình muốn hòa trộn. Biểu tƣợng CBA 

thì khổng lồ, lớn hơn bức ảnh ngƣời dùng. Bạn chỉ muốn trộn phần ảnh lớn bằng bức ảnh 

ngƣời dùng, mà tại sao bạn sử dụng $height và $width. Nếu logo nhỏ, bạn chỉ rõ chiều 

rộng và chiều cao của chúng, nếu muốn hòa trộn toàn bộ những thứ với hình ảnh đầu 

tiên. 

7.7.  Tạo Thumbnails 

Tất nhiên, việc cho thấy những hình ảnh của ngƣời dùng thì tốt. Tuy nhiên, nó 

không tốt cho cuộc triển lãm hay một danh sách hình trong một trang. Bạn cần làm sao để 

tạo ra thumbnail tự động của mỗi file upload mà bạn sử dụng cho mục đích là một phòng 

triển lãm tranh. 

  - 194 - 

Ví dụ về việc tạo Thumbnails 

Bạn muốn tạo tự động một phiên bản thumbnail tất cả các hình mà ngƣời dùng 

upload, bạn cần sửa đổi check_image.php và bao gồm hàm: 

1. Tạo một danh mục hình ảnh con cho hình ảnh. Ví dụ, bạn tạo c:\Program Files\Apache 

Group\Apache2\images\thumbs, chắc rằng thƣ mục đƣợc cho phép. 

2. Thay đổi check_image.php nhƣ sau: 

<?php 

//Kết nối cở sở dữ liệu  

$link = mysql_connect(“localhost”, “bp5am”, “bp5ampass”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(“moviesite”, $link) 

or die (mysql_error()); 

//Tạo những biến có sẵn 

$image_caption = $_POST[„image_caption‟]; 

$image_username = $_POST[„image_username‟]; 

$image_tempname = $_FILES[„image_filename‟][„name‟]; 

$today = date(“Y-m-d”); 

//đƣa hình ảnh lên và kiểm tra loại hình ảnh 

$ImageDir = “c:/Program Files/Apache Group/Apache2/test/images/”; 

//**Chèn 

$ImageThumb = $ImageDir . “thumbs/”; 

//**Kết thúc chèn 

$ImageName = $ImageDir . $image_tempname; 

if (move_uploaded_file($_FILES[„image_filename‟][„tmp_name‟], 

$ImageName)) 

 { 

//get info about the image being uploaded 

list($width, $height, $type, $attr) =  

getimagesize($ImageName); 

if ($type > 3)  

  - 195 - 

echo “Sorry, but the file you uploaded was not a GIF, JPG, or 

“ . 

“PNG file.<br>”; 

echo “Please hit your browser‟s „back‟ button and try again.”; 

} else 

 { 

//image is acceptable; ok to proceed 

//Chèn thông tin vào bảng hình ảnh 

$insert = “INSERT INTO images 

(image_caption, image_username, image_date) 

VALUES 

(„$image_caption‟, „$image_username‟, „$today‟)”; 

$insertresults = mysql_query($insert) 

or die(mysql_error()); 

$lastpicid = mysql_insert_id(); 

$newfilename = $ImageDir . $lastpicid . “.jpg”; 

if ($type == 2)  

rename($ImageName, $newfilename); 

} else  

if ($type == 1) 

 { 

$image_old = imagecreatefromgif($ImageName); 

} elseif ($type == 3) 

 { 

$image_old = imagecreatefrompng($ImageName); 

//”convert” the image to jpg 

$image_jpg = imagecreatetruecolor($width, $height); 

imagecopyresampled($image_jpg, $image_old, 0, 0, 0, 0, 

  - 196 - 

$width, $height, $width, $height); 

imagejpeg($image_jpg, $newfilename); 

imagedestroy($image_old); 

imagedestroy($image_jpg); 

//**Bắt đầu chèn 

$newthumbname = $ImageThumb . $lastpicid . “.jpg”; 

//thiết lập chiều cho thumbnail 

$thumb_width = $width * 0.10; 

$thumb_height = $height * 0.10; 

//Tạo thumbnail 

$largeimage = imagecreatefromjpeg($newfilename); 

$thumb  =  imagecreatetruecolor($thumb_width, 

$thumb_height); 

imagecopyresampled($thumb, $largeimage, 0, 0, 0, 0, 

$thumb_width, $thumb_height, $width, $height); 

imagejpeg($thumb, $newthumbname); 

imagedestroy($largeimage); 

imagedestroy($thumb); 

//**Kết thúc chèn 

$url = “location: showimage.php?id=” . $lastpicid; 

header ($url); 

?> 

3. Bây giờ chúng ta sẽ tạo gallery.php nhƣ phòng triển lãm của bạn, nhập 

đoạn mã sau: 

<?php 

//Kết nối cơ sở dữ liệu 

$link = mysql_connect(“localhost”, “root”, “”) 

or die(“Could not connect: “ . msql_error()); 

  - 197 - 

mysql_select_db(“moviesite”, $link) 

or die (mysql_error()); 

$ImageDir = “images”; 

$ImageThumb = $ImageDir . “/thumbs/”; 

?> 

<html> 

<head> 

<title>Welcome to our Photo Gallery</title> 

</head> 

<body> 

<p align=”center”>Click on any image to see it full sized.</p> 

<table align=”center”> 

<tr> 

<td align=”center”>Image</td> 

<td align=”center”>Caption</td> 

<td align=”center”>Uploaded By</td> 

<td align=”center”>Date Uploaded</td> 

</tr> 

<?php 

//get the thumbs 

$getpic = mysql_query(“SELECT * FROM images”) 

or die(mysql_error()); 

while ($rows = mysql_fetch_array($getpic)) { 

extract($rows); 

echo “<tr>

”; 

echo “<td><a href=\””.$ImageDir . $image_id . “.jpg\”>”; 

echo  “<img  src=\””  .  $ImageThumb  .  $image_id  .  “.jpg\” 

border=\”0\”>”; 

echo “</a></td>

”; 

echo “<td>” . $image_caption . “</td>

”; 

echo “<td>” . $image_username . “</td>

”; 

  - 198 - 

echo “<td>” . $image_date . “</td>

”; 

echo “</tr>

”; 

?> 

</table> 

</body> 

</html> 

4. Bây giờ bạn đƣa một vài hình sử dụng cho trang upload_image.php. Bạn sẽ thấy nhƣ 

hình 7-8, bạn có thể thêm âm thanh tùy ý. 

Hình 7.8 

Cách thức hoạt động: 

Thực sự tự thumbnails tạo ra trong trang check_image.php, bạn thêm những đoạn 

sau đây để hoàn thành 

//**Chèn từ dòng này 

$newthumbname = $ImageThumb . $lastpicid . “.jpg”; 

//Taọ kích thƣớc cho thumbnails 

$thumb_width = $width * 0.10; 

$thumb_height = $height * 0.10; 

//Tạo thumbnail 

$largeimage = imagecreatefromjpeg($newfilename); 

$thumb = imagecreatetruecolor($thumb_width, $thumb_height); 

imagecopyresampled($thumb, $largeimage, 0, 0, 0, 0, 

  - 199 - 

$thumb_width, $thumb_height, $width, $height); 

imagejpeg($thumb, $newthumbname); 

imagedestroy($largeimage); 

imagedestroy($thumb); 

//**Kết thúc dòng chèn 

Bạn tạo một thumbnail quá trình gồm 5 bƣớc nhƣ trƣớc: 

1.  Tạo một GD thân thiện từ hình nguồn 

2.  Tạo một GD thân thiện là một hình trống, với kích thƣớc nhỏ 

3.  Sao chép hình nguồn vào hình trống 

4.  Cất giữ hình mới đó vào một thƣ mục thích hợp 

5.  Xóa những hình tạm thời  

  - 200 - 

Chƣơng  8:  NGƢỜI DÙNG NHẬP CÓ HIỆU LỰC 

Nếu bạn chấp nhận cho ngƣời dùng đƣợc nhập vào trang web, bạn phải chuẩn bị 

gặp những lỗi. Có thể chỉ là lỗi đơn giản hoặc những lỗi ảnh hƣởng trang web của bạn. 

Lỗi chung nhất thƣờng gặp là lỗi thuật in cơ bản, lỗi định dạng (ví dụ cho một năm trong 

một ngày). Những lỗi nhƣ ngƣời dùng không cung cấp địa chỉ email, hoặc ngƣời dùng 

xâm nhập vào cơ sở dữ liệu của bạn. Tập lệnh cần có phần điều khiển nhập, bằng việc 

xác định dữ liệu xấu và trả về trang thông báo lỗi cho ngƣời dùng. Bao gồm: 

  Làm cho có hiệu lực những giá trị chuỗi đơn giản 

  Làm cho có hiệu lực những giá trị nguyên 

  Làm cho có hiệu lực văn bản nhập vào đã định dạng  

8.1.  Những ngƣời dùng chỉ là những ngƣời dùng … 

Ví dụ bây giờ bạn đang làm việc trong ngân hàng, bạn thiết lập hệ thống quản lý 

tài khoản cập nhật của khách hàng. Bạn sử dụng định dạng MM-DD-YYYY để định dạng 

ngày tháng. Khi đƣa vào hoạt động thì nó không làm việc. Tại sao? Vì tất cả hệ thống của 

bạn sử dụng ISO 8601 định dạng ngày tháng YYYY-MM-DD. Ngƣời sử dụng sẽ nhầm 

lẫn giữa 2 dạng này nên nhập thông tin không có hiệu lực. Bạn có thể khắc phục điều này 

bằng việc sử dụng khuôn mẫu chung và làm cho ngƣời sử dụng nhập có hiệu lực. 

8.2.   Kết hợp có hiệu lực vào Movie Site 

Để thật sự hiểu vai trò và sự kết hợp của ngƣời dùng nhập, bạn muốn thấy nó hoạt 

động. Nhƣ vậy, bạn cần thêm vài vùng trong cơ sở dữ liệu của bạn, cung cấp nhiều 

phƣơng tiện để kiểm tra ngƣời dùng nhập vào. Bạn cần thêm một vài đặc tính trong ứng 

dụng, giúp ta xem lại những phần trƣớc đây. 

Thêm vào một vùng movie_release INT(11) với giá trị mặc định là 0 sau vùng 

movie_year, nhƣ Hình 8.1 

  - 201 - 

Hình 8.1 

Cho  phép  bạn  lƣu  trữ  một  timestamp  cho  ngày  tháng  trong  phiên  bản  movie. 

Thêm vùng movie_rating vào cuối kiểu TINYINT(2). Thông tin đó chứa đánh giá khi 

bạn xem lại.(xem Hình 8.2)Cái này bắt buộc đi từ 0 đến 10 

Hình 8.2 

8.3.  Quên điều gì? 

Đôi lúc ngƣời dùng nhập dữ liệu trong form, họ quên điền đầy đủ thông tin. Nếu 

điều này xảy ra, hệ thống phải đƣợc lồng những dữ liệu sai hoặc không đầy đủ để không 

làm ảnh hƣởng đến cở sở dữ liệu. Bạn phải làm thế nào để hệ thống phản ứng lại những 

lỗi nhƣ vậy mà không làm hỏng cở sở dữ liệu. 

Ví dụ: Thêm vào tập lệnh để ngƣời dùng nhập 

Trong ví dụ này bạn chắc rằng tập lệnh có thể sửa lại khi ngƣời dùng nhập sai. 

1. Copy đoạn mã trong chƣơng 6 vào thƣ mục mới, mở tập lệnh movie.php và sửa nhƣ 

những dòng hƣớng dẫn sau: 

  - 202 - 

<?php 

$link = mysql_connect(“localhost”, “root”, “”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(„moviesite‟, $link) 

or die ( mysql_error()); 

$peoplesql = “SELECT * FROM people”; 

$result = mysql_query($peoplesql) 

or die(“Invalid query: “ . mysql_error()); 

while ($row = mysql_fetch_array($result))  

$people[$row[„people_id‟]] = $row[„people_fullname‟]; 

switch ($_GET[„action‟])  

case “edit”: 

$moviesql = “SELECT * FROM movie “ . 

“WHERE movie_id = „“ . $_GET[„id‟] . 

$result = mysql_query($moviesql) 

or die(“Invalid query: “ . mysql_error()); 

$row = mysql_fetch_array($result); 

$movie_name = $row[„movie_name‟]; 

$movie_type = $row[„movie_type‟]; 

$movie_year = $row[„movie_year‟]; 

$movie_leadactor = $row[„movie_leadactor‟]; 

$movie_director = $row[„movie_director‟]; 

break; 

default: 

$movie_name = “”; 

$movie_type = “”; 

$movie_year = “”; 

$movie_leadactor = “”; 

  - 203 - 

$movie_director = “”; 

break; 

?> 

<html> 

<head> 

<title><?php echo $_GET[„action‟]; ?> movie</title> 

<style type=”text/css”> 

TD{color:#353535;font-family:verdana} 

TH{color:#FFFFFF;font-family:verdana;background-color:#336699} 

</style> 

</head> 

<body> 

<form action=”commit.php?action=<?php 

echo $_GET[„action‟]; ?>&type=movie&id=<?php 

if (isset($_GET[„id‟])) { echo $_GET[„id‟]; } ?>”  

method=”post”> 

<?php 

if (!empty($_GET[„error‟]))  

echo “<div align=\”center\” “ . 

“style=\”color:#FFFFFF;background-color:#FF0000; 

“font-weight:bold\”>”  . 

nl2br(urldecode($_GET[„error‟])) . 

“</div><br />”; 

?> 

<table border=”0” width=”750” cellspacing=”1” 

cellpadding=”3” bgcolor=”#353535”  

align=”center”> 

  - 204 - 

<tr> 

<td bgcolor=”#FFFFFF” width=”30%”>Movie  

Name</td> 

<td bgcolor=”#FFFFFF” width=”70%”> 

<input type=”text” name=”movie_name” 

value=”<?php echo $movie_name?>”> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Movie Type</td> 

<td bgcolor=”#FFFFFF”> 

<select id=”game” name=”movie_type” 

 style=”width:150px”> 

<option value=”” selected>Select a type...</option> 

<?php 

$sql = “SELECT movietype_id, movietype_label “ . 

“FROM movietype ORDER BY movietype_label”; 

$result = mysql_query($sql) 

or die(“<font color=\”#FF0000\”>Query  

Error</font>” . mysql_error()); 

while ($row = mysql_fetch_array($result))  

if ($row[„movietype_id‟] == $movie_type) { 

$selected = “ selected”; 

} else  

$selected = “”; 

echo „<option value=”‟ . $row[„movietype_id‟] . „“„ . 

$selected . 

„>‟ . $row[„movietype_label‟] . “</option>

”; 

  - 205 - 

?> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Movie Year</td> 

<td bgcolor=”#FFFFFF”> 

<select name=”movie_year”> 

<option value=”” selected>Select a year...</option> 

<?php 

for ($year=date(“Y”); $year >= 1970 ; $year--)  

if ($year == $movie_year) 

 { 

$selected = “ selected”; 

} else  

$selected = “”; 

?> 

<option value=”<?php echo $year; ?>” 

<?php echo $selected; ?>><?php echo $year; ?></option> 

<?php 

?> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Lead Actor</td> 

  - 206 - 

<td bgcolor=”#FFFFFF”> 

<select name=”movie_leadactor”> 

<option value=”” selected>Select an actor...</option> 

<?php 

foreach ($people as $people_id =>  

$people_fullname) 

 { 

if ($people_id == $movie_leadactor)  

$selected = “ selected”; 

} else { 

$selected = “”; 

?> 

<option value=”<?php echo $people_id; ?>” 

<?php echo $selected; ?>><?php echo $people_fullname; 

?></option> 

<?php 

?> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Director</td> 

<td bgcolor=”#FFFFFF”> 

<select name=”movie_director”> 

<option value=”” selected>Select a director...</option> 

<?php 

foreach ($people as $people_id =>  

$people_fullname) 

  - 207 - 

 { 

if ($people_id == $movie_director)  

$selected = “ selected”; 

} else { 

$selected = “”; 

?> 

<option value=”<?php echo $people_id; ?>” 

<?php echo $selected; ?>><?php echo $people_fullname; 

?></option> 

<?php 

?> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF” colspan=”2” align=”center”> 

<input type=”submit” name=”submit” 

value=”<?php echo $_GET[„action‟]; ?>”> 

</td> 

</tr> 

</table> 

</form> 

</body> 

</html> 

2. Lƣu file với tên movie.php và đƣa đoạn mã mới vào thƣ mục làm việc của bạn 

3. Mở tập lệnh commit.php và chỉnh sửa nhƣ những dòng hƣớng dẫn sau: 

<?php 

// COMMIT ADD AND EDITS 

  - 208 - 

$error = „‟; 

$link = mysql_connect(“localhost”, “root”, “”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(„moviesite‟, $link) 

or die ( mysql_error()); 

switch ($_GET[„action‟]) 

 { 

case “edit”: 

switch ($_GET[„type‟])  

case “people”: 

$sql = “UPDATE people SET “ . 

“people_fullname = „“ .  

$_POST[„people_fullname‟] . 

“„ WHERE people_id = „“ . $_GET[„id‟] . “„“; 

break; 

case “movie”: 

$movie_name = trim($_POST[„movie_name‟]); 

if (empty($movie_name)) 

 { 

$error .=  

“Please+enter+a+movie+name%21%0D%0A”; 

if (empty($_POST[„movie_type‟]))  

$error .=  

“Please+select+a+movie+type%21%0D%0A”; 

if (empty($_POST[„movie_year‟])) 

 { 

$error .=  

  - 209 - 

“Please+select+a+movie+year%21%0D%0A”; 

if (empty($error))  

$sql = “UPDATE movie SET “ . 

“movie_name = „“ . $_POST[„movie_name‟] . 

“„,” . 

“movie_year  =  „“  .  $_POST[„movie_year‟]  . 

“„,” . 

“movie_type  =  „“  .  $_POST[„movie_type‟]  . 

“„,” . 

“movie_leadactor = „“ . 

 $_POST[„movie_leadactor‟] . “„,” . 

“movie_director = „“ .  

$_POST[„movie_director‟] . “„ “ . 

“WHERE movie_id = „“.$_GET[„id‟].”‟”; 

} else { 

header(“location:movie.php?action=edit&error

=” . 

$error . “&id=” . $_GET[„id‟] ); 

break; 

break; 

case “add”: 

switch ($_GET[„type‟])  

case “people”: 

$sql = “INSERT INTO people (people_fullname) “ . 

“VALUES („“ . $_POST[„people_fullname‟] . “„)”; 

break; 

  - 210 - 

case “movie”: 

$movie_name = trim($_POST[„movie_name‟]); 

if (empty($movie_name))  

$error .=  

“Please+enter+a+movie+name%21%0D%0A”; 

if (empty($_POST[„movie_type‟])) 

 { 

$error .=  

“Please+select+a+movie+type%21%0D%0A”; 

if (empty($_POST[„movie_year‟])) 

$error .=  

“Please+select+a+movie+year%21%0D%0A”; 

if (empty($error)) 

 { 

$sql  =  “INSERT  INTO  movie 

(movie_name,movie_year,” . 

“movie_type,movie_leadactor,movie_director) 

“ . 

“VALUES („“ . $_POST[„movie_name‟] . “„,” . 

“„“ . $_POST[„movie_year‟] . “„,” . 

“„“ . $_POST[„movie_type‟] . “„,” . 

“„“ . $_POST[„movie_leadactor‟] . “„,” . 

“„“ . $_POST[„movie_director‟] . “„)”; 

} else { 

header(“location:movie.php?action=add&error

=” . $error); 

  - 211 - 

break; 

break; 

if (isset($sql) && !empty($sql)) 

 { 

echo “<!--”.$sql.”-->”; 

$result = mysql_query($sql) 

or die(“Invalid query: “ . mysql_error()); 

?> 

<p align=”center” style=”color:#FF0000”> 

Done. <a href=”index.php”>Index</a> 

</p> 

<?php 

?> 

4. Lƣu với tên commit.php và đƣa lên server 

5. Mở trình soạn thảo và vào trang 191Hhttp://localhost/chapter8/index.php và thêm vào một 

movie không tên, nhƣ Hình 8.3. 

Hình 8.3 

6. Nhập vào một movie mới mà không đặt năm và kiểu movie( Nhƣ Hình 8.4) 

  - 212 - 

Hình 8.4 

7. Soạn thảo một movie từ chỉ số và xóa form tên, submit( Nhƣ Hình 8.5) 

Hình 8.5  

8. Chú ý thông báo lỗi trong việc điền form( Nhƣ Hình 8.6) 

Hình 8.6  

Cách thức hoạt động 

Khi form chuyển thông tin đến tập lệnh, dữ liệu sẽ đƣợc xác nhận. Bạn sử dụng 

một phƣơng pháp đơn giản: hàm empty() trả về true nếu chuỗi rỗng, trả về false nếu 

  - 213 - 

không. Để đảm bảo rằng ngƣời dùng không trình bày form với một không gian đơn giản 

trong vùng tên movie, bạn dùng trim() trong nội dung của vùng để loại trừ bất kỳ dẫn đến 

nào hoặc kéo dài chuỗi( một vài ngƣời làm cho công việc trở nên khó khăn). 

Cùng lúc đó mà có lỗi đƣợc phát hiện thì bạn đƣa ra thông báo lỗi, dùng biến 

$error( tập hợp tất cả các lỗi) 

if (empty($movie_name)) 

 { 

$error = “Please+enter+a+movie+name%21%0D%0A”; 

Một lần nữa bạn thấy rằng có một lỗi xuất hiện, bạn gởi đến ngƣời dùng một thông 

báo lỗi. Thông báo lỗi đƣợc URL mã hóa để đảm bảo nó đƣợc chuyển đến tập lệnh 

move.php mà không bị hỏng 

if (empty($error))  

... 

} else 

 { 

header(“location:movie.php?action=add&error=” . $error); 

Một lần gởi đến form, hệ thống cần hiển thị giải mã thông báo lỗi 

<? 

if (!empty($_GET[„error‟]))  

echo “<div align=\”center\” “ . 

“style=\”color:#FFFFFF;background-color:#FF0000;” . 

“font-weight:bold\”>” . nl2br(urldecode($_GET[„error‟])) . 

“</div><br />”; 

?> 

  - 214 - 

Điều này trình bày thông báo quá màu mè mà ngƣời dùng sẽ không nhớ. Chính sự 

cập nhật đƣợc thực hiện vào lúc cuối của đoạn mã, cùng với tất cả các điều khiển và đƣa 

ra thông báo bạn cần 

if (isset($sql) && !empty($sql)) 

 { 

echo “<!--”.$sql.”-->”; 

$result = mysql_query($sql) 

or die(“Invalid query: “ . mysql_error()); 

?> 

<p align=”center” style=”color:#FF0000”> 

Done. <a href=”index.php”>Index</a> 

</p> 

<?php 

Nếu biến $sql không đƣợc thiết lập trƣớc ( mà có thể xảy ra nếu đƣợc gọi ra khỏi 

nội dung), đoạn mã sẽ không thực thi và không làm gì cả. ( Chú ý nó sẽ là bài tập tốt cho 

bạn để lập một phản hồi cho biến cố này, nhƣ một thông điệp hoặc một đăng ký lỗi trong 

cở sở dữ liệu) 

8.4.  Việc kiểm tra những kiểu lỗi 

Việc kiểm tra lỗi ngày tháng hoặc những dữ liệu định dạng khác là một yêu cầu 

cần thiết trong hệ thống bởi vì ngƣời dùng không phải lúc nào cũng đƣợc hƣớng dẫn 

nhập dữ liệu. Bạn phải luôn kiểm tra dữ liệu mà ngƣời dùng nhập vào nếu bạn định dạng 

hoặc thiết lập giá trị đặc biệt. 

Tại điểm này, bạn cần những biểu thức chung, những biểu thức này cho phép bạn 

định nghĩa một mẫu và kiểm tra xem có thể áp dụng vào dữ liệu hay không. Nó giúp bạn 

kiểm tra ngày tháng, số bảo mật và bất kỳ một dữ liệu nào mà đƣợc chú ý việc định dạng 

(nó giúp chắc chắn trong việc định dạng vùng nguồn. 

Ví dụ về kiểm tra ngày tháng và số 

Trong bài tập này bạn sẽ thay đổi vài trang để bạn kiểm tra việc định dạng ngày 

tháng của ngƣời dùng. 

  - 215 - 

1.Mở file movie.php và thay đổi nó nhƣ sau (thay đổi đƣợc làm nổi bật) 

<?php 

$link = mysql_connect(“localhost”, “bp5am”, “bp5ampass”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(„moviesite‟, $link) 

or die(mysql_error()); 

$peoplesql = “SELECT * FROM people”; 

$result = mysql_query($peoplesql) 

or die(“Invalid query: “ . mysql_error()); 

while ($row = mysql_fetch_array($result))  

$people[$row[„people_id‟]] = $row[„people_fullname‟]; 

switch ($_GET[„action‟])  

case “edit”: 

$moviesql = “SELECT * FROM movie “ . 

“WHERE movie_id = „“ . $_GET[„id‟] . “„“; 

$result = mysql_query($moviesql) 

or die(“Invalid query: “ . mysql_error()); 

$row = mysql_fetch_array($result); 

$movie_name = $row[„movie_name‟]; 

$movie_type = $row[„movie_type‟]; 

$movie_year = $row[„movie_year‟]; 

$movie_release = $row[„movie_release‟]; 

$movie_leadactor = $row[„movie_leadactor‟]; 

$movie_director = $row[„movie_director‟]; 

$movie_rating = $row[„movie_rating‟]; 

break; 

default: 

  - 216 - 

$movie_name = “”; 

$movie_type = “”; 

$movie_year = “”; 

$movie_release = time(); 

$movie_leadactor = “”; 

$movie_director = “”; 

$movie_rating = “5”; 

break; 

?> 

<html> 

<head> 

<title><?php echo $_GET[„action‟]; ?> movie</title> 

<style type=”text/css”> 

TD 

color:#353535;font-family:verdana 

TH 

color:#FFFFFF;font-family:verdana;background-color:#336699 

</style> 

</head> 

<body> 

<form action=”commit.php?action=<?php 

echo $_GET[„action‟]; ?>&type=movie&id=<?php 

if (isset($_GET[„id‟])) 

 { 

 echo $_GET[„id‟]; 

 } 

  - 217 - 

 ?>” method=”post”> 

<?php 

if (!empty($_GET[„error‟]))  

echo “<div align=\”center\” “ . 

“style=\”color:#FFFFFF;background-color:#FF0000;” . 

“font-weight:bold\”>” . nl2br(urldecode($_GET[„error‟])) . 

“</div><br />”; 

?> 

<table border=”0” width=”750” cellspacing=”1” 

cellpadding=”3” bgcolor=”#353535” align=”center”> 

<tr> 

<td bgcolor=”#FFFFFF” width=”30%”>Movie Name</td> 

<td bgcolor=”#FFFFFF” width=”70%”> 

<input type=”text” name=”movie_name” 

value=”<?php echo $movie_name?>”> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Movie Type</td> 

<td bgcolor=”#FFFFFF”> 

<select id=”game” name=”movie_type” style=”width:150px”> 

<option value=”” selected>Select a type...</option> 

<?php 

$sql = “SELECT movietype_id, movietype_label “ . 

“FROM movietype ORDER BY movietype_label”; 

$result = mysql_query($sql) 

or die(“<font color=\”#FF0000\”>Query Error</font>” . mysql_error()); 

while ($row = mysql_fetch_array($result))  

  - 218 - 

if ($row[„movietype_id‟] == $movie_type) 

 { 

$selected = “ selected”; 

 else  

$selected = “”; 

echo „<option value=”‟ . $row[„movietype_id‟] . „“„ . $selected . 

„>‟ . $row[„movietype_label‟] . “</option>

”; 

?> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Movie Year</td> 

<td bgcolor=”#FFFFFF”> 

<select name=”movie_year”> 

<option value=”” selected>Select a year...</option> 

<?php 

for ($year=date(“Y”); $year >= 1970 ;$year--)  

if ($year == $movie_year)  

$selected = “ selected”; 

}  

else  

$selected = “”; 

  - 219 - 

?> 

<option value=”<?php echo $year; ?>” 

<?php echo $selected; ?>><?php echo $year; ?></option> 

<?php 

?> 

</select> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Lead Actor</td> 

<td bgcolor=”#FFFFFF”> 

<select name=”movie_leadactor”> 

<option value=”” selected>Select an actor...</option> 

<?php 

foreach ($people as $people_id => $people_fullname)  

if ($people_id == $movie_leadactor)  

$selected = “ selected”; 

 else    

$selected = “”; 

?> 

<option value=”<?php echo $people_id; ?>” 

<?php echo $selected; ?>><?php echo $people_fullname; 

?></option> 

<?php 

  - 220 - 

?> 

</selected> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF”>Director</td> 

<td bgcolor=”#FFFFFF”> 

<select name=”movie_director”> 

<option value=”” selected>Select a director...</option> 

<?php 

foreach ($people as $people_id => $people_fullname)  

if ($people_id == $movie_director)  

$selected = “ selected”; 

 else  

$selected = “”; 

?> 

<option value=”<?php echo $people_id; ?>” 

<?php echo $selected; ?>><?php echo $people_fullname; 

?></option> 

<?php 

?> 

</select> 

</td> 

</tr> 

<tr> 

  - 221 - 

<td bgcolor=”#FFFFFF” width=”30%”> 

Movie release date (dd-mm-yyyy) 

</td> 

<td bgcolor=”#FFFFFF” width=”70%”> 

<input type=”text” name=”movie_release” 

value=”<?php echo date(“d-m-Y”, $movie_release); ?>”> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF” width=”30%”> 

Movie rating (0 to 10) 

</td> 

<td bgcolor=”#FFFFFF” width=”70%”> 

<input type=”text” name=”movie_rating” 

value=”<?php echo $movie_rating; ?>”> 

</td> 

</tr> 

<tr> 

<td bgcolor=”#FFFFFF” colspan=”” align=”center”> 

<input type=”submit” name=”submit” 

value=”<?php echo $_GET[„action‟]; ?>”> 

</td> 

</tr> 

</table> 

</form> 

</body> 

</html> 

2.Bây giờ file commit.php và thay đổi nhƣ sau: 

<?php 

// COMMIT ADD AND EDITS 

  - 222 - 

$error = „‟; 

$link = mysql_connect(“localhost”, “root”, “”) 

or die(“Could not connect: “ . mysql_error()); 

mysql_select_db(„moviesite‟, $link) 

or die ( mysql_error()); 

switch ($_GET[„action‟])  

case “edit”: 

switch ($_GET[„type‟])  

case “people”: 

$sql = “UPDATE people SET “ . 

“people_fullname = „“ . $_POST[„people_fullname‟] . 

“„ WHERE people_id = „“ . $_GET[„id‟] . “„“; 

break; 

case “movie”: 

$movie_rating = trim($_POST[„movie_rating‟]); 

if (!is_numeric($movie_rating))  

$error .= “Please+enter+a+numeric+rating+%21%0D%0A”; 

 else  

if ($movie_rating < 0 || $movie_rating > 10)  

$error .= “Please+enter+a+rating+” . 

“between+0+and+10%21%0D%0A”; 

if (!ereg(“([0-9]{2})-([0-9]{2})-([0-9]{4})”, 

$_POST[„movie_release‟] , 

  - 223 - 

$reldatepart))  

$error .= “Please+enter+a+date+” . 

“with+the+dd-mm-yyyy+format%21%0D%0A”; 

 else  

$movie_release = @mktime(0, 0, 0, $reldatepart[„2‟], 

$reldatepart[„1‟], 

$reldatepart[„3‟]); 

if ($movie_release == „-1‟)  

$error .= “Please+enter+a+real+date+” . 

“with+the+dd-mm-yyyy+format%21%0D%0A”; 

$movie_name = trim($_POST[„movie_name‟]); 

if (empty($movie_name))  

$error .= “Please+enter+a+movie+name%21%0D%0A”; 

if (empty($_POST[„movie_type‟]))  

$error .= “Please+select+a+movie+type%21%0D%0A”; 

if (empty($_POST[„movie_year‟]))  

$error .= “Please+select+a+movie+year%21%0D%0A”; 

if (empty($error) ) 

  - 224 - 

$sql = “UPDATE movie SET “ . 

“movie_name = „“ . $_POST[„movie_name‟] . “„,” . 

“movie_year = „“ . $_POST[„movie_year‟] . “„,” . 

“movie_release = „$movie_release‟,” . 

“movie_type = „“ . $_POST[„movie_type‟] . “„,” . 

“movie_leadactor = „“ . $_POST[„movie_leadactor‟] . “„,” . 

“movie_director = „“ . $_POST[„movie_director‟] . “„,” . 

“movie_rating = „$movie_rating‟” . 

“WHERE movie_id = „“ . $_GET[„id‟] . “„“; 

else  

header(“location:movie.php?action=edit&error=” . 

$error . “&id=” . $_GET[„id‟]); 

break; 

break; 

case “add”: 

switch ($_GET[„type‟])  

case “people”: 

$sql = “INSERT INTO people (people_fullname) “ . 

“VALUES („“ . $_POST[„people_fullname‟] . “„)”; 

break; 

case “movie”: 

$movie_rating = trim($_POST[„movie_rating‟]); 

if (!is_numeric($movie_rating))  

$error .= “Please+enter+a+numeric+rating+%21%0D%0A”; 

  - 225 - 

 else  

if ($movie_rating < 0 || $movie_rating > 10)  

$error .= “Please+enter+a+rating+” . 

“between+0+and+10%21%0D%0A”; 

$movie_release = trim($_POST[„movie_release‟]); 

if (!ereg(“([0-9]{2})-([0-9]{2})-([0-9]{4})”, 

$movie_release, 

$reldatepart) || empty($movie_release))  

$error .= “Please+enter+a+date+” . 

“with+the+dd-mm-yyyy+format%21%0D%0A”; 

 else  

$movie_release = @mktime(0, 0, 0, $reldatepart[„2‟], 

$reldatepart[„1‟], 

$reldatepart[„3‟]); 

if ($movie_release == „-1‟)  

$error .= “Please+enter+a+real+date+” . 

“with+the+dd-mm-yyyy+format%21%0D%0A”; 

$movie_name = trim($row[„movie_name‟]); 

i0f (empty($movie_name))  

$error .= “Please+enter+a+movie+name%21%0D%0A”; 

  - 226 - 

if (empty($_POST[„movie_type‟]))  

$error .= “Please+select+a+movie+type%21%0D%0A”; 

if (empty($_POST[„movie_year‟]))  

$error .= “Please+select+a+movie+year%21%0D%0A”; 

if (empty($error))  

$sql = “INSERT INTO movie (movie_name,movie_year,” . 

“movie_release,movie_type,movie_leadactor,” . 

“movie_director,movie_rating) “ . 

“VALUES („“ . $_POST[„movie_name‟] . “„,” . 

“„“ . $_POST[„movie_year‟] . “„,” . 

“„$movie_release‟,” . 

“„“ . $_POST[„movie_type‟] . “„,” . 

“„“ . $_POST[„movie_leadactor‟] . “„,” . 

“„“ . $_POST[„movie_director‟] . “„,” . 

“„$movie_rating‟)”; 

 else  

header(“location:movie.php?action=add&error=” . $error); 

break; 

break; 

if (isset($sql) && !empty($sql))  

  - 227 - 

echo “<!--”.$sql.”-->”; 

$result = mysql_query($sql) 

or die(“Invalid query: “ . mysql_error()); 

?> 

<p align=”center” style=”color:#FF0000”> 

Done. <a href=”index.php”>Index</a> 

</p> 

<?php 

?> 

3. Hãy lƣu những file này lại, mở trình duyệt bạn sẽ thấy index. 

4.Click bất kỳ một movie nào, thử nhập 2003-10-10 vào phiên bản ngày tháng. Bạn sẽ 

thấy một form đẹp, rõ ràng.(Nhƣ Hình 8.7) 

Hình 8.7 

5. Thử nhập vào giá trị chữ số bên trong(nhƣ Hình  8.8)dễ dàng có đƣợc hộp kéo xuống  

nhƣng là vùng văn bản cho mục đích trong bài tập. 

  - 228 - 

Hình 8.8 

Nếu nhập vào giá trị mà không có trong phạm vi từ 0 đến 10, nó sẽ từ chối. (chú ý 

những phần thập phân thì không có trong mã này nên cũng bị mất) 

Nó hoạt động thế nào? 

Trƣớc hết, hãy nhìn vào những hàm làm cho có hiệu lực. Trong commit.php, bạn 

sử dụng hàm is_numeric(). Hàm này trả về giá trị BOOL, nếu đúng trả về TRUE, nếu 

sai trả về FALSE. Có nhiều hàm có sẵn, ban gồm: 

is_string  kiểm tra nếu nó dạng chuỗi 

is_bool kiểm tra nếu dạng BOOL( TRUE, FALSE, 0, 1) 

is_array cho ta biết nếu biến chứa mảng 

is_object xác định nếu biến chứa một đối tƣợng ( khi bạn cố gắng dùng code 

hƣớng đối tƣợng trong PHP, nó rất có ích) 

Những hàm này là tài liệu PHP trong 1 92Hwww.php.net/variable Trong trƣờng hợp 

này sử dụng is_numeric cho phép bạn biết chắc rằng ngƣời dùng đã nhập đúng giá trị số. 

$movie_rating = trim($_POST[„movie_rating‟]); 

if (!is_numeric($movie_rating)) 

 { 

$error .= “Please+enter+a+numeric+rating+%21%0D%0A”; 

}  

else 

 { 

if ($movie_rating < 0 || $movie_rating > 10)  

  - 229 - 

$error .= “Please+enter+a+rating+” . 

“between+0+and+10%21%0D%0A”; 

  Đoạn mã dùng hàm trim() để kiểm tra giá trị. Nếu giá trị là số trong khoảng từ 0 

đến 10 thì cho thấy, nếu không thì đƣa ra thông báo lỗi. 

Làm có hiệu lực ngày tháng thì hầu nhƣ  đơn giản để hiểu, nếu bạn biết những biểu thức 

chung. Ở đây là: 

$movie_release = trim($_POST[„movie_release‟]); 

if (!ereg(“([0-9]{2})-([0-9]{2})-([0-9]{4})”, 

$movie_release, 

$reldatepart) || empty($movie_release))  

$error .= “Please+enter+a+date+” . 

“with+the+dd-mm-yyyy+format%21%0D%0A”; 

 else  

$movie_release = @mktime(0, 0, 0, $reldatepart[„2‟], 

$reldatepart[„1‟], 

$reldatepart[„3‟]); 

if ($movie_release == „-1‟)  

$error .= “Please+enter+a+real+date+” . 

“with+the+dd-mm-yyyy+format%21%0D%0A”; 

  Nhƣ bạn thấy trong bài tập đầu tiên của chƣơng này sử dụng hàm trim() để kiểm 

tra tất cả những không gian trong chuỗi để chắc rằng ngƣời dùng nhập chỉ một không 

gian. 

  - 230 - 

  Bạn có thể tìm những hàm tại 193Hwww.php.net/strings . Bạn có thể tìm những hàm có 

ích khác trong trang web này. 

  Những mệnh đề tiếp theo chứa 2 điều kiện. Một là những biểu thức chung nhƣ ( [ 

0-9 ] { 2 } )-( [ 0-9 ]{ 2 } )-( [ 0-9 ] { 4 } ). Điều này bạn kiểm tra những số trong khoảng 

từ 0 đến 9 với 2 biến cố. Ví dụ: nếu không là 2. Nếu [ 0-9] { 4 } chỉ khác nhau ở chổ là 

có 4 ký số trong số, xác định phần năm trong ngày.( hai phần đầu là ngày và tháng) 

Vì thế, trong Tiếng Anh có nghĩa là “Tôi muốn chuỗi bắt đầu với một số hai ký số, 

đi theo bởi một dấu nối và sau đó nhóm với 2 ký số, rồi đến dấu nối,và cuối cùng  nhóm 

với 4 ký số.” 

if (!ereg(“([0-9]{2})-([0-9]{2})-([0-9]{4})”, 

$movie_release, 

$reldatepart) || empty( $movie_release )) 

 { 

... 

  Đây là xác định của biểu thức bình thƣờng. Nếu chuổi thỏa điều kiện của bạn, bạn 

sẽ chia 3 phần khác nhau, mỗi phần giới hạn bởi dấu ngoặc.  

  Việc cắt này đƣợc thực hiện bởi hàm ereg(). Nếu biến $movie_release thỏa với 

mẫu, ereg sẽ cắt chuỗi thành từng phần, lƣu trữ mỗi phần nhƣ từng phần tử của mảng 

$reldatepart. 

  Để đọc tài liệu PHP về những biểu thức bình thƣờng chúng ta tham khảo trang 

web 194Hwww.php.net/regex và hỏi ý kiến thầy để hiểu hơn về những biểu thức bình thƣờng. 

Nếu ngƣời dùng nhập 02-03-2004, sẽ đƣợc mảng nhƣ sau: 

Array 

[0] => 02-03-2004 

[1] => 02 

[2] => 03 

[3] => 2004 

  - 231 - 

Nhƣ bạn thấy, chỉ số đầu tiên giữ toàn bộ chuỗi, những số còn lại lƣu giữ mỗi bộ 

phận của chuỗi, giới hạn bởi dấu ngoặc bên ngoài. 

Bây giờ bạn có ngày đƣợc định dạng dễ hiểu, bạn có thể chuyển nó thành thời gian 

tạm bằng việc sử dụng hàm mktime(), cho phép bạn tạo ra thời gian tạm từ những phần 

ngày, tháng. Nó cũng là một hàm rất có ích cho việc vận dụng ngày. 

$movie_release = mktime(0, 0, 0, $reldatepart[„2‟], 

$reldatepart[„1‟], 

$reldatepart[„3‟]); 

  Mã này lƣu giữ thời gian tạm từ thông tin ngày, tháng, năm đến hệ thống bên 

trong biến $movie_release. Định dạng này là int mktime(int hour, int minute, int second, 

int month, int day, int year). Giá trị trả về là số giây giữa January 1, 1970 và ngày chỉ 

định. 

  Nếu mktime thất bại khi tạo thời gian tạm từ ngày, tháng bạn cho, nó sẽ trả về -1. 

Điều này xảy ra khi nhập sai , mặc dù nó phù hợp với biều thức bình thƣờng ví dụ nhƣ:99 

-99 9999 sẽ qua sự kiểm tra của biểu thức bình thƣờng nhƣng đây không là ngày tháng 

hợp lệ. Để chắc rằng  phải là ngày hợp lệ, bạn kiểm tra giá trị trả về từ mktime và trả lời 

tƣơng ứng  

if ($movie_release == „-1‟) 

 { 

$error .= “Please+enter+a+real+date+” . 

“with+the+dd-mm-yyyy+format%21%0D%0A”; 

  Trong trƣờng hợp này, một ngày không hợp lệ sẽ đƣa ra một lỗi hỏi về ngày tháng 

hợp lệ. Ở đây có một kỷ xảo khác: bạn có thể thi hành thời gian tạm sử dụng SQL. Nhiều 

thứ mà PHP thao tác trực tiếp từ SQL, nhƣ: 

if (!ereg(“([0-9]{2})-([0-9]{2})-([0-9]{4})”, 

$movie_release, 

$reldatepart) || empty($movie_release))  

... 

  - 232 - 

$reldate = $reldatepart[„3‟] . “-” . 

$reldatepart[„2‟] . “-” . 

$reldatepart[„1‟] . “ 00:00:00”; 

$sql = “INSERT INTO movie (movie_release) “ . 

“VALUES (UNIX_TIMESTAMP(„$reldate‟))”; 

  Trong đoạn mã này, SQL phát sinh thời gian tạm. Hàm UNIX_TIMESTAMP() 

SQL định dạng YYYY-MM-DD HH:MM:SS (2004-12-05 02:05:00) và tạo thời gia tạm 

từ đó. Trong mã, bạn cắt buộc tạo thời gian tạm tại thời điểm 00:00 

8.5.  Tóm tại 

Việc làm cho ngƣời dùng khi nhập vào có hiệu lực là ta sẵn sàng xử lý những lỗi 

gặp phải, những lỗi đó có thể cố ý hoặc vô tình, nó xảy ra hằng ngày. Những biểu thức 

bình thƣờng giúp bạn rất nhiều 

  - 233 - 

Chƣơng  9:  ĐIỀU KHIỂN VÀ TRÁNH NHỮNG LỖI 

Sau khi viết mã lệnh, ngƣời mới lập trình sẽ gặp không ít khó khăn trong việc tìm 

ra lỗi và chỉnh sửa lỗi. PHP hỗ trợ đầy đủ tính năng lập trình giao diện API (Applications 

Programming  Interface)  có thể tìm ra lỗi  và khắc phục  những lỗi ấy. Ngoài PHP thì 

Apache Web Server cũng hỗ trợ ngƣời lập trình tìm ra lỗi và khắc phục lỗi. 

9.1.  Tiếp xúc với lỗi Apache Web Server nhƣ thế nào? 

Apache có một thƣ mục Lỗi tài liệu, bạn có thể định cấu hình trong file httpd.conf 

để tạo ra những trang thông báo lỗi với PHP, vì thế ngƣời thăm trang web không thấy 

buồn chán. PHP tạo ra trang web thông báo lỗi thân thiện cho ngƣời dùng. 

Không giống những trang thông báo lỗi nhƣ PHP, trang của Apache đƣợc sử dụng 

nhiều cho những trang đã mất. 

9.1.1.  Chỉ thị lỗi của Apache 

Ví dụ về việc sử dụng phƣơng pháp Apache. 

Trƣớc hết cần thay đổi trong thƣ mục httpd.conf để cho phép tạo ra một trang thông 

báo lỗi, Apache thƣờng đƣợc mặc định bên trong những trang lỗi. Nhƣng bạn muốn có 

một thông báo nhƣ ý muốn khi có lỗi xuất hiện. 

Bạn cần có những thay đổi sau: 

1. Mở file httpd.conf, những dòng 750 hoặc xa hơn, tìm vài dòng giống nhƣ sau: 

# Customizable error responses come in three flavors: 

# 1) plain text 2) local redirects 3) external redirects 

# Some examples: 

#ErrorDocument 500 “The server made a boo boo.” 

#ErrorDocument 404 /missing.html 

#ErrorDocument 404 “/cgi-bin/missing_handler.pl” 

#ErrorDocument 402 195Hhttp://www.example.com/subscription_info.html 

2. Thay đổi thông tin cho phép  sau đó khởi động lại Apache 

# Customizable error responses come in three flavors: 

  - 234 - 

# 1) plain text 2) local redirects 3) external redirects 

# Some examples: 

ErrorDocument 400 /error.php?400 

ErrorDocument 401 /error.php?401 

ErrorDocument 403 /error.php?403 

ErrorDocument 404 /error.php?404 

1ErrorDocument 500 /error.php?500 

Nó hoạt động thế nào? 

Bạn vừa soạn thảo cấu hình Apache để  giúp bạn thi hành lỗi, bạn có thể gởi đến 

ngƣời dùng những trang lỗi phụ thuộc vào những lỗi mà ngƣời dùng gặp phải 

Có nhiều lỗi trong tài liệu nhƣng chúng ta sẽ tập trung vào lỗi mà thƣờng gặp hằng 

ngày. 

❑ 400: Lời thỉnh cầu không tốt 

❑ 401:Yêu cầu đƣợc cho phép 

❑ 403: Không đƣợc phép 

❑ 404: Không tìm thấy 

❑ 500: Lỗi từ server 

Ví dụ: Hiển thị lỗi 

Để hiển thị thông báo lỗi, bạn làm những bƣớc sau: 

1.Mở trình duyệt và lƣu với tên error.php 

2. Nhập những dòng sau: 

<?php 

$error_no = $_SERVER[„QUERY_STRING‟]; 

switch ($error_no) 

 { 

case 400: 

$error_output  =  “<h1>&quot;Bad  Request&quot; 

Error Page - “ . 

  - 235 - 

“(Error Code 400)</h1>”; 

$error_output  .=  “The  browser  has  made  a  Bad 

Request<br>”; 

$error_output  .=  “<a 

href=\”mailto:[email protected]\”>” . 

“Contact</a> the system administrator”; 

$error_output .= “ if you feel this to be in error”; 

break; 

case 401: 

$error_output  =  “<h1>&quot;Authorization 

Required&quot; “ . 

“Error Page - (Error Code 401)</h1>”; 

$error_output  .=  “You  have  supplied  the  wrong 

information to “ . 

“access a secure area<br>”; 

$error_output  .=  “<a 

href=\”mailto:[email protected]\”>” . 

 “Contact</a> the system administrator”; 

$error_output .= “ if you feel this to be in error”; 

break; 

case 403: 

$error_output = “<h1>&quot;Forbidden Access&quot; 

Error Page - “ . 

“(Error Code 403)</h1>”; 

$error_output  .=  “You  are  denied  access  to  this 

area<br>”; 

$error_output  .=  “<a 

href=\”mailto:[email protected]\”>” . 

“Contact</a> the system administrator”; 

$error_output .= “ if you feel this to be in error”; 

break; 

  - 236 - 

case 404: 

$error_output  =  “<h1>&quot;Page  Not  Found&quot; 

Error Page - “ . 

“(Error Code 404)</h1>”; 

$error_output .= “The page you are looking for cannot 

“ . 

“be found<br>”; 

$error_output  .=  “<a 

href=\”mailto:[email protected]\”>” . 

“Contact</a> the system administrator”; 

$error_output .= “ if you feel this to be in error”; 

break; 

case 500: 

$error_output  =  “<h1>&quot;Internal  Server 

Error&quot; “ . 

“Error Page – (Error Code 500)</h1>”; 

$error_output  .=  “The  server  has  encountered  an 

internal “ . 

“error<br>”; 

$error_output  .=  “<a 

href=\”mailto:[email protected]\”>” . 

“Contact</a> the system administrator”; 

$error_output .= “ if you feel this to be in error”; 

break; 

default: 

$error_output = “<h1>Error Page</h1>”; 

$error_output .= “This is the custom error Page<br>”; 

$error_output  .=  “You  should  be  <a 

href=\”index.php\”>here</a>”; 

?> 

  - 237 - 

<html> 

<head> 

<title>Beginning PHP5, Apache, MySQL Web Development</title> 

</head> 

<body> 

<?php 

echo $error_output; 

?> 

</body> 

</html> 

3.Mở trình duyệt và vào 196Hhttp://localhost/asdf/qwerty/page.html  hoặc bất kỳ trang web 

nào mà bạn biết là không thể vào thăm trang web, bạn sẽ nhìn thấy nhƣ hình 9.1  

Hình 9-1 

3.  Cách khác để kiểm tra rằng đoạn mã của bạn đƣợc ứng dụng vào 

trong trang web với chuỗi thông tin truy vấn cho ngƣời dùng. Ví 

dụ mở trình duyệt với tên 197Hhttp://localhost/error.php?500 , trang sẽ 

sử dụng truy vấn và chạy đoạn mã nếu có lỗi nó sẽ xuất hiện nhƣ 

hình sau ( giống hình trƣớc). 

  - 238 - 

Hình 9.2 

Nó hoạt động thế nào? 

Bạn vừa tạo ra những thông báo lỗi thƣờng gặp, bằng việc sử dụng switch(), bạn có thể 

hiển thị thích hợp những thông báo lỗi cần thiết cho ngƣời dùng. 

9.1.2.  Lỗi tài liệu của Apache: Trang báo lỗi thông thƣờng 

Bạn chỉ cho ngƣời dùng nhìn thấy những lỗi thông thƣờng, mặc dù bạn có thể làm 

nhiều hơn thế, đây là cách tốt để bạn theo dõi những trang mà bạn không thể kiểm tra 

định kỳ đƣợc.  

Ví dụ tạo một E_mail lỗi 

Trong bài tập này, bạn tạo ra một email phát sinh tự động gởi đến ngƣời quản trị 

thời gian xuất hiện lỗi, vào ngày nào, lỗi gì, trang nào phát sinh lỗi và thông báo lỗi nào 

đƣợc hiển thị cho ngƣời dùng định hƣớng. 

1. Mở file error.php, thay đổi nhƣ sau: 

2. Nhập vào đoạn mã sau: 

<?php 

function email_admin($error_no, 

$error_output, 

$full_date, 

$full_time, 

$request_page)  

$to = “Administrator <[email protected]>”; 

  - 239 - 

$subject = “Apache Error Generation”; 

$body = “<html>”; 

$body .= “<head>”; 

$body .= “<title>Apache Error</title>”; 

$body .= “</head>”; 

$body .= “<body>”; 

$body .= “Error occurred on <b>” . $full_date . “</b> “ . 

“at <b>” . $full_time . “</b><br>”; 

$body  .=  “Error  received  was  a  <b>”  .  $error_no  .  “</b> 

error.<br>”; 

$body .= “The page that generated the error was: <b>” . 

$request_page . “</b><br>”; 

$body .= “The generated error message was:” . $error_output; 

$body .= “</body>”; 

$body .= “</html>”; 

$headers = “MIME-Version: 1.0

”; 

$headers .= “Content-type: text/html; charset=iso-8859-1

”; 

$headers .= “From: Apache Error <[email protected]>

”; 

$headers .= “Cc: [email protected]

”; 

mail($to, $subject, $body, $headers); 

$date = getdate(); 

$full_date = $date[„weekday‟] . “, “ . 

$date[„month‟] . “ “ . 

$date[„mday‟] . “, “ . 

$date[„year‟]; 

$full_time = $date[„hours‟] . “:” . 

$date[„minutes‟] . “:” . 

$date[„seconds‟] . “:” . 

$date[„year‟]; 

$error_no = $_SERVER[„QUERY_STRING‟]; 

  - 240 - 

$request_page = $_SERVER[„REQUEST_URI‟]; 

switch ($error_no)  

case 400: 

$error_output = “<h1>\”Bad Request\” Error Page - “ . 

“(Error Code 400)</h1>”; 

$error_output .= “The browser has made a Bad Request<br>”; 

$error_output .= “<a href=\”mailto:[email protected]\”>” . 

“Contact</a> the system administrator”; 

$error_output .= “ if you feel this to be in error”; 

email_admin($error_no, 

$error_output, 

$full_date, 

$full_time, 

$request_page); 

break; 

case 401: 

$error_output = “<h1>\”Authorization Required\” Error Page - “ . 

“(Error Code 401)</h1>”; 

$error_output .= “You have supplied the wrong information to “ . 

“access a secure area<br>”; 

$error_output .= “<a href=\”mailto:[email protected]\”>” . 

“Contact</a> the system administrator”; 

$error_output .= “ if you feel this to be in error”; 

email_admin($error_no, 

$error_output, 

$full_date, 

$full_time, 

$request_page); 

break; 

case 403: 

  - 241 - 

$error_output = “<h1>\”Forbidden Access\” Error Page - “ . 

“(Error Code 403)</h1>”; 

$error_output .= “You are denied access to this area<br>”; 

$error_output .= “<a href=\”mailto:[email protected]\”>” . 

“Contact</a> the system administrator”; 

$error_output .= “ if you feel this to be in error”; 

email_admin($error_no, 

$error_output, 

$full_date, 

$full_time, 

$request_page); 

break; 

case 404: 

$error_output = “<h1>\”Page Not Found\” Error Page - “ . 

“(Error Code 404)</h1>”; 

$error_output .= “The page you are looking for “ . 

“cannot be found<br>”; 

$error_output .= “<a href=\”mailto:[email protected]\”>” . 

“Contact</a> the system administrator”; 

$error_output .= “ if you feel this to be in error”; 

email_admin($error_no, 

$error_output, 

$full_date, 

$full_time, 

$request_page); 

break; 

case 500: 

$error_output = “<h1>\”Internal Server Error\” Error Page - “ . 

“(Error Code 500)</h1>”; 

$error_output .= “The server has encountered “ . 

“an internal error<br>”; 

  - 242 - 

$error_output .= “<a href=\”mailto:[email protected]\”>” . 

“Contact</a> the system administrator”; 

$error_output .= “ if you feel this to be in error”; 

email_admin($error_no, 

$error_output, 

$full_date, 

$full_time, 

$request_page); 

break; 

default: 

$error_output = “<h1>Error Page</h1>”; 

$error_output .= “This is the custom error Page<br>”; 

$error_output .= “You should be <a href=\”index.php\”>here</a>”; 

?> 

<html> 

<head> 

<title>Beginning PHP5, Apache, MySQL Web Development</title> 

</head> 

<body> 

<?php 

echo $error_output; 

?> 

</body> 

</html> 

Nó hoạt động thế nào? 

Hàm mail() đƣợc sử dụng để gởi email cho ngƣời quản trị, getdate() ghi nhớ thời 

gian và ngày xuất hiện lỗi. Hàm mail() cho phép bạn gởi mail đến bất cứ ai khi xuất hiện 

lỗi. 

  - 243 - 

9.2.  Thi hành lỗi và tạo ra việc sửa trang lỗi với PHP 

Phụ thuộc vào kiểu lỗi xuất hiện mà đƣa ra những thông báo lỗi thích hợp, phải 

đƣa ra những lỗi để ngƣời nhận  thông báo lỗi cảm thấy dễ chịu, không cảm thấy xấu hổ 

và có hƣớng giải quyết lỗi tốt. 

9.2.1.  Các loại lỗi trong PHP 

Có 12 kiểu lỗi trong PHP, đƣợc liệt kê dƣới đây 

Lỗi  Giá trị nguyên  Tên hằng 

E_ERROR 

1  Lỗi nặng 

E_WARNING 

2  Lỗi nhẹ(cảnh báo) 

E_PARSE 

4  Thời gian biên dịch lỗi 

E_NOTICE 

8  Chú ý 

E_CORE_ERROR 

16  Lỗi  nặng  xuất  hiện  lúc 

khởi động 

E_CORE_WARNINGS 

32  Lỗi  không nặng ngay lúc 

khởi động 

E_COMPILE_WARNING 

128  Lỗi  thời  gian  biên  dịch 

không nặng lắm(cảnh báo) 

E_USER_ERROR 

256  Lỗi phát sinh ngƣời dùng 

bởi  hàm  PHP 

trigger_error() 

  - 244 - 

E_USER_WARNING 

512  Cảnh báo ngƣời dùng khi 

dùng hàm trigger_error() 

E_USER_NOTICE 

1024 

Chú  ý  khi  dùng  hàm 

trigger_error() 

E_ALL 

2047  Tất cả những lỗi và cảnh 

báo  

E_STRICT 

2048  Chú  ý  để  thời  gian  thực 

hiện cần có thay đổi tƣơng 

thích 

  Bạn  không phải  lo  lắng  về  lỗi  đánh  máy,  hãy  quan  tâm  đến  những  cảnh  báo, 

những lỗi mà bạn gặp phải, để có sự giải quyết kịp thời, dễ sử dụng hơn cho ngƣời dùng. 

Ở đây có 3 loại lỗi chính  

Fatal  error:  Lỗi nặng  khi thực hiện, thông báo lỗi không thể sửa đổi, thực hiện theo 

ngyuên  bản 

Warning: Cảnh báo, không đƣợc dùng tập lệnh vừa rồi. 

Notices: Chú ý, khi chạy vẫn đúng nhƣng có một lỗi nhỏ. 

9.2.2.  Việc phát sinh lỗi PHP 

Chúng ta tạo vài lỗi để có thể kiểm tra cần giải quyết thế nào?Nhƣ ví dụ sau: 

<?php 

//set string with “Wrox” spelled wrong 

$string_variable = “Worx books are great!”; 

//try to use str_replace to replace Worx with Wrox 

//this will generate an E_WARNING 

//because of wrong parameter count 

str_replace(“Worx”, “Wrox”); 

?> 

Nếu bạn chạy đoạn mã này, bạn sẽ thấy lỗi nhƣ sau: 

Warning: Wrong parameter count for str_replace() in 

  - 245 - 

C:\FoxServ\www\errorhandling\error1.php on line 8 

Lỗi này xuất hiện vì hàm str_replace yêu cầu tham số thứ 3 cho hàm. Tham số này là 

biến, $string_variable hoặc chuỗi văn bản mà bạn muốn nghiên cứu cho tham số thứ 

nhất, “Worx” và thay thế nó với “Worx”. Bởi điều này không tạo ra lỗi lớn mà không thi 

hành tập lệnh,  bạn có thể vẫn chạy đoạn code sau khi lỗi xuất hiện, nếu bạn làm nhƣ sau: 

<?php 

//set string with “Wrox” spelled wrong 

$string_variable = “Worx books are great!”; 

//try to use str_replace to replace Worx with Wrox 

//this will generate an E_WARNING 

//because of wrong parameter count 

str_replace(“Worx”, “Wrox”); 

//this is a non-fatal error, so the original 

//variable should still show up after the warning 

echo $string_variable; 

?> 

Chuỗi vẫn tiếp tục đƣợc thi hành sau lỗi, nó sẽ sinh ra nhƣ sau: 

Warning: Wrong parameter count for str_replace() in 

c:\FoxServ\www\errorhandling\error1.php on line 8 

Worx books are great! 

Kế đến, chúng ta sẽ đƣa ra những lỗi nặng để cho bạn thấy nó sinh ra những kết 

quả khác nhau khi lỗi xuất hiện nhƣ thế nào. 

<?php 

//beginning of page 

echo “Beginning”; 

//we are going to make a call to 

//a function that doesn‟t exist 

//this will generate an E_ERROR 

//and will halt script execution 

//after the call of the function 

  - 246 - 

fatalerror(); 

//end of page 

echo “End”; 

//won‟t be output due to the fatal error 

?> 

Sẽ xuất hiện nhƣ sau: 

Beginning 

Fatal error: Call to undefined function: fatalerror() in 

c:\FoxServ\www\errorhandling\error2.php on line 10. 

Chú ý là “Beginning” đƣợc đƣa ra vì hàm trƣớc nó đƣợc gọi, nhƣng “End” thì 

không đƣa ra vì lỗi thực hiện quá lớn. Bạn có thể ngăn lỗi lại bằng việc dùng một ký hiệu 

nhƣ sau: @fatalerror (ngăn chặn lỗi nhƣng vẫn gặp lỗi khi thi hành) 

Khi PHP mặc định lỗi không thấy E_NOTICE xuất hiện, tuy nhiên bạn có thể cho 

phép  ngƣời dùng gỡ những lỗi nhƣ khi dùng $row[variable] vì PHP coi [variable] nhƣ 

một hằng, nếu không là hằng nó giả thiết là chuỗi trong mảng. Có thể đƣa ra thông báo 

lỗi khi dùng error_reporting(number) mà số không thay đổi. 

Nếu  bạn  không  biết  cấp  độ  lỗi  đƣợc  thiết  lập,  bạn  có  thể  chạy  hàm 

error_reporting() đơn giản với bất kỳ chủ đề nào: 

<?php 

echo error_reporting(); 

?> 

  Mặc định, tất cả những việc thi hành lỗi đƣợc điều khiển bời ngƣời xây dựng nên 

lỗi, cho bạn những thông báo về liểu lỗi, tên file, số dòng lỗi xuất hiện 

  Bạn chú ý một lỗi nhƣ sau: 

Warning: Wrong parameter count for str_replace() in 

c:\FoxServ\www\errorhandling\error1.php on line 8 

  Thông thƣờng việc phát sinh lỗi thì tốt vì có thể thông báo cho ngƣời quản trị biết 

là anh ta có thể biết nhiều hơn từ những lỗi ấy. 

  Ví dụ về việc một ngƣời tạo lỗi thông thƣờng 

  Bạn sẽ tạo một lỗi thông thƣờng  nhƣng thân thiện với ngƣời dùng và hiển thị nhƣ 

sau: 

  - 247 - 

1. Trình soạn thảo trong ví dụ trƣớc nhƣ sau: 

<?php 

//create your error handler function 

function handler($error_type, 

$error_message, 

$error_file, 

$error_line)  

echo “<h1>Page Error</h1>”; 

echo  “Errors  have  occurred  while  executing  this  page. 

Contact the “; 

echo  “<a 

href=\”mailto:[email protected]\”>administrator</a> 

“ . 

“to report errors<br><br>”; 

echo “<b>Information Generated</b><br><br>”; 

echo “<b>Error Type:</b> $error_type<br>”; 

echo “<b>Error Message:</b> $error_message<br>”; 

echo “<b>Error Filename:</b> $error_file<br>”; 

echo “<b>Error Line:</b> $error_line”; 

//set the error handler to be used 

set_error_handler(“handler”); 

//set string with “Wrox” spelled wrong 

$string_variable = “Worx books are great!”; 

//try to use str_replace to replace Worx with Wrox 

//this will generate an E_WARNING 

//because of wrong parameter count 

str_replace(“Worx”, “Wrox”); 

?> 

2. Lƣu file với tên custom_error.php và mở trình duyệt, bạn sẽ thấy nhƣ  

  - 248 - 

Hình 9.3 

3. Vì lỗi của bạn là do ngƣời dùng định nghĩa, bạn có thể bắt lỗi và có thể tạo lại thông 

báo lỗi dựa vào kiểu lỗi. Tạo file custom_error.php để sắp xếp những lỗi nhƣ sau: 

<?php 

//create your error handler function 

function handler($error_type, 

$error_message, 

$error_file, 

$error_line)  

switch ($error_type)  

//fatal error 

case E_ERROR: 

echo “<h1>Fatal Error</h1>”; 

die(“A fatal error has occured at line $error_line of file 

“ . 

“$error_file.<br>” . 

“Error  message  created  was 

&quot;$error_message&quot;”); 

break; 

//warnings 

case E_WARNING: 

  - 249 - 

echo “<h1>Warning</h1>”; 

echo “A warning has occured at line $error_line of file 

“ . 

“$error_file.<br>”; 

echo  “  Error  message  created  was 

&quot;$error_message&quot;”; 

//notices 

case E_NOTICE: 

//don‟t show notice errors 

break; 

//set the error handler to be used 

set_error_handler(“handler”); 

//set string with “Wrox” spelled wrong 

$string_variable = “Worx books are great!”; 

//try to use str_replace to replace Worx with Wrox 

//this will generate an E_WARNING 

//because of wrong parameter count 

str_replace(“Worx”, “Wrox”); 

?> 

  4. Lƣu file và đƣa lên trình duyệt. Kết quả nhƣ Hình  9.4. E_ERROR đƣợc gọi 

trong mệnh đề switch có thể sử dụng bất kỳ loại lỗi nào và thực hiện những hoạt động 

khác nhau tùy theo lỗi.  

  - 250 - 

      Hình 9.4. 

Nó hoạt động thế nào? 

Tạo ra thông báo lỗi cho bạn điều khiển đầy đủ những trang web của bạn, bất chấp 

thành công hay thất bại khi thi hành. Bạn sẽ bắt lỗi, đƣa ra thông báo lỗi, hồ sơ thông báo 

lỗi và lỗi nào xuất hiện. Trang web mà bạn đƣa ra thông báo lỗi, trình bày hoặc gởi thông 

báo nhất định đến ngƣời dùng phụ thuộc vào lỗi mà ngƣời dùng mắc phải.  

Bạn đã tạo ra thông báo lỗi nhƣng không muốn ngƣời dùng nhìn thấy thông báo 

ấy, bạn có thể lịch sự xin lỗi ngƣời dùng hãy qua một trang khác vì trang này đang bị lỗi 

nhƣ thế ngƣời dùng không thấy lỗi của mình. Dùng phƣơng pháp email có thể cho ngƣời 

dùng không trực tiếp xem xét cơ sở dữ liệu mà là có bao nhiêu yêu cầu tới trang lỗi xuất 

hiện. 

Ví dụ về việc tạo một trang lỗi rõ ràng 

Trong bài này, bạn sẽ thiết lập việc thi hành một lỗi rõ ràng nhƣ bạn muốn. Bạn có 

thể tìm tất cả những lỗi mà không cần sử dụng những hƣớng dẫn có sẵn trong PHP 

1. Trình soạn thảo feature_error.php nhƣ sau: 

<?php 

//create your error handler function 

function handler($error_type, 

$error_message, 

$error_file, 

$error_line) { 

switch($error_type)  

  - 251 - 

//fatal error 

case E_ERROR: 

$to = “Administrator <[email protected]>”; 

$subject = “Custom Error Handling”; 

$body = “<html>”; 

$body .= “<head>”; 

$body .= “<title>Website error</title>”; 

$body .= “</head>”; 

$body .= “<body>”; 

$body .= “<h1>Fatal Error</h1>”; 

$body .= “Error received was a <b>” . $error_type . 

“</b> error.<br>”; 

$body .= “The page that generated the error was: <b>” . 

$error_file . “</b>”; 

$body .= “ and was generated on line: <b>” . $error_line . 

“</b><br>”; 

$body  .=  “The  generated  error  message  was:”  . 

$error_message; 

$body .= “</body>”; 

$body .= “</html>”; 

$headers = “MIME-Version: 1.0

”; 

$headers  .=  “Content-type:  text/html;  charset=iso-8859-1

”; 

$headers  .=  “From:  Apache  Error 

<[email protected]>

”; 

$headers .= “Cc: [email protected]

”; 

mail($to, $subject, $body, $headers); 

die(); //kill the script 

break; 

//warnings 

case E_WARNING: 

  - 252 - 

$to = “Administrator <[email protected]>”; 

$subject = “Custom Error Handling”; 

$body = “<html>”; 

$body .= “<head>”; 

$body .= “<title></title>”; 

$body .= “</head>”; 

$body .= “<body>”; 

$body .= “<h1>Warning</h1>”; 

$body .= “Error received was a <b>” . $error_type . 

“</b> error.<br>”; 

$body .= “The page that generated the error was: <b>” . 

$error_file . “</b>”; 

$body .= “ and was generated on line: <b>” . $error_line . 

“</b><br>”; 

$body  .=  “The  generated  error  message  was:”  . 

$error_message; 

$body .= “</body>”; 

$body .= “</html>”; 

$headers = “MIME-Version: 1.0

”; 

$headers  .=  “Content-type:  text/html;  charset=iso-8859-1

”; 

$headers  .=  “From:  Apache  Error 

<[email protected]>

”; 

$headers .= “Cc: [email protected]

”; 

mail($to, $subject, $body, $headers); 

break; 

//script will continue 

//notices 

case E_NOTICE: 

//don‟t show notice errors 

break; 

  - 253 - 

/* 

set error handling to 0 

we will handle all error reporting 

only notifying admin on warnings and fatal errors 

don‟t bother with notices as they are trivial errors 

really only meant for debugging 

*/ 

error_reporting(0); 

//set the error handler to be used 

set_error_handler(“handler”); 

/* 

Create the rest of your page here. 

We will not be displaying any errors 

We will be e-mailing the admin an error message 

Keep in mind that fatal errors will still halt the 

execution, but they will still notify the admin 

*/ 

?> 

  Nó hoạt động thế nào? 

 Với cách này đƣa ra thông báo đến ngƣời dùng những thông báo lỗi thông thƣờng 

nhƣng thân thiện đối với ngƣời dùng bằng cách dùng hàm email . 

Vì vậy, với cách đơn giản bạn chạy trang này và bạn nhận một lỗi, đôi khi đƣa ra  

thông tin có ích cho ngƣời dùng. 

9.3.  Một phƣơng pháp khác của việc thi hành lỗi 

Bạn vừa đƣa ra những thông báo lỗi thông thƣờng, có một phƣơng pháp khác tự 

nhiên hơn chèn mệnh đề echo để kiểm tra giá trị của biến và xem mệnh đề điều kiện  

đúng hay chƣa. PHP cũng cung cấp vài thông báo lỗi cho những lỗi đơn giản. 

  - 254 - 

9.3.1.  Những ngoại lệ 

PHP5 giới thiệu đặc tính mới gọi là những ngoại lệ. Những điều đó tƣơng tự nhƣ 

ngôn ngữ Java. Những điều kiện điều khiển ngọai lệ trong ứng dụng Web và cho bạn một 

cách hiệu quả để điều khiển những lỗi gặp phải. PHP5 sử dụng phƣơng pháp tìm kiếm, 

nắm bắt để điều khiển những ngoại lệ. 

Ví dụ về việc thử nghiệm với những ngoại lệ 

Trong bài này, bạn sẽ tạo một phiên bản đƣa ra vài ngoài lệ để thấy chúng làm việc 

thế nào 

1. Tạo một trang PHP với đoạn code sau: 

<?php 

//$x = “”; //Throws null Exception 

//$x = “500”; //Throws less than Exception 

$x = “1000”; //Throws NO Exception 

try  

if ($x == “”)  

throw new Exception(“Variable cannot be null”); 

if ($x < 1000)  

throw new Exception(“Variable cannot be less than 1000”); 

echo “Validation Accepted!”; 

catch (Exception $exception)  

echo $exception->getMessage(); 

echo “ - Validation Denied!”; 

?> 

  - 255 - 

2. Lƣu đoạn code với tên exceptions.php và chạy nó trong trình duyệt. Bạn không 

thấy bất cứ lỗi nào 

3. Thay $x= “1000” bằng $x= “” 

4. Lƣu file và chạy một lần nữa, bạn sẽ thấy một thông báo rỗng 

5. Thay $x= “” bằng $x= “500” 

6. Lƣu file lại và bạn sẽ thấy thông báo “less than 1000” 

Nó hoạt động thế nào? 

Sự hữu ích của khối này là tất cả những điều kiện phải gặp hoặc thấy. Đây là hữu 

ích khi bạn cần kiểm tra nhiều biến hay không muốn thông qua nhiều mệnh đề if/else cho 

việc tìm ra kết quả. Tất cả yêu cầu trong mệnh đề if mà đúng thì sẽ thực hiện, sẽ đƣa ra 

thông báo lỗi thích hợp phụ thuộc vào ngoại lệ gặp phải. 

Trong vùng thấy lỗi, bạn có thể thi hành lỗi trong bất cứ phƣơng pháp nào bạn 

thích. Bạn muốn gởi đến ngƣời dùng là bạn muốn thiết lập vài biến mặc định, kết nối cả 

hai hoặc bất cứ cái gì mà bạn cần.  

Hữu ích của việc sử dụng những ngoại lệ là cách chúng đƣa ra những hàm và 

code. Ví dụ, nếu bạn có một hàm gọi là hàm B mà bên trong thì gọi hàm C và một ngoại 

lệ trong hàm C thông qua việc sử dụng try{} , ngoại lệ sẽ dừng việc xử lý phiên bản  nếu 

khối đƣợc tìm thấy 

Nếu không tìm thấy try{}…catch{} khi thi hành code, lỗi sẽ xuất hiện trên màn 

hình để thông báo ngoại lệ đã xuất hiện. 

Ngoại lệ cũng có thể thông qua nhƣ sau: 

<?php 

try 

 { 

throw new Exception(“This will be rethrown”); 

catch (Exception $e)  

throw $e; 

?> 

  - 256 - 

9.3.2.  Không gặp những điều kiện 

Không phải trong bất cứ đoạn mã nào cũng gặp lỗi, nó chỉ xuất hiện khi liên quan 

đến PHP, bằng việc sử dụng vài phƣơng pháp khác nhau trong đoạn mã để kiểm tra lỗi 

xuất hiện. 

<input type=”submit” name=”submit” value=”Submit”> 

Bạn đang kiểm tra để thấy nút nhấn khi nào hoặc sẽ không thi hành thông tin khi 

nào. Bạn có thể làm điều này nhƣ sau: 

if ($_POST[„submit‟] == “submit”)  

//form has been submitted 

} else 

 { 

//form has not been submitted 

9.3.3.  Phân tích lỗi 

Phân  tích  lỗi  là  kiểu  lỗi  chính,  nó  xuất  hiện  khi  bạn  quên  một  dấu  chấm 

phẩy,…Những lỗi này  không làm  với  mệnh đề điều kiện, chúng là cú pháp chính là 

nguyên nhân dừng việc thực thi. Phân tích lỗi xấu hơn những lỗi nặng vì chúng không thể 

chạy tất cả những phiên bản, chúng cho bạn thông tin về lỗi. 

9.4.  Tóm lại. 

Bạn đọc đƣợc nhiều thứ trong chƣơng này, từ việc biết đƣợc những lỗi cho đến việc 

phòng ngừa những lỗi, giúp ngƣời lập trình làm thế nào để phòng ngừa lỗi, tìm ra lỗi. 

Bạn đang đọc truyện trên: AzTruyen.Top