Tìm hiểu về Tường lửa ứng dụng Web WAF (Web Application Firewall)

19/10/2019

Tường lửa ứng dụng web WAF (Web Application Firewall) được thiết kế để kiểm soát truy cập từ một mạng không tin cậy đến mạng tin cậy và ngược lại. Mọi luồng dữ liệu đi qua tường lửa được kiểm soát theo chính sách bảo mật định sẵn.

Trong những năm gần đây, xu hướng tấn công vào ứng dụng web đang ngày càng trở nên phổ biến. Các kỹ thuật tấn công được sử dụng chủ yếu là cross-site scripting, SQL injection, và nhiều các kỹ thuật khác… tất cả các kỹ thuật này đều nhắm vào lớp ứng dụng trong mô hình OSI. Các lỗ hổng trong ứng dụng web chủ yếu xảy ra do người lập trình không kiểm tra kỹ các tham số hay ký tự do người dùng nhập vào để tương tác với ứng dụng web. Để khắc phục các lỗi trên ứng dụng web, người lập trình cần hiểu và viết được các đoạn mã ở mức độ bảo mật nhất, tuy nhiên việc viết đoạn mã sao cho “bảo mật” nhất thường khó thực hiện, bởi các lẽ sau: Thứ nhất, các đơn vị lập trình thường không có hoặc thiếu đội ngũ chuyên trách về việc kiểm tra và sửa lỗi bảo mật mã nguồn ứng dụng. Thứ hai, đôi khi áp lực phải hoàn thành ứng dụng web trong thời gian nhanh khiến cho các ứng dụng web được đưa vào vận hành mà không qua các khâu kiểm thử. Thứ ba, việc dùng các công cụ kiểm tra lỗi web tự động đôi khi cũng không tìm ra hết các lỗi khi được thực hiện bằng tay. Do vậy, việc bảo mật một ứng dụng web đó là một quá trình phòng thủ theo chiều sâu bao gồm các khâu phát triển, vận hành, xây dựng cơ sở hạ tầng bảo vệ tốt và có một đội ngủ chuyên trách vấn đề bảo mật riêng cho web.

Tường lửa ứng dụng web (Web Application Firewall – WAF) là một giải pháp nhằm bảo vệ cho ứng dụng web tránh khỏi các lỗi bảo mật nói trên. WAF là một thiết bị phần cứng hoặc phần mềm được cài lên máy chủ có chức năng theo dõi các thông tin được truyền qua giao thức http/https giữa trình duyệt của người dùng và máy chủ web tại lớp 7. Một WAF có khả năng thực thi các chính sách bảo mật dựa trên các dấu hiệu tấn công, các giao thức tiêu chuẩn và các lưu lượng truy cập ứng dụng web bất thường. Đây là điều mà các tường lửa mạng khác không làm được.

Web Security: Tường lửa ứng dụng Web (WAF)

Mô hình của một hệ thống Tường lửa ứng dụng Web (WAF)

Kiến trúc tường lửa ứng dụng web

Vị trí đặt WAF:

Các thiết bị WAF cứng thường được đặt sau tường lửa mạng và trước máy chủ ứng dụng web. Việc đặt WAF được thực hiện sao cho tất cả các lưu lượng đến ứng dụng web cần qua WAF trước. Tuy nhiên, đôi khi cũng có ngoại lệ khi WAF chỉ được dùng để giám sát cổng đang mở trên máy chủ web. Ngoài ra, các chương trình WAF còn được cài đặt trực tiếp lên máy chủ web và thực hiện các chức năng tương tự như các thiết bị WAF là giám sát các lưu lượng đến và ra khỏi ứng dụng web.

 Một ví dụ triển khai WAF trong máy chủ web Windows

 Một ví dụ triển khai WAF trong máy chủ web Windows

Mô hình bảo mật:

Một WAF hoạt động dựa theo 2 mô hình bảo mật: Positive và Negative. Mô hình Positive chỉ cho phép các lưu lượng hợp lệ được định nghĩa sẳn đi qua và chặn tất cả các lưu lượng còn lại. Mô hình Negative sẽ cho phép tất cả các lưu lượng vượt qua và chỉ chặn các lưu lượng được mà WAF cho là nguy hại. Đôi khi cũng có các WAF cung cấp cả 2 mô hình trên, tuy nhiên thông thường WAF chỉ cung cấp 1 trong 2 mô hình. Với mô hình Postitive thì đòi hỏi nhiều cấu hình và tùy chỉnh, còn mô hình Negative chủ yếu dựa vào khả năng học hỏi và phân tích hành vi của lưu lượng mạng.

Mô hình hoạt động:

WAF có thể hoạt động ở các mô hình riêng biệt, dưới đây là một số mô hình tham khảo:

- Reverse Proxy: đây là chức năng được sử dụng phổ biến khi triển khai WAF. Trong mô hình này, WAF giám sát tất cả các lưu lượng đi đến ứng dụng web, sau đó thay vì cho các địa chỉ IP bên ngoài gửi yêu cầu trực tiếp đến máy chủ web thì WAF đứng ra làm trung gian để gửi các yêu cầu này đến máy chủ web thay cho trình duyệt gốc rồi gửi trả lại kết quả cho các địa chỉ IP kia. Mô hình này có nhược điểm là tạo ra độ trễ khi kết nối từ trình duyệt đến ứng dụng web.

