Advent of Code 是程序员测试和提高解决问题能力的一种有趣方式。在解决谜题时,您可能希望直接使用其 URL 自动获取个性化谜题输入,而不是将输入复制到本地可用的文本文件中。但是,尝试使用简单的 HTTP 请求访问输入 URL 会导致以下消息:
谜题输入因用户而异。请登录以获取您的谜题输入。
本文解释了为什么会发生这种情况以及如何使用 Go 编程语言动态正确获取输入。
问题:为什么我们不能直接获取输入?
《代码的降临》要求您登录才能访问您的个性化谜题输入。当您通过浏览器登录时,Advent of Code 会在您的浏览器中设置会话 cookie。此 cookie 用于识别您的帐户并提供您独特的输入。
如果您的 HTTP 请求不包含此会话 cookie,Advent of Code 服务器无法将您识别为登录用户,因此会出现错误消息。
解决方案:在 HTTP 请求中使用 Session Cookie
我们必须在 HTTP 请求中包含会话 cookie 才能获取拼图输入。以下是分步指南:
登录 Advent of Code。
打开浏览器的开发者工具(按 F12 键)并导航到“网络”选项卡。
刷新 Advent of Code 页面并在请求标头中查找 cookie 标头。
- 提取会话 cookie 的值。
注意:对您的会话 cookie 保密非常重要,因为其他人可以访问您的 Advent of Code 帐户(如果他们可以访问它)。
获取输入的代码
下面是一个简单的程序,我们将用它来动态获取拼图输入:
- 设置基本 URL
我们首先定义用于获取输入的基本 URL,并创建一个函数来读取特定日期的输入。
const baseURL = "https://adventofcode.com/2024/day/%s/input" func readInput(day string) { url := fmt.Sprintf(baseURL, day) fmt.Println(url) }
- 创建 HTTP 请求
接下来,我们创建一个 HTTP 请求并包含会话 cookie。
client := &http.Client{} req, err := http.NewRequest("GET", url, nil) if err != nil { fmt.Printf("Error creating HTTP request: %v\n", err) return } // Add the session cookie req.Header.Add("Cookie", "session=[YOUR_SESSION_TOKEN]")
http.NewRequest:为输入 URL 创建 HTTP GET 请求。
req.Header.Add:使用会话令牌向请求添加标头以进行身份验证。 (将 [YOUR_SESSION_TOKEN] 替换为您的实际令牌)。
- 发送请求并处理响应
现在我们发送 HTTP 请求并读取服务器的响应。
const baseURL = "https://adventofcode.com/2024/day/%s/input" func readInput(day string) { url := fmt.Sprintf(baseURL, day) fmt.Println(url) }
client.Do(req):发送 HTTP 请求并存储响应。
defer resp.Body.Close():确保读取后关闭响应正文。
resp.StatusCode:检查 HTTP 状态代码。 200 以外的代码表示错误。
- 读取并打印输入
最后,我们读取响应正文并打印拼图输入。
client := &http.Client{} req, err := http.NewRequest("GET", url, nil) if err != nil { fmt.Printf("Error creating HTTP request: %v\n", err) return } // Add the session cookie req.Header.Add("Cookie", "session=[YOUR_SESSION_TOKEN]")
io.ReadAll(resp.Body):读取响应正文。
string(body):将正文从字节切片转换为字符串,以便于显示。
- 定义主要函数
我们从主函数调用 readInput 函数来获取第一天的输入。
resp, err := client.Do(req) if err != nil { fmt.Printf("Error making HTTP request: %v\n", err) return } defer resp.Body.Close() if resp.StatusCode != http.StatusOK { fmt.Printf("Unexpected HTTP status: %d\n", resp.StatusCode) return }
增强安全性
在我们的代码中对会话令牌进行硬编码并不安全。相反,我们应该使用以下步骤将其存储为环境变量:
- 使用终端导出会话令牌:
body, err := io.ReadAll(resp.Body) if err != nil { fmt.Printf("Error reading response body: %v\n", err) return } fmt.Println(string(body))
- 修改代码以从环境变量中读取会话令牌。 (确保您的导入中包含“os”):
func main() { readInput("1") // Fetches input puzzle for day 1 }
这有助于将会话令牌保留在源代码之外,从而降低意外暴露的风险。
- 完整程序代码
以下是完整的程序供参考:
export AOC_SESSION="[YOUR_SESSION_TOKEN]"
要记住的事情
会话过期:会话令牌可能会在一段时间后过期。如果遇到问题,请重新登录并检索新令牌。
隐私:切勿公开共享您的会话令牌,包括在博客文章或 GitHub 存储库中。
结论
您可以通过在 HTTP 请求中包含会话 cookie 来动态获取您的 Advent of Code 输入。
欢迎在评论部分分享您的技巧或提出问题。快乐编码,祝 2024 年代码降临一切顺利!
以上是在 GO 中动态获取代码输入的出现的详细内容。更多信息请关注PHP中文网其他相关文章!

本文演示了创建模拟和存根进行单元测试。 它强调使用接口,提供模拟实现的示例,并讨论最佳实践,例如保持模拟集中并使用断言库。 文章

OpenSSL,作为广泛应用于安全通信的开源库,提供了加密算法、密钥和证书管理等功能。然而,其历史版本中存在一些已知安全漏洞,其中一些危害极大。本文将重点介绍Debian系统中OpenSSL的常见漏洞及应对措施。DebianOpenSSL已知漏洞:OpenSSL曾出现过多个严重漏洞,例如:心脏出血漏洞(CVE-2014-0160):该漏洞影响OpenSSL1.0.1至1.0.1f以及1.0.2至1.0.2beta版本。攻击者可利用此漏洞未经授权读取服务器上的敏感信息,包括加密密钥等。

本文探讨了GO的仿制药自定义类型约束。 它详细介绍了界面如何定义通用功能的最低类型要求,从而改善了类型的安全性和代码可重复使用性。 本文还讨论了局限性和最佳实践

本文讨论了GO的反思软件包,用于运行时操作代码,对序列化,通用编程等有益。它警告性能成本,例如较慢的执行和更高的内存使用,建议明智的使用和最佳

本文讨论了GO中使用表驱动的测试,该方法使用测试用例表来测试具有多个输入和结果的功能。它突出了诸如提高的可读性,降低重复,可伸缩性,一致性和A

本文使用跟踪工具探讨了GO应用程序执行流。 它讨论了手册和自动仪器技术,比较诸如Jaeger,Zipkin和Opentelemetry之类的工具,并突出显示有效的数据可视化


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

禅工作室 13.0.1
功能强大的PHP集成开发环境

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

Dreamweaver CS6
视觉化网页开发工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具