golang實現檔案上傳並轉存資料庫功能詳解
導讀 | 這篇文章主要為大家詳細介紹了golang實現檔案上傳並轉存資料庫功能,文中示例程式碼介紹的非常詳細,具有一定的參考價值,感興趣的小夥伴們可以參考一下 |
本文例項為大家分享了golang實現檔案上傳並轉存資料庫的具體程式碼,供大家參考,具體內容如下
需求
上傳圖片,且可選擇將圖片儲存到資料中。
一、流程圖
二、步驟
1.上傳檔案介面
獲取檔案,並返回base64string流
程式碼如下(示例):
func setIconPost(c *gin.Context) { //獲取檔案,icon實現對上傳檔案的訪問,header是對上傳檔案資訊的標記 icon,header,err :=c.Request.FormFile("file") dangerous(err) defer icon.Close() //path.Ext是取字尾,Tolower小寫 ext := strings.ToLower(path.Ext(header.Filename)) if header.Size>1024*1024*2{ fmt.Println("檔案過大") } buf := bytes.NewBuffer(nil) //讀取icon的資料存入buf中 if _,err := io.Copy(buf,icon);err != nil{ return } //將base64返回前端 renderData(c, gin.H{ "base64":base64.StdEncoding.EncodeToString(buf.Bytes()), "icon-ext":ext, },nil) }
2.儲存資料
程式碼如下(示例):
func setEntPost(c *gin.Context) { var f Identical bind(c,&f) models.EtpSave(f.Copyright,"copyright") models.EtpSave(f.Introduction,"introduction") models.EtpSave(f.Icon,"icon") models.EtpSave(f.Logo,"logo") models.EtpSave(f.Version,"version") models.EtpSave(f.Belong,"belong") renderMessage(c,nil) }
3.儲存的資料庫操作
type Etp struct { Id int `json:"id"` Ckey string `json:"ckey"` Cval string `json:"cval"` Kind int `json:"kind"` } func EtpSave(cval, ckey string) error { var obj Etp //資料庫是否存在 has,err := DB["rdb"].Table("configs").Where("ckey=?",ckey).Get(&obj) if err != nil{ return err } //不存在 if !has { _, err = DB["rdb"].Table("configs").Where("ckey=?",ckey).Insert(Etp{ Ckey: ckey, Cval: cval, Kind: 1, }) }else{ obj.Cval = cval DB["rdb"].Table("configs").Where("ckey=?",ckey).Cols("cval").Update(&obj) } return err }
4.最佳化
若上傳圖片稍大,在轉存MySQL時會報錯。Data too long for column '......' at row 1
解決方法
將資料庫欄位格式設定為longtext
總結
本需求主要難點在於對於golang核心庫方法的掌握,包括上傳檔案,[]bytes 和 string之間的轉換。
整體框架:
一、接收檔案/圖片介面
二、修改/儲存圖片的介面
三、儲存資料的方法
原文來自:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69955379/viewspace-2909925/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- SpringBoot實現檔案上傳功能詳解Spring Boot
- 自定義檔案上傳功能實現方法
- 【node】檔案上傳功能簡易實現
- 使用Spring Boot實現檔案上傳功能Spring Boot
- AJAX資料互動及檔案上傳功能
- 檔案上傳漏洞思路詳解
- 檔案上傳(解析)漏洞詳解
- 強大靈活的檔案上傳庫:FilePond 詳解
- input 實現檔案上傳,並驗證檔案不大於5M
- ajax實現檔案上傳
- PHP實現單檔案、多檔案上傳 封裝 物件導向實現檔案上傳PHP封裝物件
- SpringCloudGateway閘道器服務實現檔案上傳功能SpringGCCloudGateway
- 教你如何實現c#檔案上傳下載功能C#
- .net web core 如何編碼實現檔案上傳功能Web
- 前端頁面上實現表單提交檔案上傳功能前端
- SpringBoot整合阿里雲OSS物件儲存實現檔案上傳Spring Boot阿里物件
- 【轉】大檔案上傳原理及C#實現方案C#
- Vue實現多檔案上傳功能(前端 + 後端程式碼)Vue前端後端
- 檔案上傳原理和實現
- 使用Spring實現上傳檔案Spring
- Spring mvc檔案上傳實現SpringMVC
- HttpFileCollection 實現多檔案上傳HTTP
- 【轉】kafka-檔案儲存機制詳解Kafka
- golang讀取檔案的json資料流,並解析到struct,儲存到資料庫GolangJSONStruct資料庫
- Simple WPF: S3實現MINIO大檔案上傳並顯示上傳進度S3
- 通過配置檔案(.htaccess)實現檔案上傳
- 使用java的MultipartFile實現layui官網檔案上傳實現全部示例,java檔案上傳JavaUI
- 【Git/Github】向已有倉庫上傳檔案/資料夾Github
- js實現帶上傳進度的檔案上傳JS
- 用PHP實現上傳的ZIP檔案的解壓PHP
- 關於node實現檔案上傳
- PHP實現圖片(檔案)上傳PHP
- Feign實現檔案上傳下載
- Java檔案上傳如何實現呢?Java
- SpringMVC多個檔案上傳實現SpringMVC
- 檔案上傳漏洞&靶場通關詳解
- python 簡易微信實現(註冊登入+資料庫儲存+聊天+GUI+檔案傳輸)Python資料庫GUI
- 如何實現上萬大檔案上傳到伺服器並穩定供種?伺服器