”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 为什么我的 Web 应用程序中的请求之间没有维护 Gorilla 会话变量?

为什么我的 Web 应用程序中的请求之间没有维护 Gorilla 会话变量?

发布于2024-11-12
浏览:515

Why are Gorilla Sessions Variables Not Maintained Across Requests in My Web Application?

使用 Gorilla 会话时未维护会话变量

问题

使用 Gorilla Sessions Web 工具包时,会话变量不会跨请求保留。当服务器启动并且用户访问 localhost:8100/ 时,他们将被定向到 login.html,因为会话值不存在。登录后,会话变量将被存储,并且用户将被重定向到 home.html。然而,尽管存在会话变量,打开一个新选项卡并输入 localhost:8100/ 仍会将用户引导至 login.html 而不是 home.html。

解释

中出现了几个问题提供的代码:

  1. 会话路径: 会话路径定义为 /loginSession。这将会话 cookie 的有效性限制到该特定路径。为了使会话能够跨不同路径(例如 localhost:8100/home)工作,您应该将会话路径设置为 /.
  2. 语法错误: 条件 session.Values["email "] == nil 是不正确的。相反,应该使用类型断言来检查会话值是否为字符串: if val, ok := session.Values["email"].(string); ok { // 检查值是否为字符串 }.
  3. 错误处理: 会话保存操作 (sessionNew.Save(req, res)) 不会检查错误。添加错误处理以捕获和处理会话保存期间的任何潜在问题。
  4. SessionHandler 中的会话处理: 应在 中提供静态文件之前获取并验证会话会话处理程序方法。此外,不应在此函数中设置路由器路径,因为它不在此处的范围内。相反,在 main() 中设置路由器路径,并利用单独的函数在处理静态文件请求之前检查有效会话。

相关代码片段(解决问题后):

// Set session options
store.Options = &sessions.Options{
    Domain:   "localhost",
    Path:     "/",
    MaxAge:   3600 * 8, // 8 hours
    HttpOnly: true,
}

// Session handling in `SessionHandler`
func SessionHandler(res http.ResponseWriter, req *http.Request) {
    session, err := store.Get(req, "loginSession")
    if err != nil {
        // Handle the error
    }

    // Check for a valid session
    if session.Values["email"] == nil {
        http.Redirect(res, req, "html/login.html", http.StatusFound)
    } else {
        http.Redirect(res, req, "html/home.html", http.StatusFound)
    }
}
最新教程 更多>
  • 如何在 Golang Web 服务器中流式传输 MP4 视频?
    如何在 Golang Web 服务器中流式传输 MP4 视频?
    GoLang Web 服务器流视频问:Golang Web 服务器配置为服务 HTML、CSS、JavaScript 和图像失败尝试流式传输 MP4 视频。该问题是由于处理大型视频文件而引起的。 Chrome 要求服务器支持超过一定大小的视频的 Range 请求,但提供的代码没有解决这个问题。通过实...
    编程 发布于2024-11-14
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-11-14
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-11-14
  • 如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 识别今天生日的用户使用 MySQL 确定今天是否是用户的生日涉及查找生日匹配的所有行今天的日期。这可以通过一个简单的 MySQL 查询来实现,该查询将存储为 UNIX 时间戳的生日与今天的日期进行比较。以下 SQL 查询将获取今天有生日的所有用户: FROM USERS ...
    编程 发布于2024-11-14
  • CSS 中的“display: table-column”实际上做了什么?
    CSS 中的“display: table-column”实际上做了什么?
    CSS“display: table-column”应该如何工作?在 HTML 中,表格由行组成,每行含有细胞。 CSS 扩展了这个概念,允许设计者定义特定的行和列布局。虽然“display: table-row”和“display: table-cell”很简单,但“display: table-...
    编程 发布于2024-11-14
  • Babel 6 如何以不同的方式处理默认导出?
    Babel 6 如何以不同的方式处理默认导出?
    重大变更:Babel 6 导出默认行为随着 Babel 6 的发布,默认导出的处理方式发生了重大变化。虽然 Babel 之前添加了 module.exports = Exports["default"] 行,但此功能已被删除。此修改需要更改模块导入语法。以前,使用旧语法的代码:v...
    编程 发布于2024-11-14
  • 掌握 Next.js 中的 SSR:如何提升 SEO 和用户体验
    掌握 Next.js 中的 SSR:如何提升 SEO 和用户体验
    SSR(服务器端渲染)是 Next.js 中生成页面的另一种方法。在本文中,我想解释什么是 SSR、它是如何工作的,以及如何在 Next.js 项目的 Page Router 和 App Router 中实现它。 什么是SSR? SSR是一种在用户发出请求后生成静态页面(或预渲染页面...
    编程 发布于2024-11-14
  • 为什么 PHP 5.2 不允许抽象静态类方法?
    为什么 PHP 5.2 不允许抽象静态类方法?
    PHP 5.2 严格模式:为什么不允许抽象静态类方法?在 PHP 5.2 中,启用严格警告可能会触发熟悉的警告:“静态函数不应该是抽象的”。此警告源于 PHP 5.2 中引入的一项更改,该更改不允许抽象静态类方法。原因:历史监督PHP 5.2 最初缺乏后期静态绑定,使抽象静态函数变得无用。由于抽象静...
    编程 发布于2024-11-14
  • 如何为 10 个连续点的每段绘制不同颜色的线?
    如何为 10 个连续点的每段绘制不同颜色的线?
    用不同的颜色绘制一条线问题陈述给定两个列表,latt和lont,目标是绘制一条线,其中每个列表10 个连续点的线段以不同的方式表示color.解决方案线段数量有限如果线段数量较少,例如10个或更少,一个简单的方法就是使用循环以唯一的颜色绘制每个段。import numpy as np import ...
    编程 发布于2024-11-14
  • 如何在 MySQL 中根据计数过滤数据而不使用嵌套 SELECT?
    如何在 MySQL 中根据计数过滤数据而不使用嵌套 SELECT?
    MySQL - 在 WHERE 子句中使用 COUNT(*)用户在尝试使用 WHERE 子句中的 COUNT(*) 函数过滤 MySQL 中的数据时遇到了挑战WHERE 子句。他们寻求一种有效的方法来完成此任务,而不使用嵌套 SELECT 语句,因为它会消耗大量资源。用户提供了以下伪代码来说明他们期...
    编程 发布于2024-11-14
  • 如何在 Python 中按名称访问 SQL 结果列值?
    如何在 Python 中按名称访问 SQL 结果列值?
    在 Python 中按列名称访问 SQL 结果列值处理数据库中的大量列时,依赖于列索引数据检索可能会变得很麻烦。本文通过提供一种在 Python 中使用列名称检索 SQL 结果列值的方法来解决对更直观方法的需求。解决方案:利用 DictCursor Python 的 MySQLdb 模块提供了 Di...
    编程 发布于2024-11-14
  • 除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为的主要场景bool:语句:if、whi...
    编程 发布于2024-11-14
  • 何时使用 Django ORM 的 select_lated 与 prefetch_lated?
    何时使用 Django ORM 的 select_lated 与 prefetch_lated?
    Django ORM 的 select_lated 和 prefetch_lated 之间的区别在 Django ORM 中,select_lated 和 prefetch_lated 方法在管理数据库查询中的关系方面具有不同的用途。select_latedDjango的select_lated方法...
    编程 发布于2024-11-14
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-14
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-11-13

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3