Loading [MathJax]/jax/input/TeX/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >聊聊dubbo-go的ConsumerSignFilter

聊聊dubbo-go的ConsumerSignFilter

原创
作者头像
code4it
修改于 2020-07-24 02:04:21
修改于 2020-07-24 02:04:21
37400
代码可运行
举报
文章被收录于专栏:码匠的流水账码匠的流水账
运行总次数:0
代码可运行

本文主要研究一下dubbo-go的ConsumerSignFilter

ConsumerSignFilter

dubbo-go-v1.4.2/filter/filter_impl/auth/consumer_sign.go

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
type ConsumerSignFilter struct {
}
​
func init() {
    extension.SetFilter(constant.CONSUMER_SIGN_FILTER, getConsumerSignFilter)
}
  • ConsumerSignFilter的init方法设置了getConsumerSignFilter

getConsumerSignFilter

dubbo-go-v1.4.2/filter/filter_impl/auth/consumer_sign.go

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
func getConsumerSignFilter() filter.Filter {
    return &ConsumerSignFilter{}
}
  • getConsumerSignFilter创建了ConsumerSignFilter

Invoke

dubbo-go-v1.4.2/filter/filter_impl/auth/consumer_sign.go

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
func (csf *ConsumerSignFilter) Invoke(ctx context.Context, invoker protocol.Invoker, invocation protocol.Invocation) protocol.Result {
    logger.Infof("invoking ConsumerSign filter.")
    url := invoker.GetUrl()err := doAuthWork(&url, func(authenticator filter.Authenticator) error {
        return authenticator.Sign(invocation, &url)
    })
    if err != nil {
        panic(fmt.Sprintf("Sign for invocation %s # %s failed", url.ServiceKey(), invocation.MethodName()))}
    return invoker.Invoke(ctx, invocation)
}
  • Invoke方法会先执行doAuthWork方法,其传递的func执行authenticator.Sign(invocation, &url)

OnResponse

dubbo-go-v1.4.2/filter/filter_impl/auth/consumer_sign.go

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
func (csf *ConsumerSignFilter) OnResponse(ctx context.Context, result protocol.Result, invoker protocol.Invoker, invocation protocol.Invocation) protocol.Result {
    return result
}
  • OnResponse方法直接返回result

doAuthWork

filter/filter_impl/auth/default_authenticator.go

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
func doAuthWork(url *common.URL, do func(filter.Authenticator) error) error {shouldAuth := url.GetParamBool(constant.SERVICE_AUTH_KEY, false)
    if shouldAuth {
        authenticator := extension.GetAuthenticator(url.GetParam(constant.AUTHENTICATOR_KEY, constant.DEFAULT_AUTHENTICATOR))
        return do(authenticator)
    }
    return nil
}
  • doAuthWork方法先从url读取constant.SERVICE_AUTH_KEY判断是否需要auth,需要的话,则获取authenticator,执行do(authenticator)

Sign

dubbo-go-v1.4.2/filter/filter_impl/auth/default_authenticator.go

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
func (authenticator *DefaultAuthenticator) Sign(invocation protocol.Invocation, url *common.URL) error {
    currentTimeMillis := strconv.Itoa(int(time.Now().Unix() * 1000))consumer := url.GetParam(constant.APPLICATION_KEY, "")
    accessKeyPair, err := getAccessKeyPair(invocation, url)
    if err != nil {
        return errors.New("get accesskey pair failed, cause: " + err.Error())
    }
    inv := invocation.(*invocation_impl.RPCInvocation)
    signature, err := getSignature(url, invocation, accessKeyPair.SecretKey, currentTimeMillis)
    if err != nil {
        return err
    }
    inv.SetAttachments(constant.REQUEST_SIGNATURE_KEY, signature)
    inv.SetAttachments(constant.REQUEST_TIMESTAMP_KEY, currentTimeMillis)
    inv.SetAttachments(constant.AK_KEY, accessKeyPair.AccessKey)
    inv.SetAttachments(constant.CONSUMER, consumer)
    return nil
}
​
func getAccessKeyPair(invocation protocol.Invocation, url *common.URL) (*filter.AccessKeyPair, error) {
    accesskeyStorage := extension.GetAccesskeyStorages(url.GetParam(constant.ACCESS_KEY_STORAGE_KEY, constant.DEFAULT_ACCESS_KEY_STORAGE))
    accessKeyPair := accesskeyStorage.GetAccessKeyPair(invocation, url)
    if accessKeyPair == nil || IsEmpty(accessKeyPair.AccessKey, false) || IsEmpty(accessKeyPair.SecretKey, true) {
        return nil, errors.New("accessKeyId or secretAccessKey not found")
    } else {
        return accessKeyPair, nil
    }
}
  • Sign方法通过getAccessKeyPair从accesskeyStorage.GetAccessKeyPair获取accessKeyPair,然后通过getSignature计算signature,没有err则设置到attachment中

