登录
首页 >  Golang >  Go问答

怎样获取发布日期

来源:stackoverflow

时间:2024-02-17 15:51:24 176浏览 收藏

大家好,今天本人给大家带来文章《怎样获取发布日期》,文中内容主要涉及到,如果你对Golang方面的知识点感兴趣,那就请各位朋友继续看下去吧~希望能真正帮到你们,谢谢!

问题内容

我在go中有一个gc函数,它是由对主题的pubsub推送订阅触发的。我正在尝试接收发布时间,但它似乎未填充。

规范说字符串(时间戳格式),但是,我的模型中的该字段是空的。除发布时间外,所有其他信息均已填充。

type pubsubmessagemodel struct {
    data        []byte            `json:"data"`
    attributes  map[string]string `json:"attributes"`
    publishtime string            `json:"publishtime"`
}

只是尝试记录该属性;

log.Info().Msgf("Publish Time is - %s\n", m.PublishTime)

结果为空字符串:

发布时间为-

有什么建议吗?


解决方案


它没有很好的记录,但确实如此。

直接向函数推送时的 event structure is different 与具有 http 触发函数的推送订阅进行比较。

相反,您可以通过事件元数据的事件 id 和时间戳属性访问publishtime 和 messageid。此元数据可通过调用函数时传递给函数的上下文对象来访问。

在 go 中的 background context description 中,有关于使用(函数/元数据)获取上下文值的包的说明

这里是如何实现这一点

  1. 执行 go 获取 cloud.google.com/go
  2. 在代码中使用此依赖项并从上下文中获取消息元数据
import (
    "cloud.google.com/go/functions/metadata"
    "context"
    "log"
)

type PubSubMessage struct {
    Data []byte `json:"data"`
}

// HelloPubSub consumes a Pub/Sub message.
func HelloPubSub(ctx context.Context, m PubSubMessage) error {
    meta,err := metadata.FromContext(ctx)
    if err != nil {
        log.Println(err)
        return err
    }
    log.Printf("publishTime, %s", meta.Timestamp)
    log.Printf("messageId, %s", meta.EventID)
    log.Printf("Type, %s", meta.EventType)
    log.Printf("Resource, %s", meta.Resource)
    return nil
}

今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>