intTypePromotion=1
zunia.vn Tuyển sinh 2024 dành cho Gen-Z zunia.vn zunia.vn
ADSENSE

PHP có thể làm gì, 9 thứ thú vị có thể làm với PHP

Chia sẻ: NIIT ICT Hà Nội | Ngày: | Loại File: PDF | Số trang:28

53
lượt xem
6
download
 
  Download Vui lòng tải xuống để xem tài liệu đầy đủ

PHP chủ yếu được sử dụng để làm các trang web động, nhưng có nhiều thứ thú vị hơn bạn có thể làm với PHP. Trong tài liệu này, bạn sẽ thấy 9 ví dụ thú vị về cách bạn có thể sử dụng PHP để lập trình bên cạnh việc làm các trang web động. PHP có thể được sử dụng làm nhiều thứ như tạo ứng dụng Real-time, tạo REST và Web Service, Theme Wordpress, Plugin...

Chủ đề:
Lưu

Nội dung Text: PHP có thể làm gì, 9 thứ thú vị có thể làm với PHP

  1. PHP Có thể Làm gì? 9 Thứ thú vị có thể làm với PHP PHP chủ yếu được sử dụng để làm các trang web động, nhưng có nhiều thứ thú vị hơn bạn có thể làm với PHP. Trong bài viết này, bạn sẽ thấy 9 ví dụ thú vị về cách bạn có thể sử dụng PHP để lập trình bên cạnh việc làm các trang web động. Chắc chắn bạn sẽ ngạc nhiên khi thấy PHP có thể được sử dụng làm nhiều thứ hay như thế. • Nhân tiện, nếu bạn thật sự muốn bắt đầu với PHP, Khóa học Lập trình Web với PHP trong 3 tháng là một cách giúp bạn nhanh chân hơn. Vậy bạn có thể làm gì với PHP? Hãy cùng tìm hiểu ngay bên dưới đây. Mục lục: 1. Tại sao nên sử dụng PHP? 2. PHP dùng để làm gì? 3. PHP có thể Xác thực thông tin người dùng (bao gồm xác minh hai bước) 4. PHP có thể thao tác với các CSDL dễ dàng 5. PHP có thể lập trình Backend 6. PHP có thể tạo ứng dụng Real-time 7. PHP có thể tạo Theme và Plugin WordPress 8. PHP có thể tạo REST và WEB Service 9. Tạo hệ thống chạy ngầm với PHP (PHP Daemon) 10. Tạo hình ảnh với PHP 11. PHP có thể tạo Kịch bản hệ thống 12. Kết luận
  2. 1. Tại sao nên sử dụng PHP? PHP là một ngôn ngữ kịch bản (Scripting Languages) hiện đại được sử dụng trong gần 80% trang web (Số liệu 20/09/2019), tăng từ 72% vào năm 2010. Tỷ lệ ngôn ngữ lập trình dùng cho Server-side (Nguồn W3Tech) Có nhiều lý do khác nhau tại sao PHP lại trở thành một ngôn ngữ lập trình web phổ biến như vậy, nhưng có 3 lý do chính sau: • PHP dễ học hơn nhiều ngôn ngữ khác
  3. • PHP thích hợp các trang web thiên về nội dung và hỗ trợ dữ liệu từ Backend • PHP cung cấp cho bạn một bộ công cụ hoàn chỉnh để bạn làm việc. Thực tế là PHP được rất sử dụng rộng rãi cũng có nghĩa là bạn có thể tìm kiếm hướng dẫn học tập, group, diễn đàn thảo luận rất dễ dàng. Vấn đề chính chống lại PHP là hiệu năng và hiệu suất tổng thể kém nhiều ngôn ngữ khác ở nhiều trường hợp. Chắc chắn, có thể bạn đã hy vọng PHP sẽ có hiệu suất cao như C hoặc C ++. Tuy nhiên, trừ khi bạn đang làm việc trên các hệ thống quan trọng, phức tạp, đồ sộ hoặc hệ thống nhúng trong đó hiệu suất là ưu tiên hàng đầu. Còn đa phần các trường hợp, hiệu suất của PHP đã là quá đủ. Hơn nữa, Ở phiên bản PHP7, PHP có hiệu suất rất tốt nếu so sánh với các ngôn ngữ tương tự. Và trên thực tế, PHP có thể nhanh hơn 382% so với Python, nhanh hơn 378% so với Perl và nhanh hơn 195% so với Ruby. (Bạn có thể xem thử nghiệm hiệu suất tại đây) 2. PHP sử dụng để làm gì?
  4. PHP có thể làm gì? PHP có thể làm nhiều loại nhiệm vụ khác nhau. Ví dụ: Hãy thử nghĩ rằng bạn cần triển khai một HTTP Backend hoặc REST Service. Trong trường hợp đó, bạn muốn sử dụng một ngôn ngữ: • Được hỗ trợ tốt bởi các máy chủ web được sử dụng nhiều nhất như Apache • Tích hợp hoàn hảo với các cơ sở dữ liệu SQL như MySQL • Có thể xử lý văn bản, chuỗi và dữ liệu số dễ dàng Trong trường hợp này, sử dụng PHP là hoàn hảo. Trên thực tế, PHP thường là lựa chọn đầu tiên cho các dự án như vậy. Thử xem biểu đồ sau:
  5. Ví dụ ứng dụng đo nhiệt độ bằng PHP Đây là một đồ thị HTML5 mà tôi đã tạo ra tại nơi làm việc. Nó hiển thị nhiệt độ không khí trong 24 giờ qua. Bản thân đồ thị được tạo ra với một thư viện canvas có tên là RGraph, nhưng các giá trị nhiệt độ thực tế được tính toán, lưu trữ và truy xuất bởi PHP. Nhưng làm thế nào để bạn biết dự án của bạn phù hợp với ngôn ngữ PHP? Đơn giản, bạn sẽ chỉ cần hỏi 3 câu hỏi sau: • Dự án của tôi sẽ sử dụng các thế mạnh và chức năng của PHP? • Tôi có thể chạy dự án này từ Web Server hoặc với trình thông dịch PHP Command line không? • Dự án này có đòi hỏi hiệu suất và hiệu quả rất cao? Nếu bạn trả lời "CÓ" cho hai câu hỏi đầu tiên và "KHÔNG" cho câu hỏi cuối cùng, thì PHP là một ứng cử viên hàng đầu.
  6. Bây giờ, lan man cũng đã đủ rồi. Đã đến lúc để xem một số ví dụ thực tế về những gì bạn có thể làm với PHP, bắt đầu với một thứ bạn chắc chắn bạn sẽ sử dụng: Xác thực thông tin người dùng. 3. PHP có thể Xác thực thông tin người dùng (bao gồm xác minh hai bước) Xác thực thông tin người dùng là một trong những nền tảng của bảo mật web. Nếu bạn đang xây dựng trang web có phần tài khoản người dùng, rất có thể bạn cần triển khai xác thực người dùng. Có rất nhiều kỹ thuật khác nhau mà bạn có thể sử dụng, từ xác thực tên người dùng / mật khẩu theo cách đơn giản đến việc xác minh hai bước (hoặc phức tạp hơn) Và đoán xem... Với PHP, bạn có thể thực hiện bất kỳ kỹ thuật nào trong số này. Xác thực tên người dùng và mật khẩu Thực hiện xác thực tên người dùng và mật khẩu dễ dàng như việc so sánh hai chuỗi. PHP có thể dễ dàng lưu trữ và truy xuất các cặp tên người dùng và mật khẩu trên cơ sở dữ liệu, sử dụng mã hóa cấp cao nhất mà không cần cố gắng gì nhiều. Vậy trong thực tế việc này có thể làm thế nào? Hãy xem các chức năng đăng nhập và add_account sau đây được của tôi:
  7. /* Xác thực Tên người dùng và mật Khẩu */ public function login($name, $password) { /* Kiểm tra độ dài của chuỗi */ if ((mb_strlen($name) < 3) || (mb_strlen($name) > 24)) { return TRUE; } if ((mb_strlen($password) < 3) || (mb_strlen($password ) > 24)) { return TRUE; } try { /* Đầu tiên, tìm kiếm username */ $sql = 'SELECT * FROM accounts WHERE (account_name = ?) AND (account_enabled = 1) AND ((account_expiry > NOW ()) OR (account_expiry < ?))'; $st = $this->db->prepare($sql, array(PDO::ATTR_CURS OR => PDO::CURSOR_FWDONLY));
  8. $st->execute(array($name, '2000-01-01')); $res = $st->fetch(PDO::FETCH_ASSOC); /* Nếu username tồn tại được kết nối, tiếp tục kiểm tra password */ if (password_verify($password, $res['account_passwo rd'])) { /* Log in ok, we retrieve the account data */ $this->account_id = $res['account_id']; $this->account_name = $res['account_name']; $this->is_authenticated = TRUE; $this->expiry_date = $res['account_expiry']; $this->session_start_time = time(); /* Bây giờ chúng ta tạo Cookie và gửi nó đến trì nh duyệt của người dùng*/ $this->create_session(); } } catch (PDOException $e) { /* Ngoại lệ (SQL error) */
  9. echo $e->getMessage(); return FALSE; } /* Nếu không có ngoại lệ xảy ra, return true */ return TRUE; } /* Thêm một tài khoản mới */ public static function add_account($username, $password, &$db) { /* First we check the strings' length */ if ((mb_strlen($username) < 3) || (mb_strlen($username ) > 24)) { return TRUE; } if ((mb_strlen($password) < 3) || (mb_strlen($password ) > 24)) {
  10. return TRUE; } /* Băm mật khẩu */ $hash = password_hash($password, PASSWORD_DEFAULT); try { /* Thêm tài khoản mới trên Database (Nên kiểm tra t ên người dùng đã tồn tại hay chưa) */ $sql = 'INSERT INTO accounts (account_name, account _password, account_enabled, account_expiry) VALUES (?, ?, ?, ?)'; $st = $db->prepare($sql); $st->execute(array($username, $hash, '1', '1999-01- 01')); } catch (PDOException $e) { /* Ngoại lệ (SQL error) */ echo $e->getMessage(); return FALSE; }
  11. /* Nếu không có ngoại lệ xảy ra, return true */ return TRUE; } Xác thực Cookie và Xử lý Session Web Cookie là tiêu chuẩn thực tế để duy trì các phiên đăng nhập mở. Bạn có thể xử lý các phiên đăng nhập dựa trên cookie rất dễ dàng bằng cách sử dụng PHP Session. Nhờ có PHP Session, bạn không cần phải suy nghĩ gì về chi tiết các cookie: Chỉ cần Start và Close Session là bạn đã hoàn thành. Note: Không có gì có thể dễ hơn đâu. Nếu bạn muốn, bạn cũng có thể tự mình quản lý cookie để xây dựng các ứng dụng an toàn hơn bằng xác minh 2 bước Xác minh 2 bước với PHP Xác minh hai bước là hình thức xác minh thường được sử dụng trên các website hiện đại ngày nay. Đây là những gì sẽ xảy ra: Sau khi đăng nhập bằng tên người dùng và mật khẩu của bạn, trang web sẽ yêu cầu bạn nhập mã khác (hoặc mã thông báo). Đó có thể là mã được tạo bởi ứng dụng di động, tin nhắn văn bản được gửi đến điện thoại di động của bạn hoặc mã thông báo được gửi đến email của bạn. Còn có một số dịch vụ sử dụng thậm chí nhiều hơn hai bước. Ví dụ, các trang web ngân hàng thường gửi mã thông báo đến điện thoại di
  12. động của bạn và một số khác vào email của bạn để tăng tính bảo mật. Điểm mấu chốt là: Với PHP, bạn có thể triển khai bất kỳ loại hệ thống xác thực hai bước nào (thậm chí nhiều hơn). Trên thực tế, PHP hoàn toàn có khả năng: • Tạo mã thông báo ngẫu nhiên, an toàn và lưu trữ trên cơ sở dữ liệu • Gửi mã thông báo đến hộp thư đến của bạn bằng PHPMailer • Kết nối với nhà cung cấp dịch vụ SMS API API để gửi mã thông báo dưới dạng tin nhắn SMS • Bạn muốn xem việc tạo mã thông báo ngẫu nhiên dễ dàng như thế nào, lưu trữ nó trên cơ sở dữ liệu và gửi nó đến hộp thư đến của người dùng? Đây là mã ví dụ xác minh 2 bước:
  13. */ /* Tạo token ngẫu nhiên gồm 6 chữ số */ $token = random_int(100000, 999999); /* Chuyển token thành chuỗi */ $token = strval($token); /* Tạo một hàng database với token. /* Query: */ $query = 'INSERT INTO user_tokens (user_id, token_timesta mp, token_value) VALUES (?, NOW(), ?)'; /* Mảng giá trị: */ $values = array($user_id, $token); try { /* Thực hiện truy vấn SQL */ $result = $PDO->prepare($query, array(PDO::ATTR_CURSOR => PDO::CURSOR_FWDONLY)); $result->execute($values);
  14. } catch (PDOException $e) { /* Nếu có lỗi, 1 ngoại lệ được ném ra */ echo 'PDO exception. Error message: "' . $e->getMessag e() . '". Error code: ' . strval($e->getCode()) . '.'; die(); } /* Gửi tin nhắn cho người dùng với token */ try { /* Thiết lập người gửi thư. */ $PHPMailer->setFrom('noreply@yoursite.com'); /* Đặt email của người dùng làm người nhận. */ $PHPMailer->addAddress($user_email); /* Thiết lập tiêu đề. */ $PHPMailer->Subject = 'Access Token'; /* Thiết lập nội dung tin nhắn. */
  15. $PHPMailer->Body = 'Vui lòng sử dụng mã sau để đăng nh ập: ' . $token; /* Gửi thư. */ $PHPMailer->send(); } catch (Exception $e) { /* PHPMailer exception. */ echo $e->errorMessage(); die(); } 4. PHP có thể thao tác với các CSDL dễ dàng PHP hỗ trợ cơ sở dữ liệu ngay từ những ngày đầu. Danh sách các hệ thống cơ sở dữ liệu được hỗ trợ là: • MySQL • PostgreSQL • Berkeley DB (Rất phù hợp cho quản trị hệ thống) • Oracle • Microsoft SQL Server • SQLite • … Với PHP, bạn cũng có thể sử dụng cơ sở dữ liệu NoQuery như MongoDB.
  16. Còn bảo mật với PHP thì sao? Đừng lo lắng quá về vấn đề bảo mật nếu bạn không làm trong ngành tài chính, tiền tệ... Với cấp độ thông thường, PHP giúp dễ dàng thực hiện các câu lệnh SQL an toàn bằng cách sử dụng các câu lệnh escaping và prepared. Đối với các kịch bản phổ biến sử dụng MySQL tiêu chuẩn, tiện ích mở rộng PDO rất phù hợp để xây dựng mã SQL an toàn và mạnh mẽ. Đoạn mã dưới đây cho bạn thấy cách bạn có thể làm điều đó với tiện ích mở rộng PDO.
  17. $PDO->setAttribute(PDO::ATTR_CASE, PDO::CASE_NATURAL); } catch (PDOException $e) { /* Nếu xảy ra lỗi, một ngoại lệ sẽ được ném ra */ pdo_exception($e); } 5. PHP có thể lập trình Backend Ngày nay, lập trình Website là về sự kết hợp giữa các công nghệ frontend và backend. Các ứng dụng Frontend có thể rất đơn giản, như các trang web động cơ bản với các hàm JavaScript và AJAX đơn giản hoặc các trang web web phức tạp được xây dựng với các Framework và thư viện như JQuery, Node.JS, Angular, v.v. Bất kể ngôn ngữ hoặc thư viện nào frontend nào được tạo ra đều cần lấy một số dữ liệu từ phía Backend. Server Backend cũng có thể được tạo ra sử dụng công nghệ khác nhau. Python, Perl, Java, và thậm chí C hay C++ đều có thể được sử dụng cùng với HTTP Server để cung cấp dữ liệu từ Backend cho ứng dụng Frontend. Nhưng, ngôn ngữ được sử dụng nhiều nhất tính đến thời điểm hiện tại là PHP, bởi vì PHP đã được tạo ra để nhắm thẳng đến mục đích này. Ví dụ, Nhiều ứng dụng Frontend sử dụng định dạng JSON để giao tiếp với Backend Server.
  18. Để sử dụng PHP cung cấp dữ liệu ở định dạng này rất dễ dàng và đơn giản. Hãy xem cách đọc một số dữ liệu người dùng từ cơ sở dữ liệu và sau đó trả về ở định dạng JSON qua ví dụ sau:
  19. 'address' => $res['user_address'], 'birthday' => $res['user_birthday']); } /* Tạo và xuất ra JSON string */ $json = json_encode($users); echo $json; 6. PHP có thể tạo ứng dụng Real-time Các ứng dụng Web Real-time (thời gian thực) bao gồm chats, hệ thống giám sát, bot, mạng xã hội, web game và v.v. Bạn có thể xây dựng các ứng dụng như vậy bằng các công nghệ khác nhau, đáng chú ý là sử dụng MEAN stack bao gồm Node.JS, Express và Angular.JS. Các Framework dựa trên WebSocket như Socket.IO cũng rất mạnh mẽ và được sử dụng rộng rãi ngày nay. Một số hiệu ứng ứng dụng thời gian thực chỉ dùng thư viện Javascript là Node.js để xây dựng Backend Server, nhưng trong một số trường hợp sử dụng PHP cũng rất tốt. Bạn có thể sẽ thắc mắc và muốn biết "Node.js hay PHP tốt hơn?". Nhưng nếu để tìm ra công nghệ chiến thắng thì tôi nghĩ nó thật ngu ngốc khi đánh giá công nghệ web. Tốt hơn là, tập trung vào làm thế nào để làm cho các công nghệ hoạt động cùng nhau thay vì cố gắng tìm ra những thứ tốt nhất. Ví dụ, cách đây không lâu tôi đã tạo một Backend Server với Node.JS cho một hệ thống chat đơn giản. Tuy nhiên, tôi đã gặp một số rắc rối khi sử dụng cơ sở dữ liệu.
  20. Vậy tôi đã làm gì sau đó? Rất đơn giản. Tôi đã tạo Node.JS kết nối với một Backend bằng PHP và sử dụng nó để thực hiện các thao tác với cơ sở dữ liệu mà tôi không thể làm được nếu chỉ sử dụng Node. Tại sao chỉ chọn giữa Node.JS và PHP trong khi chúng ta có thể sử dụng cả hai? Node: Chính xác hơn là bạn nên biết Sự khác nhau giữa PHP và Node.js để biết sử dụng, kết hợp lúc nào phù hợp. 7. PHP có thể tạo Theme và Plugin WordPress Chắc bạn đã biết hầu hết các Web Framework và CMS (hệ thống quản lý nội dung) được viết bằng PHP. WordPress là một trong những CMS thành công nhất với mức độ phổ biến liên tục tăng trong trong hai thập kỷ qua. Nếu bạn cảm thấy hứng thú với Wordpress, hãy xem kho lưu trữ plugin WordPress chính thức hoặc tại các trang web như Envato Market: Đã có bao nhiêu phần mềm đang được viết (và bán) cho WordPress? Một điều rõ ràng là: Nếu bạn có kế hoạch kiếm tiền bằng nghề lập trình, thì PHP là lựa chọn an toàn và nhanh chóng hơn nhiều ngôn ngữ lập trình khác. 8. PHP có thể tạo REST và WEB Service Các Web Service (bao gồm các REST service) là các hệ thống trao đổi dữ liệu giữa máy với máy qua HTTP(S).
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

Đồng bộ tài khoản
7=>1