網站首頁 編程語言 正文
前言
最近在寫一個文件上傳的功能,現在來進行整理總結一下go語言如何上傳文件的,本文主要分享一下golang實現文件上傳的流程和具體代碼,供大家參考,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
文件上傳
表單操作
要使表單能夠上傳文件,需要添加form的enctype屬性enctype="multipart/form-data"
,upload.html代碼如下:
<html> <head> <title>上傳文件</title> </head> <body> <form enctype="multipart/form-data" action="/upload" method="post"> <input type="file" name="uploadfile" /> <input type="submit" value="upload" /> </form> </body> </html>
服務端操作
在服務端啟動一個服務,并添加一個handlerFunc并完善相關功能即可:
package main import ( "fmt" "html/template" "io" "log" "net/http" "os" ) func main() { http.HandleFunc("/upload", Upload) if err := http.ListenAndServe("127.0.0.1:9090", nil); err != nil { log.Fatal(err) } } func Upload(w http.ResponseWriter, r *http.Request) { //判斷請求方式 if r.Method == "POST" { //設置內存大小 r.ParseMultipartForm(32 << 20) //獲取上傳文件 file, handler, err := r.FormFile("uploadfile") if err != nil { fmt.Println(err) return } defer file.Close() fmt.Fprintf(w, "%v", handler.Header) //創建上傳目錄 os.Mkdir("./upload", os.ModePerm) //創建上傳文件 f, err := os.Create("./upload/" + handler.Filename) if err != nil { fmt.Println(err) return } defer f.Close() io.Copy(f, file) w.WriteHeader(http.StatusCreated) io.WriteString(w, "Uploaded successfully") } else { //渲染頁面 解析模板文件 tpl, _ := template.ParseFiles("./upload.html") tpl.Execute(w, nil) } }
通過http://127.0.0.1:9090/upload來測試文件上傳。 截圖
選擇文件之后就會在當前目錄下的upload文件夾中看到上傳的文件了。
流程實現
通過上面的示例可以看到,處理文件上傳我們需要先調用FormFile,FormFile返回提供的表單鍵的第一個文件, FormFile函數如下:
func (r *Request) FormFile(key string) (multipart.File, *multipart.FileHeader, error) { if r.MultipartForm == multipartByReader { return nil, nil, errors.New("http: multipart handled by MultipartReader") } if r.MultipartForm == nil { err := r.ParseMultipartForm(defaultMaxMemory) if err != nil { return nil, nil, err } } if r.MultipartForm != nil && r.MultipartForm.File != nil { if fhs := r.MultipartForm.File[key]; len(fhs) > 0 { f, err := fhs[0].Open() return f, fhs[0], err } } return nil, nil, ErrMissingFile }
在FormFile方法中,會調用r.ParseMultipartForm, ParseMultipartForm函數如下:
func (r *Request) ParseMultipartForm(maxMemory int64) error { if r.MultipartForm == multipartByReader { return errors.New("http: multipart handled by MultipartReader") } if r.Form == nil { err := r.ParseForm() if err != nil { return err } } if r.MultipartForm != nil { return nil } mr, err := r.multipartReader(false) if err != nil { return err } f, err := mr.ReadForm(maxMemory) if err != nil { return err } if r.PostForm == nil { r.PostForm = make(url.Values) } for k, v := range f.Value { r.Form[k] = append(r.Form[k], v...) // r.PostForm should also be populated. See Issue 9305. r.PostForm[k] = append(r.PostForm[k], v...) } r.MultipartForm = f return nil }
里面的參數表示maxMemory,調用ParseMultipartForm之后,ParseMultipartForm將請求主體解析為multipart / form-data。解析整個請求體,將上傳的文件部分存儲在maxMemory大小的內存里面,如果文件大小超過了maxMemory,那么剩下的部分將存儲在系統的臨時文件中。我們可以通過r.FormFile獲取上面的文件句柄,然后實例中使用了io.Copy來存儲文件。
小結
文件上傳主要有以下三步:
- 表單中增加enctype屬性
- 服務端調用r.ParseMultipartForm,把上傳的文件存儲在內存和臨時文件中
- 使用r.FormFile獲取文件句柄,然后對文件進行存儲等處理。
原文鏈接:https://juejin.cn/post/7134935002432667679
相關推薦
- 2022-06-28 C#使用RestClient調用Web?API_C#教程
- 2021-10-12 shell實現Fisher–Yates?shuffle洗牌算法介紹_linux shell
- 2023-06-13 C語言函數多個返回值方式_C 語言
- 2022-08-30 C++示例講解初始化列表方法_C 語言
- 2022-07-06 Python?dataframe如何設置index_python
- 2022-04-15 Python爬蟲之requests庫基本介紹_python
- 2022-12-23 iOS之異常與信號使用場景分析_IOS
- 2022-04-22 Element UI 使用表單校驗,正確輸入后,仍然有提示信息
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支