beego文件上传服务器,beego 数据处理----文件上传-Go语言中文社区

文件上传

在 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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值