前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Go 1.24 - os.Root 锁定工作目录

Go 1.24 - os.Root 锁定工作目录

作者头像
老麦
发布于 2025-05-19 13:31:49
发布于 2025-05-19 13:31:49
3900
代码可运行
举报
文章被收录于专栏:Go与云原生Go与云原生
运行总次数:0
代码可运行

Go 1.24 - os.Root 锁定工作目录

建议点击 查看原文 查看最新内容。

原文链接: https://typonotes.com/posts/2025/05/16/os-root-in-go124/

os.Root 可以锁定工作目录。 使用户无法打开目录外的文件,例如 ../../../etc/passwd 。 可以算一种 安全保护

最重要的是 强制约束用户, 限制用户行为, 检查计划外的使用逻辑 。 免得和煞笔瞎掰扯, 浪费时间。

  1. 使用 root, _ := os.OpenRoot(basedir) 锁定工作目录
  2. 以后的所有操作都要基于 root.Xzzzz() 展开
  3. root.OpenFile(path) 在打开文件之前, 会判断 文件路径 的合法性。 basedir 之外的路径拒绝访问。
    1. path 可以是绝对路径。
    2. path 也可以是基于 basedir 的相对路径。
invalid-file-path.png
invalid-file-path.png

invalid-file-path.png

  1. 美中不足: 不支持 root.ReadFile(path) 这样的快捷 API。 还是需要分成 root.OpenFileio.ReadAll。 有点不习惯了。

所有方法如下, https://pkg.go.dev/os@master#Root

Code Demo

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package main

import (
"bytes"
"io"
"os"
)

// demo
var configdir = "/tmp/go-demo-os-root/configdir"

func main() {

 _ = os.MkdirAll(configdir, 0755)

// os.OpenRoot 打开并锁定目录
 root, err := os.OpenRoot(configdir)
if err != nil {
panic(err)
 }

// root.OpenFile 打开文件, 可以是基于 root 的相对路径
 f, err := root.OpenFile("../main.go", os.O_RDONLY, 0644)
if err != nil {
panic(err)
 }
defer f.Close()

// 不支持 os.ReadFile 这样的快捷方式。
// 使用 io 读取文件
 _, err = io.ReadAll(f)
if err != nil {
panic(err)
 }

// ... omit
}

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2025-05-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 熊猫云原生Go 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Go 1.24 - os.Root 锁定工作目录
    • Code Demo
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档