- Transparent Proxy: Ở mô hình này, WAF đứng giữa tường lửa mạng và máy chủ web và hoạt động tương tự ở mô hình Reverse Proxy nhưng không đứng ra làm trung gian kết nối như bên Reverse Proxy. Mô hình này không đòi hỏi phải thay đổi điều gì trong hạ tầng mạng nhưng có thể không cung cấp được một số dịch vụ như mô hình Reverse Proxy có thể.

- Layer 2 Brigde: Ở mô hình này, WAF đứng giữa tường lủa mạng và máy chủ web, nhưng hoạt động giống như một thiết bị Switch ở lớp 2. Mô hình này giúp mạng hoạt động với hiệu năng cao và mạng thay đổi không đáng kể, tuy nhiên nó lại không thể cung cấp các dịch vụ cao cấp khác mà các mô hình WAF khác có thể.

- Host/Server Based: Đây là các phần mềm được cài trực tiếp lên máy chủ web. Các loại Host based không cung cấp các tính năng tương tự như các loại WAF network base. Tuy nhiên mô hình này có thể khắc phục được vài điểm yếu mà các mô hình network base (các thiết bị WAF cứng) có. Tuy nhiên nó cũng làm tăng mức độ tải của máy chủ web.

 

Tin liên quan

17/02/2021

Dự đoán xu hướng điện toán đám mây năm 2021

Điện toán đám mây đóng vai trò quan trọng trong việc đối phó với cuộc khủng hoảng COVID-19. Các nhà cung cấp dịch vụ Cloud là những công ty thành công nổi bật trong năm bất thường nhất này.

15/02/2021

5 nền tảng công nghệ tiên phong trong năm mới 2021

Công nghệ ngày nay đang phát triển với tốc độ chóng mặt, tạo điều kiện cho sự thay đổi và tiến bộ nhanh hơn, khiến tốc độ thay đổi tăng nhanh, cho đến cuối cùng nó sẽ trở thành cấp số nhân.

09/02/2021

Tổng kết 5 xu hướng công nghệ HOT nhất năm 2020

Từ đầu năm 2020, sự bùng phát của đại dịch Covid 19 đã gây ra vô số khó khăn cho thế giới và đặc biệt ảnh hưởng mạnh mẽ đến các nhà sản xuất điện thoại, laptop,... trong lĩnh vực công nghệ.

06/02/2021

5 trong số các nền tảng Hosting Node.js tốt nhất cho năm 2021 (miễn phí và trả phí)

​Bạn đang gặp khó khăn trong việc tìm kiếm dịch vụ Hosting Node.js tốt nhất cho dự án tiếp theo của bạn? Trong bài viết này này, Viettel IDC sẽ chia sẻ với bạn một số dịch vụ Hosting Node.js cả miễn phí và trả phí cho người dùng ở mọi mức độ khác nhau. Hãy cũng chúng tôi theo dõi nhé.

06/02/2021

Một số nhà cung cấp dịch vụ Domain Hosting nước ngoài bạn nên biết

​Web Hosting và Domain Hosting, mặc dù có liên quan chặt chẽ với nhau nhưng bản chất nó là hai dịch vụ hoàn toàn khác nhau. Web Hosting cho phép người dùng tạo và lưu trữ nội dung, như một trang web, trên các máy chủ Internet. Domain Hosting ngoài việc cung cấp tên miền nó giúp khách truy cập vào nội dung web của bạn.

06/02/2021

Top 4 nhà cung cấp dịch vụ Dedicated Server Hosting nước ngoài tốt nhất

Khi Website của bạn có hàng nghìn lượt truy cập từ người dùng quốc tế hàng ngày, bạn nên cân nhắc đến một dịch vụ Dedicated Server Hosting. Nó sẽ mang đến cho bạn tất cả trải nghiệm tốt nhất có thể như trang Web tải nhanh hơn và hạn chế lỗi.

06/02/2021

Mắt Bão Hosting - Những "giới hạn" bạn cần biết khi sử dụng

​Mắt Bão Hosting là một trong nhiều dịch vụ được cung cấp bởi một nhà cung cấp tên miền lớn tại Việt Nam. Thế mạnh chủ yếu của Mắt Bão tập trung ở mảng tên miền. Vậy nếu như bạn có ý định thuê và sử dụng Mắt Bão Hosting cho mục đích kinh doanh của mình thì điều đó có thực sự phù hợp?

05/02/2021

Hosting Viettel - Sự hòa hợp giữa chất lượng và giá cả

​Hosting Viettel định hình mình là một bộ giải pháp hướng đến những khách hàng ở phân khúc tầm trung. Do đó, những sản phẩm trong bộ sưu tập Hosting Viettel hiện cũng đi theo chiều hướng này. So với những giải pháp Hosting từ những nhà cung cấp khác thì Hosting Viettel có gì đặc biệt hơn hay không?

03/02/2021

Những điều người dùng nên lưu ý khi sử dụng Hosting Việt Nam

Hosting Việt Nam có thể được hiểu là những gói dịch vụ lưu trữ dành cho người dùng tại Việt Nam nói riêng. Thực tế trên thị trường, có rất nhiều nhà cung cấp dịch vụ Hosting Việt Nam này.

03/02/2021

Hosting Linux là gì? Viettel IDC - Nhà cung cấp dịch vụ Hosting Linux phổ biến tại Việt Nam

Linux được xem như là hệ điều hành phổ biến nhất bởi vì nó là một nền tảng mã nguồn mở. Hệ thống mã nguồn mở cho phép nhà phát triển có thể sửa đổi và phân phối lại mà không bị hạn chế như hệ điều hành Windows.