0

0

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

DDD

DDD

发布时间:2024-12-05 08:54:01

|

996人浏览过

|

来源于dev.to

转载

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

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

  • 提取会话 cookie 的值。

在 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 请求并读取服务器的响应。

Mfkiqpl旅行社旅游线路预订程序
Mfkiqpl旅行社旅游线路预订程序

升级报告:增加动态新闻功能后台添加,删除,编辑,支持UBB代码,支持上传片及文件。 增加我要入团功能散客可以自由选择加入贵社最近要出发的团队。 增加线路置顶功能置顶后的线路永远显示在最前面。 增加同行报价功能管理员在后台添加同行用户,同行用户登录后可查看贵社线路对同行的报价。同行报价在添加线路中一并添加。(感谢网友拽哥提出修改意见) 增加更多线路显示的分页功能方便大型旅行社由于线路过多而引起的部分

下载
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
    }

client.do(req):发送 http 请求并存储响应。

defer resp.body.close():确保读取后关闭响应正文。

resp.statuscode:检查 http 状态代码。 200 以外的代码表示错误。

  • 读取并打印输入

最后,我们读取响应正文并打印拼图输入。

body, err := io.readall(resp.body)
    if err != nil {
        fmt.printf("error reading response body: %v\n", err)
        return
    }

    fmt.println(string(body))

io.readall(resp.body):读取响应正文。

string(body):将正文从字节切片转换为字符串,以便于显示。

  • 定义主要函数

我们从主函数调用 readinput 函数来获取第一天的输入。

func main() {
    readinput("1") // fetches input puzzle for day 1
}

增强安全性

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

  1. 使用终端导出会话令牌:
export aoc_session="[your_session_token]"
  1. 修改代码以从环境变量中读取会话令牌。 (确保您的导入中包含“os”):
req.header.add("cookie", "session="+os.getenv("aoc_session"))

这有助于将会话令牌保留在源代码之外,从而降低意外暴露的风险。

  • 完整程序代码

以下是完整的程序供参考:

package main

import (
    "fmt"
    "io"
    "net/http"
    "os"
)

const baseURL = "https://adventofcode.com/2024/day/%s/input"

func readInput(day string) {
    url := fmt.Sprintf(baseURL, day)

    client := &http.Client{}
    req, err := http.NewRequest("GET", url, nil)
    if err != nil {
        fmt.Printf("Error creating HTTP request: %v\n", err)
        return
    }

    // Use session token from environment variable
    req.Header.Add("Cookie", "session="+os.Getenv("AOC_SESSION"))

    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))
}

func main() {
    readInput("1")
}

要记住的事情

  • 会话过期:会话令牌可能会在一段时间后过期。如果遇到问题,请重新登录并检索新令牌。

  • 隐私:切勿公开共享您的会话令牌,包括在博客文章或 github 存储库中。

结论

您可以通过在 http 请求中包含会话 cookie 来动态获取您的 advent of code 输入。

欢迎在评论部分分享您的技巧或提出问题。快乐编码,祝 2024 年代码降临一切顺利!

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

401

2023.08.02

cookie
cookie

Cookie 是一种在用户计算机上存储小型文本文件的技术,用于在用户与网站进行交互时收集和存储有关用户的信息。当用户访问一个网站时,网站会将一个包含特定信息的 Cookie 文件发送到用户的浏览器,浏览器会将该 Cookie 存储在用户的计算机上。之后,当用户再次访问该网站时,浏览器会向服务器发送 Cookie,服务器可以根据 Cookie 中的信息来识别用户、跟踪用户行为等。

6424

2023.06.30

document.cookie获取不到怎么解决
document.cookie获取不到怎么解决

document.cookie获取不到的解决办法:1、浏览器的隐私设置;2、Same-origin policy;3、HTTPOnly Cookie;4、JavaScript代码错误;5、Cookie不存在或过期等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

346

2023.11.23

阻止所有cookie什么意思
阻止所有cookie什么意思

阻止所有cookie意味着在浏览器中禁止接受和存储网站发送的cookie。阻止所有cookie可能会影响许多网站的使用体验,因为许多网站使用cookie来提供个性化服务、存储用户信息或跟踪用户行为。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

411

2024.02.23

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

88

2025.08.19

session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

315

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

747

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

88

2025.08.19

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

58

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 3万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.5万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号