Đối với những diễn đàn, hay các website thương mại điện tử, web shop,… đều có chức năng đăng ký thành viên, để thành viên có thể có những quyền hạn nhất định nào đó như mua hàng, bình luận bài viết,…Đây là một trong những chức năng quan trọng và gần như là cần phải có đối với các website kể trên. Chính vì thế hôm nay mình chia sẽ đến các bạn bài viết về hướng dẫn tạo form đăng ký và đăng nhập trong lập trình website PHP.
Lưu ý :

Đối với các bạn mới bắt đầu học lập trình PHP các bạn nên gõ theo từng đoạn code để nhớ bài và hiểu vấn đề hơn, đừng copy nguyên đoạn code như vậy sẽ không nắm được lâu kiến thức.
Chuẩn bị :

Để bắt đầu thực hành bài này, các bạn hãy chuẩn bị cho mình những điều cần thiết sau :
– Đã khởi chạy (start) môi trường để lập trình PHP (coi lại bài Hướng dẫn cài đặt môi trường lập trình PHP)
– Chuẩn bị công cụ editor phù hợp để có thể code (các bạn có thể tham khảo bài Giới thiệu về các editor cho nhà phát triển web)

– Trong thư mục gốc của website (ở đây mình dùng wamp nên thư mục gốc sẽ là www, còn đối với các bạn dùng xampp, thì thư mục gốc sẽ là htdocs), các bạn tạo 1 folder đặt tên là my_website để chưa tất cả source code mà mình sẽ hướng dẫn các bạn từng bước làm 1 website hoàn chỉnh bằng ngôn ngữ lập trình PHP từ đây trở về sau.

Trong thư mục my_website , các bạn tạo cho mình cấu trúc thư mục như sau :

thư mục chính php

1. Tạo form đăng ký :

Đầu tiên mình sẽ thiết kế một form đăng ký, đặt tên là register.php, (đặt trong thư mục my_website) bao gồm các trường :
– trường để người dùng nhập nickname
– trường để người dùng nhập mật khẩu
– trường để người dùng nhập họ tên
– trường để người dùng nhập địa chỉ email

Chạy đoạn code trên (vào browser gõ đường dẫn http://localhost/my_website/register.php) ta được form đăng ký đơn giản như sau

form đăng ký php

2. Tạo cơ sở dữ liệu lưu trữ

Tiếp đến, ta sẽ thiết kế cơ sở dữ liệu và tạo bảng lưu trữ thông tin người dùng, ở đây mình lấy tên cho database là “kungfuphp” và bảng là “users”. Trong bảng uses sẽ bao gồm các cột

  • id : kiểu int, khóa chính, thuộc tính tự tăng (auto increment)
  • username : tên đăng nhập, kiểu var char, độ dài là 30 kí tự
  • password  : mật khẩu, kiểu var char, độ dài 30 kí tự
  • name : tên người dùng, kiểu var char, độ dài 255 kí tự
  • email : địa chỉ email, kiểu var char, đồ dài 255 kí tự

3. Bắt đầu code

a) Tạo kết nối đến mysql để lấy dữ liệu

Để có thể select hoặc insert, update dữ liệu trong database, ta cần phải tạo một giao thức kết nối giữa PHP và Mysql. Ở đây mình sẽ tạo một file mới tên là connection.php, đặt trong thư mục lib và gõ theo như đoạn code dưới đây:

Ở đoạn code trên, chúng ta dùng phương thức mysqli_connect của PHP để PHP có thể kết nối tới dữ liệu mysql với 3 tham số:

  • $server_host :tên host chưa database, ở đây mình dùng là localhost vì chạy ở máy tính cục bộ, còn khi upload website lên các host khác thì chúng ta có thể thay đổi tham số này cho phù hợp.
  • $server_username  : tên đăng nhập vào database, mặc định ở local là root
  • $server_password ; mật khẩu đăng nhập vào database, mặc định ở local là rỗng

