Một vài kiến thức nền tảng về web

Tram Ho

Nếu bạn mới chuẩn bị bắt đầu bước đầu tiên làm quen với hacking thì bài viết đầu tiền trong seri này rất cần thiết với bạn. Nó sẽ giúp bạn hiểu được internet hoạt động như thế nào.

Chúng ta có thể mô tả một cách tổng quan rằng internet là một hệ thống các thiết bị thông tin được kết nối với nhau và có thể gửi tin nhắn cho nhau. Một số các thiết bị chỉ có phép nhận các loại message nhất định, một số thì chỉ nhận message từ 1 danh sách các thiết bị được xác định. Nhưng tất cả các hệ thống trên internet đều có 1 địa chỉ ip mà mọi người đều có thể gửi message đến. Và các hệ thống này sẽ xác định những điều cần làm với các message này và cách phản hỏi lại chúng cho người gửi.

  • Để các hệ thống khác nhau có thể xác định được cấu trúc của các message này để xử lý thì chúng sẽ sử dụng các giao thức chung. Ví dụ như giao thức HTTP và HTTPS định nghĩa giao thức mà các trình duyệt internet của bạn giao tiếp. Ví khi trình duyệt của bạn và máy chủ web đồng ý sử dụng giao thức này thì chúng có thể giao tiếp với nhau.
  • Khi mà bạn gõ địa chỉ http://www.google.com vào trình duyệt của bạn thì các bước sẽ được thực hiện như sau:
    • Trình duyệt của bạn sẽ lấy ra domain name của trang web từ url là : google.com
    • Máy tính của bạn sẽ gửi yêu cầu DNS đến máy chủ được cài làm DNS severs của bạn. DNS sẽ giúp máy bạn phân giải domain name thành địa chỉ IP : 216.58.201.228:80
    • Máy tính của bạn sẽ cố gắng cài đặt một kết nối TCP đến địa chỉ IP này trên cổng 80 (cổng mặc định sử dụng cho giao thức HTTP). ( Bạn có thể thử tự tạo kết nối TCP bằng cách chạy lệnh nc 216.58.201.228 80 trên teminal.
    • Nếu thành công thì trình duyệt sẽ gửi 1 HTTP request đại loại như:

Sau đó nó sẽ đợi 1 phản hồi từ server kiểu như:

  • Sau đó trình duyệt sẽ phân tích và render các tài nguyên được trả về như HTMLCSS, và Javascript thành trang web hiện thị cho người dùng.
  • Ngoài ra các request này còn có các method (phương thức) khác nhau. Ví dụ như Post, Get, Put, …
    • Get: Truy xuất các thông tin tài nguyên được xác định theo yêu cầu.
    • Head: Tương tự như Get nhưng server sẽ không trả về request body trong response.
    • Post: Thường được sử dụng để gọi đến các chức năng để tạo 1 cái gì đó ví dụ như tạo comment trong các bài đăng, tạo tài khoản người dùng, … Tất nhiên các hành động này có thể server sẽ không thực hiện nếu như xảy ra lỗi hoặc không có quyền từ phía người dùng,…
    • Put: Phương thức này thường được dùng để gọi các chức năng dùng để chỉnh sửa các nguồn tài nguyên có sẵn.
    • Delete: Như tên gọi phương thức này để xóa một tài nguyên xác định trên server.
    • Trace: Đây là một phương thức không phổ biến giúp client xem được những gì máy chủ trả về, và sử dụng để kiểm tra và chuẩn đoán thông tin.
    • Connect: Thực sự dùng để sử dụng riêng với proxy.
    • Options: Sử dụng để yêu cầu thông tin từ sever về các phương thức có thể sử dụng. Ví dụ gọi phương thức OPTIONS có thể giúp client biết được server chấp nhận các phương thức GET, POST, PUT, DELETE nhưng không chấp nhận các phương thức HEAD hoặc TRACE.

Trên đây là một số kiến thức nền tảng về Web mà TopDev đã chọn lọc để cung cấp cho các bạn, mong rằng các bạn thấy chúng hữu ích. Cảm ơn các bạn đã theo dõi bài viết.

Chia sẻ bài viết ngay

Nguồn bài viết : viblo.asia