静态文件的上传代码

  • 静态文件上传

    • 前端代码

      如果form表单中牵涉到文件上传,在form表单中就需要添加一个属性enctype="multipart/form-data"不然上传就是假上传,后台不能获取到上传的文件。<form>修改如下:

        <form method="post" action="/addArticle" enctype="multipart/form-data">
            <input type="file" class="input_file"  name="uploadname">

       

    • 后台代码修改

      后台接收上传文件有两个函数可以用。

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

      作用 是获取前端传递过来的文件。

      参数 是input标签中的name值

      返回值 有三个,一个是文件流(就是我们打开文件返回的内容),第二个是文件相关信息,包括文件头,文件大小,文件名字等,第三个是错误信息。示例代码如下:

          file,head,err := this.GetFile("uploadname")
            if err != nil{
                beego.Info("上传图片错误,请重新添加!")
                this.TplName = "add.html"
                return
            }

      SaveToFile(fromfile, tofile string) error

      作用直接保存前端出过来的文件。

      参数 有两个参数,第一个参数是前端<input>标签的name属性值,第二个参数是文件在服务器端存储的位置。注意:这个位置字符串在前面需要加一个.

      返回值是错误信息。示例代码如下:

        err := this.SaveToFile("uploadname","./static/img/1.jpg")
        if err != nil{
                beego.Info("上传图片错误,请重新添加!")
                this.TplName = "add.html"
                return
            }

       

    • 在我们开发过程中,如果后台接收文件并存储需要做以下几种判断

      文件格式判断

      我们通过GetFile可以获取到文件名,然后通过path包,可以分离出文件的后缀,即文件格式,把你需要的文件格式过滤出来,不需要的返回即可。我们根据文件名获取文件后缀,代码如下:

        //文件格式判断
            fileExt := path.Ext(head.Filename)
            if fileExt != ".jpg" && fileExt != ".png" && fileExt != ".jpeg"{
                beego.Info("上传图片格式不正确,请重新添加!")
                this.TplName = "add.html"
                return
            }

      文件大小的判断

      我们获取文件之后,在存储之前,文件流一般是在内存中,所以文件不易过大,我们在这里做一个文件大小的判断。代码如下:

        //文件大小判断
            if head.Size > 5000000{
                beego.Info("上传图片太大,请重新添加!")
                this.TplName = "add.html"
                return
            }

      避免文件重名

      获取文件之后我们要把文件存储到服务器上,但是用户可能会上传同名的文件,如果文件同名的话,后来上传的文件就把之前上传的文件给覆盖了,所以我们要给上传的文件重新确定一个名字。这里我们以上传文件时的时间作为上传文件的文件名。默认的时间格式和我们常见的时间格式不一样,所以这里我们需要对事件做一个格式化。格式化字符串为"2006-01-02-15-04-05(规定的必须是这个,方便记忆可以用6-1-2-3-4-5来记)代码如下:

        fileName := time.Now().Format("2006-01-02-15-04-05")
        //存储
        this.SaveToFile("uploadname","./static/img/"+fileName+fileExt)

       

  • 保存数据到数据库

    这里是数据的插入操作,我们不做详细解释,直接看代码:

       //插入数据库
          //获取orm对象
          o := orm.NewOrm()
          //获取要插入的对象
          var article models.Article
          //给对象赋值
          article.ArtiName = articleName
          article.Acontent = content
          //这一步需要注意,我们存储的图片是图片地址,没有 .
          article.Aimg = "/static/img/"+fileName+fileExt
          //插入
          o.Insert(&article)

     

  • 返回视图

    如果没有视图,先返回一句话,代码如下:

    
      this.Ctx.WriteString("添加成功")

     

  • 完整代码如下:

     //获取数据
          articleName := this.GetString("articleName")
          content := this.GetString("content")
      ​
      //数据校验
          if articleName == "" || content == ""{
              beego.Info("添加文章数据不完整,请重新输入")
              this.TplName = "add.html"
              return
          }
      ​
      //获取上传图片
          file,head,err := this.GetFile("uploadname")
          defer file.Close()
      ​
          if err != nil{
              beego.Info("上传图片错误,请重新添加!")
              this.TplName = "add.html"
              return
          }
          //文件格式判断
          fileExt := path.Ext(head.Filename)
          if fileExt != ".jpg" && fileExt != ".png" && fileExt != ".jpeg"{
              beego.Info("上传图片格式不正确,请重新添加!")
              this.TplName = "add.html"
              return
          }
      ​
          //文件大小判断
          if head.Size > 5000000{
              beego.Info("上传图片太大,请重新添加!")
              this.TplName = "add.html"
              return
          }
      ​
          //避免文件重名
          fileName := time.Now().Format("2006-01-02-15-04-05")
          this.SaveToFile("uploadname","./static/img/"+fileName+fileExt)
      ​
      //插入数据库
          //获取orm对象
          o := orm.NewOrm()
          //获取要插入的对象
          var article models.Article
          //给对象赋值
          article.ArtiName = articleName
          article.Acontent = content
          //这一步需要注意,我们存储的图片是图片地址,没有.
          article.Aimg = "/static/img/"+fileName+fileExt
          //插入
          o.Insert(&article)
      ​
      //返回视图
          this.Ctx.WriteString("添加成功")

     

