Lỗi không kiểm tra đầu vào

Một phần của tài liệu Giáo trình cơ sở an toàn thông tin (Trang 38 - 40)

2.2.2.1.Gii thiu

Lỗi không kiểm tra đầu vào (Unvalidated input) là một trong các dạng lỗ hổng bảo mật phổ biến, trong đó ứng dụng không kiểm tra, hoặc kiểm tra không đầy đủ các dữ liệu đầu vào, nhờđó kẻ tấn công có thể khai thác lỗi để tấn công ứng dụng và hệ thống. Dữ liệu đầu vào

- 38 -

(Input data) cho ứng dụng rất đa dạng, có thể đến từ nhiều nguồn với nhiều định dạng khác nhau. Các dạng dữ liệu đầu vào điển hình cho ứng dụng có thể bao gồm:

- Các trường dữ liệu văn bản (text);

- Các lệnh được truyền qua địa chỉURL để kích hoạt chương trình;

- Các file âm thanh, hình ảnh, hoặc đồ họa do người dùng, hoặc các tiến trình khác cung cấp;

- Các đối sốđầu vào trong dòng lệnh;

- Các dữ liệu từ mạng hoặc từ các nguồn không tin cậy.

Trên thực tế, kẻ tấn công có thể sử dụng phương pháp thủ công, hoặc tựđộng để kiểm tra các dữ liệu đầu vào và thử tất cả các khảnăng có thểđể khai thác lỗi không kiểm tra đầu vào. Theo thống kê của trang web OWASP2, một trang web chuyên về thống kê các lỗi bảo mật

ứng dụng web, lỗi không kiểm tra đầu vào luôn có mặt ở nhóm dẫn đầu trong các lỗi bảo mật web trong khoảng 5 năm trở lại đây.

2.2.2.2.Tn công khai thác

Có hai dạng chính tấn công khai thác lỗi không kiểm tra đầu vào: (1) cung cấp dữ liệu quá lớn hoặc sai định dạng để gây lỗi cho ứng dụng, và (2) chèn mã khai thác vào dữ liệu đầu vào

để thực hiện trên hệ thống của nạn nhân, nhằm đánh cắp dữ liệu nhạy cảm hoặc thực hiện các hành vi phá hoại. Hình 2.17 minh họa tấn công khai thác lỗi không kiểm tra đầu vào dạng (1) thông qua việc nhập dữ liệu quá lớn, gây lỗi thực hiện cho trang web.

Hình 2.17.Cung cấp dữ liệu quá lớn để gây lỗi cho ứng dụng

Chúng ta minh họa tấn công khai thác lỗi không kiểm tra đầu vào dạng (2) bằng việc chèn mã tấn công SQL vào dữ liệu đầu vào, tiếp theo mã tấn công SQL được thực hiện trên hệ

- 39 -

quản trịcơ sở dữ liệu đích nhằm đánh cắp, hoặc phá hủy dữ liệu trong cơ sở dữ liệu. Giả thiết một trang web tìm kiếm sản phẩm sử dụng câu lệnh SQL sau để tìm kiếm các sản phẩm:

"SELECT * FROM tbl_products WHERE product_name like '%" + keyword + "%'"

trong đó tbl_products là bảng lưu thông tin các sản phẩm, product_name là trường tên sản phẩm và keyword là từ khóa cung cấp bởi người dùng thông qua form tìm kiếm. Nếu người dùng nhập từkhóa là "iPhone 7", khi đó câu lệnh SQL trở thành:

"SELECT * FROM tbl_products WHERE product_name like '%iPhone 7%'"

Nếu trong bảng có sản phẩm thỏa mãn điều kiện tìm kiếm, câu lệnh SQL sẽ trả về tập bản ghi. Nếu không có sản phẩm nào thỏa mãn điều kiện tìm kiếm, câu lệnh SQL sẽ trả về tập bản ghi rỗng. Nếu người dùng nhập từ khóa "iPhone 7';DELETE FROM tbl_products;--", khi đó

câu lệnh SQL trở thành:

"SELECT * FROM tbl_products WHERE product_name like '%iPhone 7';DELETE

FROM tbl_products;--%'"

Như vậy, câu lệnh SQL được thực hiện trên cơ sở dữ liệu gồm 2 câu lệnh: câu lệnh chọn

SELECT ban đầu và câu lệnh xóa DELETE do kẻ tấn công chèn thêm. Câu lệnh “DELETE FROM tbl_products” sẽ xóa tất cả các bản ghi trong bảng tbl_products. Sởdĩ kẻ tấn công có thể thực hiện điều này là do hầu hết các hệ quản trịcơ sở dữ liệu cho phép thực hiện nhiều câu lệnh SQL theo m (batch) trong một chuỗi lệnh, trong đó các câu lệnh được ngăn cách bởi dấu (;). Ngoài ra, dấu “--” ở cuối dữ liệu nhập để loại bỏ hiệu lực của phần lệnh còn lại do “--” là

ký hiệu bắt đầu phần chú thích của dòng lệnh SQL. Ngoài DELETE, kẻ tấn công có thể chèn thêm các lệnh SQL khác, như INSERT, hoặc UPDATE để thực hiện việc chèn thêm bản ghi, hoặc sửa đổi dữ liệu theo ý đồ tấn công của mình.

2.2.2.3.Phòng chng

Biện pháp chủ yếu phòng chống tấn công khai thác lỗi không kiểm tra đầu vào là lọc dữ

liệu đầu vào. Tất cả các dữ liệu đầu vào, đặc biệt dữ liệu nhập từngười dùng và từ các nguồn không tin cậy cần được kiểm tra kỹlưỡng. Các biện pháp cụ thể bao gồm:

- Kiểm tra kích thước và định dạng dữ liệu đầu vào; - Kiểm tra sự hợp lý của nội dung dữ liệu;

- Tạo các bộ lọc để lọc bỏ các ký tựđặc biệt và các từ khóa của các ngôn ngữ trong các

trường hợp cần thiết mà kẻ tấn công có thể sử dụng: + Các ký tựđặc biệt: *, ', =, --

+ Các từ khóa ngôn ngữ: SELECT, INSERT, UPDATE, DELETE, DROP,.... (với dạng tấn công chèn mã SQL).

Một phần của tài liệu Giáo trình cơ sở an toàn thông tin (Trang 38 - 40)

Tải bản đầy đủ (PDF)

(144 trang)