golang/go

x/tools/go/analysis/structtag: stricter JSON tag checking

Open

#74,376 创建于 2025年6月25日

在 GitHub 查看
 (6 评论) (11 反应) (0 负责人)Go (133,883 star) (19,008 fork)batch import
AnalysisProposalProposal-Acceptedhelp wanted

描述

Background: This recent article https://blog.trailofbits.com/2025/06/17/unexpected-security-footguns-in-gos-parsers/ describes (among other things) a number of security weaknesses in Go's encoding/json package. Some of these could be mitigated by better static checking of struct field tags; indeed, the author of the post links to two semgrep rules that enforce these checks. Specifically:

  • semgrep -c r/trailofbits.go.unmarshal-tag-is-dash
  • semgrep -c r/trailofbits.go.unmarshal-tag-is-omitempty

Proposal: Let's add these two checks to the structtag analyzer so that users get immediate feedback in their LSP-enabled editor, and whenever they run go vet.

贡献者指南

x/tools/go/analysis/structtag: stricter JSON tag checking · golang/go#74376 | Good First Issue