Giao tiếp giữa các cửa sổ với Window.postMessage API (ok)
https://viblo.asia/p/giao-tiep-giua-cac-cua-so-voi-windowpostmessage-api-V3m5WaAQZO7
Hoặc tham khảo https://viblo.asia/p/giao-tiep-giua-cac-cua-so-voi-windowpostmessage-api-V3m5WaAQZO7
Một ví dụ đã hoàn thành:
C:\xampp\htdocs\blog\index.php
C:\xampp\htdocs\blog\postMessageTarget.html
Kết quả:
Giao tiếp giữa các cửa sổ với Window.postMessage API
Mở đầu
Bạn đã bao giờ có nhu cầu giao tiếp giữa các cửa sổ hoặc cửa sổ hiện tại và iframe bên trong chưa. như truyền data từ cửa sổ này đến cửa sổ kia và ngược lại. Vậy làm cách nào để làm được điều đó? thì window.postMessage api chính là giải pháp của bạn? chúng ta cùng tìm hiểu trong bài viết này nhé!!
Cú pháp
Với các tham số được mô tả bằng bảng dưới đây:
Tên
Mô tả
targetWindow
Reference tới một windows hoặc iframe nào đó mà bạn muốn gửi message, giá trị này được trả về khi gọi hàm window.open hoặc tên, id của frame trong biến window.frames
message
Dữ liệu cần gửi đến targetOrigin, có thể là string hoặc objec .....
targetOrigin
Là trang sẽ nhận được message này. Hoặc có thể là "*" thì message này sẽ được gửi đến mọi window target đến nó (Không khuyến khích dùng)
Gửi Message
Để dõ hơn mình sẽ tạo ra 2 cửa sổ window như này:
Window 1 (http://localhost:8002/window-1)
Window 2 (http://localhost:8002/window-2)
Tiếp theo mình sẽ viết code js cho window 1 để gửi message cho window 2:
Nhận Message
Tiếp theo viết code nhận message từ window-1 cho window-2
Các thuộc tính nhận được sẽ bao gồm:
Tên
Mô tả
data
Đối tượng được truyền đến
origin
Nguồn gốc của data truyền đến. bạn phải kiểm tra trường này để tranh trường hợp người khác giả mạo sender cũng như xử lý những message không liên quan tới mình
source
reference đến đối tượng cửa sổ đã gửi tin nhắn; bạn có thể sử dụng điều này để thiết lập giao tiếp hai chiều giữa hai cửa sổ với nguồn gốc khác nhau.
Thành quả sẽ như thế này :
Vấn đề về bảo mật
Nếu trang web của bạn không muốn nhận message từ các trang khác gửi tới thì tuyệt đối không lắng nghe event message dưới đây:
Nếu bạn bắt buộc phải nhận message từ những trang khác thì luôn luôn xác minh danh tính của trang gửi đến bằng cách sử dụng origin
Bất kỳ window nào cũng có thể gửi tin nhắn đến các window khác, và bạn không phải biết tin nhắn đó có độc hại hay không vì vậy không chỉ xác minh danh tính của window gửi đến mà bạn còn phải luôn xác minh cú pháp của tin nhắn nhận được
Luôn chỉ định chính xác targetOrigin.và không dùng "*" khi bạn sử dụng postMessage để gửi data đến window khác.
Tổng kết
Last updated