Golang实现图片上传功能的示例代码

 更新时间:2022年05月28日 10:39:07   作者:林台山人  
这篇文章主要和大家分享一下如何利用Golang实现图片上传功能,文中的实现步骤讲解详细,对我们学习有一定的参考价值,需要的可以参考一下

该代码为使用beego实现前后端图片上传。话不多说,直接上代码。

1.前端代码

html代码:

 <div class="col-5 f-l text text-r">背景图(必须):</div>
  <div class="img-box">
    <label>
      <span class="copy-btn Hui-iconfont"></span>
      <input type="file" class="up-file">
    </label>
  </div>
  <div class="img-file col-offset-5">
  </div>

2.JS代码

a.读取图片代码,用于在页面上显示

//读取图片
function loadImg(){
    //获取文件
    var file = $(".up-file")[0].files[0];
    //创建读取文件的对象
    var reader = new FileReader();
    //创建文件读取相关的变量
    var imgFile;
    //为文件读取成功设置事件
    reader.onload=function(e) {
        var e=window.event||e;
        imgFile = e.target.result;
        console.log(imgFile);
        $(".img-file").css({'background':"url("+imgFile+")"});
        isimg();
    };
 
    //正式读取文件
    reader.readAsDataURL(file);
 
}

b.验证是否有图片存在

//是否有图片验证
function isimg(){
    var img= $(".img-file").css('background-image');
 
    if(img.indexOf("data:image")==-1&&img.indexOf(".jpg")==-1){
        $(".mess").html("请添加背景图片").css("opacity",1);
        return false;
    }
    else{
        $(".mess").css("opacity",0).html("");
        return true;
    }
}

c.提交上传,将图片以base64编码的方式传给后端

function addData(){
    var url=$(".img-file").css("background-image");
    var data1=[{"name":"url","value":url}];
    $.ajax({
        url:"/commmethod/method/uploadimg",
        data:data1,
        type:"post",
        ContentType:"application/json",
        success:function(resp){
         ......
        }
    });
}

3.后端代码

func (this *CommMethodController) UploadImg() {
    fileurl := this.GetString("url")
    DataArr := strings.Split(fileurl, ",")
  //去除包装,获取到base64编码
    imgBase64 := DataArr[1][:len(DataArr[1])-2]
  //base64转码
    imgs, err := base64.StdEncoding.DecodeString(imgBase64)
    if err != nil {
        beego.Error("base64 decode error:", err)
    }
    timenow := time.Now().Unix()
    file, err := os.OpenFile("./static/img/"+strconv.FormatInt(timenow, 10)+".jpg", os.O_CREATE|os.O_WRONLY, 0644)
    if err != nil {
        beego.Debug("create file error:", err)
    }
    w := bufio.NewWriter(file) //创建新的 Writer 对象
    _, err3 := w.WriteString(string(imgs))
    if err3 != nil {
        beego.Error("write error:", err3)
    }
    w.Flush()
    defer file.Close()
    imgname := strconv.FormatInt(timenow, 10) + ".jpg"
    t := struct {
        ImageName string `json:"imagename"`
    }{imgname}
    this.Data["json"] = t
    this.ServeJSON()
}
 
/**
*此代码主要用于编辑图片时,删除原有图片
 * 判断文件是否存在  存在返回 true 不存在返回false
 */
func checkFileIsExist(filename string) bool {
    var exist = true
    if _, err := os.Stat(filename); os.IsNotExist(err) {
        exist = false
    }
    return exist
}

到此这篇关于Golang实现图片上传功能的示例代码的文章就介绍到这了,更多相关Golang图片上传内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 利用rpm打包上线部署golang代码的方法教程

    利用rpm打包上线部署golang代码的方法教程

    RPM是RPM Package Manager(RPM软件包管理器)的缩写,这篇文章主要给大家介绍了关于利用rpm打包上线部署golang代码的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2018-01-01
  • Golang项目搭配nginx部署反向代理负载均衡讲解

    Golang项目搭配nginx部署反向代理负载均衡讲解

    这篇文章主要为大家介绍了Golang项目搭配nginx部署正反向代理负载均衡讲解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪
    2022-04-04
  • 超实用的Golang通道指南之轻松实现并发编程

    超实用的Golang通道指南之轻松实现并发编程

    Golang 中的通道是一种高效、安全、灵活的并发机制,用于在并发环境下实现数据的同步和传递。本文主要介绍了如何利用通道轻松实现并发编程,需要的可以参考一下
    2023-04-04
  • Go mod replace使用方法及常见问题分析

    Go mod replace使用方法及常见问题分析

    这篇文章主要为大家介绍了Go mod replace使用方法及常见问题分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • Golang template 包基本原理分析

    Golang template 包基本原理分析

    这篇文章主要为大家介绍了Golang template 包基本原理分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • Go数据结构之HeapMap实现指定Key删除堆

    Go数据结构之HeapMap实现指定Key删除堆

    这篇文章主要给大家介绍了Go语言数据结构之HeapMap实现指定Key删除堆,通过使用Go语言中的container/heap包,我们可以轻松地实现一个优先级队列,文中有详细的代码示例讲解,需要的朋友可以参考下
    2023-07-07
  • 深入理解Go gin框架中Context的Request和Writer对象

    深入理解Go gin框架中Context的Request和Writer对象

    这篇文章主要为大家详细介绍了Go语言的gin框架中Context的Request和Writer对象,文中的示例代码讲解详细,对我们深入了解Go语言有一定的帮助,快跟随小编一起学习一下吧
    2023-04-04
  • Golang中map的深入探究

    Golang中map的深入探究

    Go中Map是一个KV对集合,下面这篇文章主要给大家介绍了关于Golang中map探究的相关资料,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-09-09
  • 浅谈Go1.18中的泛型编程

    浅谈Go1.18中的泛型编程

    本文主要介绍了Go1.18中的泛型编程,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • 一文详解Golang使用接口支持Apply方法的配置模式

    一文详解Golang使用接口支持Apply方法的配置模式

    这篇文章主要为大家介绍了一文详解Golang使用接口支持Apply方法的配置模式,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2024-01-01

最新评论