首页 > 后端开发 > Golang > 在 GO 中动态获取代码输入的出现

在 GO 中动态获取代码输入的出现

Susan Sarandon
发布: 2024-12-08 10:32:17
原创
194 人浏览过

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 标头。

FETCHING ADVENT OF CODE INPUTS DYNAMICALLY IN GO

  • 提取会话 cookie 的值。

FETCHING ADVENT OF CODE INPUTS DYNAMICALLY IN GO

注意:对您的会话 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
    }
登录后复制

增强安全性

在我们的代码中对会话令牌进行硬编码并不安全。相反,我们应该使用以下步骤将其存储为环境变量:

  1. 使用终端导出会话令牌:
body, err := io.ReadAll(resp.Body)
    if err != nil {
        fmt.Printf("Error reading response body: %v\n", err)
        return
    }

    fmt.Println(string(body))
登录后复制
  1. 修改代码以从环境变量中读取会话令牌。 (确保您的导入中包含“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中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板