0

我正在使用 Go 进行编码,并创建了一个文件处理程序和一个打印该文件值的程序。

但是,当我运行它时,应该使用 file.Filename 创建的文件被删除。

不知道是什么原因,即使我尝试调试,也没有答案,即使我google了它,我也没有得到答案。

(64 位 Windows 10 (WSL2))

package main

import (
    "fmt"
    "io"
    "io/ioutil"
    "os"

    "github.com/labstack/echo"
)

func checkErr(err error) {
    if err != nil {
        panic(err)
    }
}

func readFile(filename string) string {
    data, err := ioutil.ReadFile(filename)
    checkErr(err)
    return string(data)
}

func main() {
    e := echo.New()

    e.POST("/file", func(c echo.Context) error {
        file, err := c.FormFile("file")
        checkErr(err)

        src, err := file.Open()
        checkErr(err)
        defer src.Close()

        dst, err := os.Create(file.Filename)
        checkErr(err)
        defer dst.Close()

        _, err = io.Copy(dst, src)
        checkErr(err)

        data := readFile(file.Filename)

        fmt.Println(data)

        return c.String(200, "sd")
    })

    e.Logger.Fatal(e.Start(":5000"))
}

4

1 回答 1

0

我猜你的文件存在,但你写的代码是在更改“刷新到磁盘”之前读取文件。

就在这儿:

defer dst.Close()
 _, err = io.Copy(dst, src)

应该Close()Sync()你的作家尽快,否则你可能会在写完之前阅读。而且由于您的readFile()函数没有重新使用该文件,因此您Sync()最好立即关闭(而不是)它,而不是延迟

试试这个:

 _, err = io.Copy(dst, src)
dst.Close()
if err != nil {
  
}

复制时可能会出错,但我们仍然希望 Close() 文件(如果在os.Create, os.Open,os.OpenFile...

于 2021-01-02T10:12:53.613 回答