WordPress Nonce là gì? Cách để ngăn chặn một cuộc tấn công CSRF

Ngày đăng: 15 - 09 - 2021 Lượt xem: 1287 lượt

Tấn công CSRF là gì?

Tấn công CSRF (Cross Site Request Forgery) là một kỹ thuật tấn công có khả năng giả mạo người dùng để thực hiện các hoạt động không mong muốn trên website, hay ứng dụng.

Một cuộc tấn công CSRF có khả năng gây ra hậu quả nghiêm trọng cho người dùng hoặc doanh nghiệp, như thay đổi mật khẩu, đánh cắp dữ liệu, phá hoại,…

Để ngăn chặn một kịch bản tấn công bằng kỹ thuật CSRF, WordPress đã có một cơ chế để chống lại vấn đề này bằng Nonce.

Vậy, WordPress Nonce là gì?

WordPress Nonce hay Nonce là một chuỗi ký tự ngẫu nhiên được đính kèm với URL hoặc biểu mẫu (form) để xác minh rằng, hành động được thực hiện bởi chính người dùng đó.

Chuỗi ký tự này được sử dụng một lần và khác nhau đối với mỗi người dùng. Điều đó có nghĩa là không thể làm giả được. Nếu nonce không hợp lệ, WordPress sẽ từ chối yêu cầu.

Sơ đồ hoạt động của nonce

Sơ đồ cho thấy nonce hoạt động như thế nào

Làm thế nào để triển khai WordPress Nonce?

Có 3 cách để tạo WordPress Nonce:

  • wp_create_nonce() – Tạo một nonce đơn giản, sử dụng tuỳ vào mục đích của bạn.
  • wp_nonce_url() – Thêm một tham số _wpnonce vào đường dẫn URL.
  • wp_nonce_field() – Tạo ra một trường input hidden có chứa nonce.

Ví dụ:

<?php
$new_nonce = wp_create_nonce( 'add_product' );
// zxcvbn678

$url = 'https://hocwordpress.vn/';
$nonce_url = wp_nonce_url( $url, 'delete_product' );
// https://hocwordpress.vn/_wpnonce=zxcvbn678

wp_nonce_field( 'change_password' );
// <input id="_wpnonce" name="_wpnonce" type="hidden" value="zxcvbn678" />

Để xác minh nonce, chúng ta sử dụng hàm wp_verify_nonce()

Ví dụ dưới đây xử lý việc gởi biểu mẫu – submit form.

<?php
$nonce = $_POST['_wpnonce'];

if( wp_verify_nonce( $nonce, 'change_password' ) ) {
  // Thành công, tiến hành thay đổi password
  // ...
} else {
  return false; // Huỷ bỏ
}

Tổng kết

CSRF là lỗ hổng phổ biến nhất được tìm thấy trong các plugin và theme WordPress. Qua bài viết này, hi vọng mình đã giúp các bạn ngăn chặn được một cuộc tấn công bằng kỹ thuật CSRF trong tương lai.

Nếu các bạn thấy hay có thể theo dõi chuyên mục thủ thuật wordpress để biết thêm nhiều kiến thức mới nha.

Hãy follow fanpage để nhận được những bài viết mới nhất nhé : Hocwordpress Group

Chúc bạn có những kiến thức về  wordpress thú vị và hay ho !

5 3 votes
Đánh giá bài viết

Nhận thông báo
Nhận thông báo cho
guest

0 Góp ý
Inline Feedbacks
View all comments

Bài viết liên quan

WordPress Multisite là gì? 6 bước cài đặt chi tiết

WordPress Multisite là gì? 6 bước cài đặt chi tiết

20 - 11 - 2022

Doanh nghiệp của bạn đang phát triển muốn mở rộng thêm nhiều chi nhánh và muốn xây dựng thêm...

Chi tiết cách kiểm tra mã độc WordPress và loại bỏ chúng

Chi tiết cách kiểm tra mã độc WordPress và loại bỏ chúng

15 - 11 - 2022

Đối với website, mã độc được sử dụng để đánh cắp thông tin khách hàng, nắm giữ thông tin...

So sánh Blogspot và WordPress, 2 nền tảng Blog tốt nhất hiện nay

So sánh Blogspot và WordPress, 2 nền tảng Blog tốt nhất hiện nay

11 - 11 - 2022

WordPress và Blogspot hiện nay đang là 2 nền tảng website dạng blog nổi tiếng nhất trên thế giới....

Uncategorized là gì, cách đổi tên danh mục Uncategorized trong WordPress

Uncategorized là gì, cách đổi tên danh mục Uncategorized trong WordPress

05 - 11 - 2022

Trong WordPress, Category để chỉ một danh mục được sử dụng để gom các bài viết có liên quan...

Elementor là gì? hướng dẫn cài đặt Elementor chi tiết

Elementor là gì? hướng dẫn cài đặt Elementor chi tiết

03 - 11 - 2022

Elementor là một plugin xây dựng trang giúp bạn dễ dàng tạo các trang web WordPress đẹp. Ngay cả...

4 cách xóa category trong URL WordPress đơn giản, nhanh chóng

4 cách xóa category trong URL WordPress đơn giản, nhanh chóng

02 - 11 - 2022

Nhà phát triển wordpress thêm / category / urls để dễ dàng xác định các trang web có /...

0
Would love your thoughts, please comment.x