分享

beego文件上传服务器,beego 数据处理

 菌心说 2021-09-08

文件上传

在 beego 中你可以很容易的处理文件上传,就是别忘记在你的 form 表单中增加这个属性 enctype=“multipart/form-data”,否则你的浏览器不会传输你的上传文件。

文件上传之后一般是放在系统的内存里面,如果文件的 size 大于设置的缓存内存大小,

那么就放在临时文件中,默认的缓存内存是 64M,你可以通过如下来调整这个缓存内存大小:

beego.MaxMemory = 1<<22

或者在配置文件中通过如下设置:

maxmemory = 1<<22

Beego 提供了两个很方便的方法来处理文件上传:

GetFile(key string) (multipart.File, *multipart.FileHeader, error)

该方法

SaveToFile(fromfile, tofile string) error

该方法是在 GetFile 的基础上实现了快速保存的功能

fromfile 是提交时候的 html 表单中的 name

建立 fileupload 控制器

package controllers

import (

'log'

'github.com/astaxie/beego'

)

type FileUploadController struct {

beego.Controller

}

// 上传文件的页面

func (c * FileUploadController) Get() {

c.TplName = 'fileupload.html'

}

// 上传文件

func (this *FileUploadController) Post() {

// uploadfilename,这是一个key值,对应的是html中input type-'file’的name属性值

f, h, err := this.GetFile('uploadfilename')

if err != nil {

log.Fatal('getfile err', err)

}

// 关闭上传的文件,不然的话会出现临时文件不能清除的情况

defer f.Close()

// 保存位置在 static/upload, 没有文件夹要先创建

this.SaveToFile('uploadfilename', 'static/upload/' + h.Filename)

// html页面

this.TplName = 'fileupload.html'

}

建立fileupload.html页面

文件上传

添加路由

beego.Router('/fileupload', &controllers.FileUploadController{})

项目的结构如下

0fe250c1ed0bdff7f5f6698c13617311.png

浏览器访问

b51f91fc5be5f8c228e60f4712e586be.png

结果

8dab4ed10aff790777acf8f04e2fc15c.png

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多