phương thức or die nhằm kiểm tra nếu kết nối thất bại sẽ xuất ra dòng chữ “không thể kết nối tới database”

phương thức mysqli_query($conn,”SET NAMES ‘UTF8′”) bạn có thể thêm vào hoặc không đều được, đây là phương thức tùy chọn, dành cho trong trường hợp cơ sở dữ liệu của bạn có các kí tự đặc biệt dạng utf-8 thì khi truy vấn hoặc cập nhật dữ liệu sẽ không bị lỗi font chữ

Tiếp đến trong file register.php, bạn cần phải require file connection.php vừa tạo vào bằng cách dùng từ khóa require_once (hoặc include, include_once, require)

Sau khi đã require_once tập tin connection.php vào, chúng ta đến giai đoạn kiểm tra thông tin đăng ký hợp lệ và lưu dữ liệu vào database, ở đây mình sẽ lấy các thông tin ở form đăng ký đã tạo ở trên bằng phương thức POST, các bạn lưu ý là :

  • Trong thẻ <form> ở trên có phương thức method mình cố tình để sẵn là method=”POST” nên các bạn phải dùng từ khóa $_POST để có thể lấy được thông tin
  • Trong PHP, từ khóa $_POST chỉ lấy được giá trị của thẻ input thông qua thuộc tính name, không phải thẻ id nhé các bạn
  • Ngoài phương thức POST, chúng ta còn có thể sử dụng phương thức GET và sử dụng từ khóa $_GET để lấy dữ liệu
  • Sự khác nhau giữa POST và GET thì mình sẽ nói rõ hơn trong các bài sau 🙂

Ở đoạn code bên trên đây, mình dùng từ khóa isset để kiểm tra button có name là btn_submit đã được click hay chưa, nếu click rồi thì mới bắt đầu lấy thông tin và insert dữ liệu vào database, tranh trường hợp khi load trang, đoạn code thực thi sẽ tự động chạy. Như đã nói ở trên, mình dùng từ khóa $_POST để lấy các thông tin username, password, name, email và kiểm tra nếu 1 trong các field này rỗng thì sẽ xuất ra thông báo là “bạn vui lòng nhập đầy đủ thông tin”, ngược lại sẽ là thực thi việc lưu trữ dữ liệu như sau:

Toàn bộ code đầy đủ trong file register.php sẽ như sau :

Video demo (phóng to lên, chọn chế độ HD 720 xem cho rõ nhé)

Vậy là chúng ta đã thiết kế xong trang register.php cho phép người dùng nhập dữ liệu và lưu trữ vào database. Bài viết cũng khá dài nên mình tạm dừng ở đây, các bạn có thắc mắc gì thì hãy để lại comment bên dưới bài viết nhé. Trong bài tiếp theo mình sẽ nói về việc kiểm tra thông tin có trong database và tạo form đăng nhập. Các bạn nhớ đón xem, thân !

Đợi chút, bạn có muốn tự tay tạo thiết kế website bằng HTML, CSS, Bootstrap cho riêng mình ? Nếu có thì xem tại đây nhé

Nguon : kungfuphp.com
Đánh giá bài viết

Mình là Hiếu.
Mình lập ra Kungfu PHP nhằm mục đích chia sẽ những gì mình biết đến với các bạn bao gồm các lĩnh vực như : tiền điện tử, kiếm tiền online, marketing, lập trình…
Hy vọng nơi đây là mái nhà chung để chúng ta có thể học tập và trao đổi với nhau, cùng nhau phát triển.
Chúc các bạn luôn vui !

Bạn có muốn tham gia nhóm thảo luận ICO tốt nhất ?

