PHP [8] là một ngôn ngữ lập trình kịch bản hay một loại mã lệnh chủ yếu được dùng để phát triển các ứng dụng viết cho máy chủ, mã nguồn mở, dùng cho mục đích tổng quát. Nó rất thích hợp với web và có thể dễ dàng nhúng vào trang HTML. Do được tối ưu hóa cho các ứng dụng web, tốc độ nhanh, nhỏ gọn, cú pháp giống C và Java, dễ học và thời gian xây dựng sản phẩm tương đối ngắn hơn so với các ngôn ngữ khác nên PHP đã nhanh chóng trở thành một ngôn ngữ lập trình web phổ biến nhất thế giới.
Đoạn mã sau minh họa giúp cách viết PHP lồng vào các trang HTML dễ dàng như thế nào: 1. <html> 2. <head> 3. <title>Mã mẫu</title> 4. </head> 5. <body> 6. <?php
7. echo "Hello world!";
8. ?>
9. </body> 10. </html>
Thẻ <?php và thẻ ?> sẽ đánh đấu sự bắt đầu và sự kết thúc của phần mã PHP qua đó máy chủ biết để xử lý và dịch mã cho đúng. Đây là một điểm khá tiện lợi của PHP giúp cho việc viết mã PHP trở nên khá trực quan và dễ dàng trong việc xây dựng phần giao diện ứng dụng HTTP.
PHP chỉ phân tích các đoạn mã nằm trong những dấu giới hạn của nó. Bất cứ mã nào nằm ngoài những dấu giới hạn đều được xuất ra trực tiếp không thông qua xử lý bởi PHP. Các dấu giới hạn thường dùng nhất là <?php và ?>, tương ứng với dấu giới hạn mở và đóng. Các dấu giới hạn <script language="php"> và </script> cũng đôi khi
được sử dụng. Cách viết dấu giới hạn dạng thẻ ngắn cũng có thể được dùng để thông báo bắt đầu đoạn mã PHP, là <? hay <?= (dấu này được sử dụng để in ra (echo) các xâu ký tự hay biến) với thẻ thông báo kết thúc đoạn mã PHP là ?>.
Các biến được xác định bằng cách thêm vào trước một dấu đô la ($) và không cần xác định trước kiểu dữ liệu. Không giống với tên hàm và lớp, tên biến là trường hợp nhạy cảm. Cả dấu ngoặc kép ("") và ký hiệu đánh dấu văn bản (‘’) đều có thể dùng để truyền xâu và giá trị biến. PHP coi xuống dòng như một khoảng trắng theo kiểu như một ngôn ngữ dạng tự do (free-form language) (trừ khi nó nằm trong trích dẫn xâu), và các phát biểu được kết thúc bởi một dấu chấm phẩy. PHP có ba kiểu cú pháp chú thích: /* */ cho phép một đoạn chú thích tùy ý, trong khi đó // và # cho phép chú thích trong phạm vi một dòng.
2.2.1.1. Biểu thức chính quy
Biểu thức chính quy (Regular Expressions hay Regex, [9]) là một chuỗi miêu tả một bộ các chuỗi khác, theo những quy tắc cú pháp nhất định, hoặc có thể hiểu đơn giản hơn là một mẫu (pattern) dùng để mô tả 1 lớp ký tự nào đó.
Áp dụng vào trong vấn đề thu thập thông tin, biểu thức chính quy đóng vai trò quan trọng trong việc bóc tách thông tin. Sử dụng thành thạo biểu thức chính quy ta có thể bóc tách được mọi thông tin trong một trang html.
Trong PHP, ta có thể sử dụng biểu thức regex thông qua các hàm regex. PHP cung cấp 3 nhóm hàm regex, tên của chúng dc bắt đầu bởi: ereg, mb_ereg và preg. 2 loại đầu sử dụng engine POSIX Extended, còn preg sử dụng engine PCRE (Perl- Compatible). Ở đây chúng ta chỉ cần tìm hiểu về nhóm preg. Một số hàm phổ biến trong nhóm preg là:
• Hàm preg_math : sử dụng khi muốn dùng một pattern để lấy ra một chuỗi trong một chuỗi khác.
- Cấu trúc hàm: <?php
$string = 'chuỗi cần áp dụng biểu thức regex'; $pattern = '/biểu thức regex/';
preg_match($pattern, $string, $match); ?>
Trong đó $match chính là kết quả khi ánh xạ $pattern vào $string. - Ví dụ :
$string = ‘LazyDog is not a dog’ $pattern = ‘dog’
Thì $match sẽ là ‘dog’. Vì biểu thức chính quy mặc định phân biệt chữ hoa và chữ thường.
• Hàm preg_replace : sử dụng khi muốn tìm kiếm và thay thế một chuỗi trong một chuỗi khác.
- Cấu trúc hàm: preg_match($pattern, ’’ , $string)
- Ví dụ : Để loại bỏ tất cả các ký tự không phải (a-z) và (A-Z) và số (0,9) ra khỏi chuỗi ta dùng hàm:
preg_replace('/[^a-z0-9]+/i','',$str);
Biểu thức chính quy bao gồm 11 ký tự / cặp ký tự mang ý nghĩa đặc biệt. Để giải phóng các ký tự / cặp ký tự đặc biệt ta dùng ký tự ’ \ ‘ đằng trước các ký tự đặc biệt. Sau đây là bảng các ký tự / cặp ký tự đặc biệt:
Ký tự / cặp ký tự Ý nghĩa Ví dụ Kết quả
{...} Bắt đầu vào kết thúc min, max ký tự a{1,3} a,aa,aaa [...] Bắt đầu và kết thúc một lớp ký tự [a-z] Tất cả các ký tự từ a đến z (...) Bắt đầu và kết thúc một so mẫu con \ Dùng để giải phóng các ký tự đặc biệt
^ Ký tự bắt đầu, nếu đặt trong lớp ký tự nó mang ý nghĩa phủ định [^a-z] Những ký tự không phải là a-z $ Ký tự kết thúc (.*)basic$ Chuỗi kết
thúc bằng basic . Bất kỳ ký tự nào trừ ký tự xuống dòng (.*) Lấy các ký tự trên 1 dòng
| Hoặc a(c|d)b Chuỗi acb
hoặc adb
? Có hoặc không ab?c Chuỗi abc
hoặc ac * Lặp nhiều lần hoặc không lặp a* <null>, a,
aa...
+ Lặp ít nhất một lần a+ a, aa, aaa, ...
Trên thực tế ngoài các ký tự có thể in được bình thường chúng ta còn có những ký tự không in được như tab, space, esc. Để giải quyết vấn đề này biểu thức chính quy sử dụng các tổ hợp ký tự đặc biệt để thể hiện các ký tự không in được. Sau đây là bảng các tổ hợp ký tự thông dụng được sử dụng trong biểu thức chính quy:
Tổ hợp phím Thể hiện cho ký tự \t Tab \n Xuống dòng \e Esc \s Space \d Lớp ký tự [0-9] \w Lớp ký tự [a-zA-Z]