小结

ConsumerSignFilter的Invoke方法会先执行doAuthWork方法,其传递的func执行authenticator.Sign(invocation, &url)

doc

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
聊聊dubbo-go的ConsumerSignFilter
dubbo-go-v1.4.2/filter/filter_impl/auth/consumer_sign.go
code4it
2020/07/29
4280
聊聊dubbo-go的ProviderAuthFilter
dubbo-go-v1.4.2/filter/filter_impl/auth/provider_auth.go
code4it
2020/07/24
2940
聊聊dubbo-go的ProviderAuthFilter
聊聊dubbo-go的ProviderAuthFilter
dubbo-go-v1.4.2/filter/filter_impl/auth/provider_auth.go
code4it
2020/07/29
3530
聊聊dubbo-go的DubboInvoker
dubbo-go-v1.4.2/protocol/dubbo/dubbo_invoker.go
code4it
2020/07/26
4460
聊聊dubbo-go的DubboInvoker
聊聊dubbo-go的TpsLimitFilter
dubbo-go-v1.4.2/filter/filter_impl/tps_limit_filter.go
code4it
2020/07/18
3280
聊聊dubbo-go的TpsLimitFilter
聊聊dubbo-go的AccessLogFilter
dubbo-go-v1.4.2/filter/filter_impl/access_log_filter.go
code4it
2020/07/14
3050
聊聊dubbo-go的AccessLogFilter
聊聊dubbo-go的gracefulShutdownFilter
dubbo-go-v1.4.2/filter/filter_impl/graceful_shutdown_filter.go
code4it
2020/07/16
3470
聊聊dubbo-go的gracefulShutdownFilter
聊聊dubbo-go的TokenFilter
dubbo-go-v1.4.2/filter/filter_impl/token_filter.go
code4it
2020/07/19
2890
聊聊dubbo-go的TokenFilter
聊聊dubbo-go的tracingFilter
dubbo-go-v1.4.2/filter/filter_impl/tracing_filter.go
code4it
2020/07/22
3440
聊聊dubbo-go的tracingFilter
聊聊dubbo-go的failfastCluster
dubbo-go-v1.4.2/cluster/cluster_impl/failfast_cluster.go
code4it
2020/08/06
2930
聊聊dubbo-go的failfastCluster
聊聊dubbo-go的HystrixFilter
dubbo-go-v1.4.2/filter/filter_impl/hystrix_filter.go
code4it
2020/07/20
3710
聊聊dubbo-go的HystrixFilter
聊聊dubbo-go的failsafeCluster
dubbo-go-v1.4.2/cluster/cluster_impl/failsafe_cluster.go
code4it
2020/08/08
3410
聊聊dubbo-go的failsafeCluster
聊聊dubbo-go的EchoFilter
dubbo-go-v1.4.2/filter/filter_impl/echo_filter.go
code4it
2020/07/15
3870
聊聊dubbo-go的EchoFilter
聊聊dubbo-go的failbackCluster
dubbo-go-v1.4.2/cluster/cluster_impl/failback_cluster.go
code4it
2020/08/05
2820
聊聊dubbo-go的failbackCluster
聊聊dubbo-go的GenericFilter
dubbo-go-v1.4.2/filter/filter_impl/generic_filter.go
code4it
2020/07/17
5900
聊聊dubbo-go的GenericFilter
聊聊dubbo-go的PrometheusReporter
dubbo-go-v1.4.2/metrics/prometheus/reporter.go
code4it
2020/07/31
4900
聊聊dubbo-go的PrometheusReporter
聊聊dubbo-go的metricsFilter
dubbo-go-v1.4.2/filter/filter_impl/metrics_filter.go
code4it
2020/07/21
5630
聊聊dubbo-go的metricsFilter
聊聊dubbo-go的broadcastCluster
dubbo-go-v1.4.2/cluster/cluster_impl/broadcast_cluster.go
code4it
2020/08/11
3620
聊聊dubbo-go的registryAwareCluster
dubbo-go-v1.4.2/cluster/cluster_impl/registry_aware_cluster.go
code4it
2020/08/09
3270
聊聊dubbo-go的registryAwareCluster
聊聊dubbo-go的forkingCluster
dubbo-go-v1.4.2/cluster/cluster_impl/forking_cluster.go
code4it
2020/08/11
2150
相关推荐
聊聊dubbo-go的ConsumerSignFilter
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验