时间显示上可能会出问题,Mysql的自动时间戳会比我们的真实时间晚八个小时。原因是因为我们没有设置Mysql的时间戳,所以Mysql的自动添加时间是以美国东部时间为准,这里我们需要改成北京时间:代码如下

  mysql > SET time_zone = '+8:00';   # 此为北京时,我们所在东8区
  mysql> flush privileges;   # 立即生效
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 当出现element文件上传nginx静态文件post请求405问题时,这通常是由于nginx配置不正确导致的。405错误表示服务器禁止使用POST方法请求该URL。解决此问题的方法如下: 1. 检查nginx配置文件中的location段,确保已经正确配置了POST请求。比如,确保在location段内使用了`allow_methods`指令来允许POST方法。示例如下: ``` location / { allow_methods GET POST; } ``` 2. 检查文件上传路径是否正确设置。上传文件时,nginx需要指定正确的文件上传路径,并且该路径需要有相应的写权限。确保路径正确,并且nginx用户(通常是www-data)拥有该路径的写权限。 3. 检查nginx是否加载了必要的模块。如果没有加载所需的模块,nginx可能无法处理POST请求。确保在nginx的配置文件中加载了`ngx_http_upload_module`模块,该模块负责处理文件上传请求。 4. 检查nginx是否正确处理了静态文件请求。如果nginx在处理静态文件时出错,可能会导致405错误。可以通过浏览器直接访问静态文件URL,以确保nginx可以正确返回静态文件。 5. 检查后端服务器是否正确处理了POST请求。如果nginx配置正确,但是后端服务器无法处理POST请求,也会导致405错误。可以使用其他工具或编程语言测试后端服务器是否可以正确处理POST请求。 综上所述,通过检查nginx的配置文件和相关权限,确保路径和模块正确配置,检查后端服务器的处理能力,应该能够解决element文件上传nginx静态文件post请求405问题。 ### 回答2: 当使用Nginx作为静态文件服务器时,出现element文件上传时POST请求返回405错误的问题,可能是由于Nginx配置不正确导致的。 首先要确保Nginx支持POST请求,可以在Nginx的配置文件中添加以下内容: ``` location / { try_files $uri $uri/ /index.html; if ($request_method = POST) { return 405; } } ``` 上述配置中,通过try_files指令将请求转发给index.html,同时对POST请求返回405错误。 另外,还需要确保Nginx支持文件上传,需要在Nginx配置文件中添加以下内容: ``` client_max_body_size 100m; ``` 上述配置可以通过设置可以上传文件大小,这里设置为100m。 在以上配置添加完毕后,重新启动Nginx服务,然后再次尝试element文件上传的POST请求,应该可以成功上传文件了。 如果还出现405错误,可以检查以下几点: 1. 确保Nginx的配置文件正确加载并且重新启动了Nginx服务。 2. 检查element文件上传的POST请求是否正确,可以使用浏览器的开发者工具查看请求的URL和请求方式是否正确。 3. 检查服务器端代码,确保能够正确接收并处理上传文件。 总结:要解决element文件上传时Nginx静态文件POST请求返回405错误的问题,需要正确配置Nginx支持POST请求和文件上传,并确保相关代码的正确性。 ### 回答3: 当使用Nginx作为静态文件服务器时,使用element组件进行文件上传时可能面临405问题。405是HTTP状态码之一,表示请求的方法不被服务器支持。 造成这个问题的可能原因是,Nginx默认情况下只允许GET和HEAD方法。而文件上传通常使用POST方法来传输文件。因此,当element组件发送POST请求时,Nginx会拒绝该请求并返回405状态码。 要解决这个问题,可以通过在Nginx的配置文件中添加额外的配置来允许POST方法。 首先,在Nginx的配置文件中找到相关的location配置,该配置指定了要处理文件上传的URL路径。 然后,在该location的配置中添加如下配置项: ``` location /upload { if ($request_method = POST) { # 处理文件上传的逻辑 } # 其他配置项 } ``` 上述配置中,我们使用if语句来判断请求的方法是否为POST。如果是POST方法,我们可以在其中添加处理文件上传的逻辑。 注意,这只是一个示例配置,并不代表完整的配置文件,你需要根据自己的实际情况进行调整。 完成以上配置后,保存并重启Nginx服务。此时,element组件发送的POST请求将被Nginx正确处理,不再返回405状态码,解决了文件上传的问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值