71 Comments Already

  1. aaaaaaaaaaaaaa bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb

  2. Anh ơi cho em hỏi, form này có dùng để lưu trữ thông tin đăng ký mua hàng được ko. E làm một cái form đăng ký mua hàng trực tiếp trên website nhưng chưa biết lưu trữ vào đâu.

  3. cảm ơn tác giả nhiều, đúng cái mình đang tìm, làm xong cho chạy rất ok

  4. cái này là lỗi kết nối rồi, nó báo ko sử dụng password kìa, e thử để password rỗng xem sao

  5. Warning: mysqli_connect(): (HY000/1045): Access denied for user ‘root’@’localhost’ (using password: NO) in D:\WampServer\wamp64\www\firstphp\lib\connectdata.php on line 11
    em bị như này . em đã thử thay đổi password của user root nhưng vẫn không được.
    Mong anh chỉ dùm em.

  6. Nếu muốn kiểm tra xem tên đăng nhập có chứa kí tự đặc biệt hay không thì làm sao vậy ad

    • < ?php $string = 'foo'; if (preg_match('/[\'^£$%&*()}{@#~?><>,|=_+¬-]/’, $string)) { // one or more of the ‘special characters’ found in $string }

    • dùng biểu thức chính quy nhé bạn

  7. Notice: Undefined variable: conn in C:\xampp\htdocs\www\dk1\register.php on line 20

    Warning: mysqli_query() expects parameter 1 to be mysqli, null given in C:\xampp\htdocs\www\dk1\register.php on line 20

    Warning: mysqli_num_rows() expects parameter 1 to be mysqli_result, null given in C:\xampp\htdocs\www\dk1\register.php on line 22

    Notice: Undefined variable: conn in C:\xampp\htdocs\www\dk1\register.php on line 38

    Warning: mysqli_query() expects parameter 1 to be mysqli, null given in C:\xampp\htdocs\www\dk1\register.php on line 38
    chúc mừng bạn đã đăng ký thành công

    nó báo ntn là thành công chưa a

  8. Cho mình hỏi chút. Có bản phpmyadmin dùng cho winxp k nhỷ hoặc có cách nào tạo localhost trên winxp k vậy

  9. Admin ơi! mình làm theo như trên mà nhập vào form đăng ký xong nhấn đăng ký k thấy hiện thông báo cũng k thấy lưu dữ liệu. hay do mình dùng PHP8 nên code này k đc vậy

  10. Bài viết nên cho thêm hình ảnh demo

  11. Bài viết rất bổ ích.
    Mình có 1 góp ý nhỏ: bạn @kungfuphp nên có đường dẫn để tải về các source code ví dụ. Có thể đưa lên git hoặc sourceForge để track các thay đổi sau này.

  12. cho mình hỏi nếu mình muốn mã hóa password bang md5 trước khi đưa vào csdl thì làm sao nhỉ ?

  13. mình đăng ký thành công nhưng chỉ được lần đầu. các lần sau thông tin không vào csdl là bị gì nhỉ?

  14. Các bác cho em hỏi nếu mà làm form đăng kí như này. giờ mình muốn export ra files csv hay exls của exel thì phải viết code thế nào vậy

  15. ad ơi, làm sao để hiện thị được tiếng việt trên web vậy? mình có dùng mà vẫn k được 🙁

  16. mình làm y như bạn chạy dc r nhung vao database thì vẫn chưa insert dc

  17. add còn hoạt động không ta

  18. các anh cho em hỏi tí ạ, mình thêm đoạn code kiểm tra user đã tồn tại chưa vào đâu à!
    cảm ơn ae!

  19. cho mình hỏi nếu muốn thêm phần phân quyền thì làm như nào vậy

  20. ad ơi a cho em hỏi phần tạo cơ sở dữ liệu lưu trữ khi tạo database có name kungfuphp và bảng users thì mình tạo bằng gì và lưu ở đâu ạ??? mong nhận được câu trả lời sớm nhất từ ad ạ. em cảm ơn ad ạ!!!

  21. e ko hiểu cái chỗ ở bước 2 ạ, chỗ bước 2 là dùng để làm ji ạ

  22. chỗ $database = ‘kungfuphp’; là sao ko phải là nháy kép mà là nháy đơn vậy?

  23. Tại sao anh lại không làm phần kiểm tra từ db rồi cho kết nối vào vậy ạ
    Nếu có thêm phần đó thì sẽ hay hơn

  24. Cho mình hỏi là: Mình đã chạy được trang login rồi, bây h nếu mình thêm phần register vào (là có 2 form á) thì chỉ việc lấy code trên chèn thêm vô hay phải làm cách khác.

  25. cho mình hỏi? nếu dữ liệu mới nhập vào trùng với dữ liệu đã có thì phải thêm câu lệnh như thế nào?
    minh mới học php nên nhiều chỗ chưa biết mong moi. người chỉ bảo!

    • bạn sử dụng câu query “select count(*) from table where field_can_check_trung = ‘gia tri can chack'”. Câu query này sẽ trả ra 1 giá trị, nếu nó lớn hơn 0 là trùng, ngược lại bằng 0 là không trùng

      • anh ơi cho em hỏi em nene thêm code “select count(*) from table where field_can_check_trung = ‘gia tri can chack’”. này vao đau vậy anh ạ em thêm hoài mà nó không được vói anh cho em hỏi cái phần phân quyền luôn

        • Bạn thêm vào trước đoạn code insert dữ liệu vào database đó, nếu trùng thì ko cho insert, còn ko trùng thì cho insert

  26. Khi mình đăng ký 1 thành công rồi mình refresh lại trang thì nó lại insert thêm 1 lần nữa!!! Có cách giải quyết nó không ad?

  27. Ad cho em hỏi file inc dùng để làm gì ạ?

  28. các bài biết của kungfu rất là hay và chi tiết.cảm ơn bạn nhé! cho mình xin cái fb hay email làm quen học hỏi nào! hii

  29. bài viết rất hay

  30. mình cũng bị lỗi giống bạn huy.làm y chang.trong trang register mình điền đầy đủ thông tin đăng ký xong nhấn đăng ký thì chỉ hiện ra dòng thông báo ” điền đầy đủ thông tin ” mà trong phpmyadmin database vẫn chưa thấy dc insert @@ giúp với

    • mình mới edit lại code 1 tí, bạn sửa đoan này $password = $_POST[“password”]; -> thành đoạn này nhé $password = $_POST[“pass”]; . Bởi vì $_POST sẽ lấy theo thuộc tính name của input là ‘pass’.

      • tks admin. mình làm dc trang đăng ký goy`.còn phần 2 trang đăng nhập vs trang welcome mình làm giống ad mà chưa dc. ad coi lại dùm nhé.tks nhìu

  31. sao minhg làm giống như hướng dẫn, mà không insert dc dữ liệu vào database dc vậy, hic

    • có thông báo lỗi gì ra ngoài ko bạn ? nếu không thể insert được thì bạn thử echo biến $sql ra ngoài màng hình, và copy đoạn đó và phpmyadmin, thực thi xem có chạy được không (làm điều này để đảm bảo rằng câu lệnh $sql chạy đúng). Thân

      • mình mới edit lại code 1 tí, bạn sửa đoan này $password = $_POST[“password”]; -> thành đoạn này nhé $password = $_POST[“pass”]; . Bởi vì $_POST sẽ lấy theo thuộc tính name của input là ‘pass’.

  32. hay day

  33. Giới thiệu về hệ quản trị cơ sở dữ liệu MySQL

    • Bài rất hay nhưng mình thắc mắc là sao k có ktra xem trong db có tài khaorn đó chưa nhỉ, ntnay có thể dễ bị lặp tài khaorn dki

      • Bạn có thể thêm đoạn này vào để kiểm tra tài khoản trùng lặp:

        $sql=”select * from taikhoan where user=’$name'”;
        $kt=mysql_query($sql);
        if(mysql_num_rows($kt)>0)
        {
        echo “username nay da ton tai”;
        }

Trả lời

Email của bạn sẽ không được hiển thị công khai. Các trường bắt buộc được đánh dấu *

loading...