Catch up on everything announced at Firebase Summit, and learn how Firebase can help you accelerate app development and run your app with confidence. Learn More

ทริกเกอร์ Pub/Sub

จัดทุกอย่างให้เป็นระเบียบอยู่เสมอด้วยคอลเล็กชัน บันทึกและจัดหมวดหมู่เนื้อหาตามค่ากำหนดของคุณ

Pub/Sub ของ Google Cloud เป็นบัสข้อความที่กระจายไปทั่วโลกซึ่งปรับขนาดโดยอัตโนมัติตามที่คุณต้องการ คุณสามารถสร้างฟังก์ชันที่จัดการเหตุการณ์ Pub/Sub ได้โดยใช้ functions.pubsub

เปิดใช้ฟังก์ชันผับ/ย่อย

คุณสามารถทริกเกอร์ฟังก์ชันเมื่อใดก็ตามที่ข้อความ Pub/Sub ใหม่ถูกส่งไปยังหัวข้อเฉพาะ คุณต้องระบุชื่อหัวข้อ Pub/Sub ที่คุณต้องการเรียกใช้ฟังก์ชันของคุณ และตั้งค่าเหตุการณ์ภายในตัวจัดการเหตุการณ์ onPublish() :

exports.helloPubSub = functions.pubsub.topic('topic-name').onPublish((message) => {
  // ...
});

เข้าถึงเพย์โหลดข้อความ Pub/Sub

เพย์โหลดสำหรับข้อความ Pub/Sub สามารถเข้าถึงได้จากวัตถุ Message ที่ส่งคืนไปยังฟังก์ชันของคุณ สำหรับข้อความที่มี JSON ในเนื้อหาข้อความ Pub/Sub นั้น Firebase SDK for Cloud Functions มีคุณสมบัติตัวช่วยในการถอดรหัสข้อความ ตัวอย่างเช่น นี่คือข้อความที่เผยแพร่ด้วยเพย์โหลด JSON อย่างง่าย:

gcloud pubsub topics publish topic-name --message '{"name":"Xenia"}'

คุณสามารถเข้าถึงเพย์โหลดข้อมูล JSON เช่นนี้ผ่านคุณสมบัติ json :

  // Get the `name` attribute of the PubSub message JSON body.
  let name = null;
  try {
    name = message.json.name;
  } catch (e) {
    functions.logger.error('PubSub message was not JSON', e);
  }

เพย์โหลดอื่นๆ ที่ไม่ใช่ JSON มีอยู่ในข้อความ Pub/Sub เป็นสตริงที่เข้ารหัส base64 ในวัตถุข้อความ หากต้องการอ่านข้อความดังต่อไปนี้ คุณต้องถอดรหัสสตริงที่เข้ารหัส base64 ดังที่แสดง:

gcloud pubsub topics publish topic-name --message 'MyMessage'

// Decode the PubSub Message body.
const messageBody = message.data ? Buffer.from(message.data, 'base64').toString() : null;

เข้าถึงแอตทริบิวต์ข้อความ

ข้อความ Pub/Sub สามารถส่งพร้อมกับแอตทริบิวต์ข้อมูลที่ตั้งค่าไว้ในคำสั่งเผยแพร่ ตัวอย่างเช่น คุณสามารถเผยแพร่ข้อความที่มีแอตทริบิวต์ name :

gcloud pubsub topics publish topic-name --attribute name=Xenia

คุณสามารถอ่านแอตทริบิวต์ดังกล่าวได้จาก Message.attributes :

// Get the `name` attribute of the message.
const name = message.attributes.name;

คุณอาจสังเกตเห็นว่าข้อมูลพื้นฐานบางอย่าง เช่น ID ข้อความหรือเวลาเผยแพร่ข้อความไม่มีอยู่ใน Message.attributes หากต้องการหลีกเลี่ยงปัญหานี้ คุณสามารถเข้าถึงรายละเอียดเหล่านี้ได้ใน EventContext ของเหตุการณ์ที่ทริกเกอร์ ตัวอย่างเช่น:

exports.myFunction = functions.pubsub.topic('topic1').onPublish((message, context) => {
    console.log('The function was triggered at ', context.timestamp);
    console.log('The unique ID for the event is', context.eventId);
});