Gin显示项目本地图片给前端

需求与背景

最近开发项目中遇到了一个问题,就是后端的一张图片,需要传递给前端,前端拿到后展示给用户

解决过程

最初想的是,查找gin框架有关图片上传的内容,后面才反应过来,图片上传是把不在项目中的图片给上传到项目中,而我们的需求是,把项目本地的图片展示给前端。这是两个不同的问题,图片文件上传在先,图片展示给前端在后。 我们的需求是在图片已经上传的基础上完成的,因为图片已经在项目中了。

方式一:

 

func main() {
	r := gin.Default()
	r.GET("upload", func(c *gin.Context) {
		c.File("test.png")
	})
	r.Run(":8088") // 监听并在 0.0.0.0:8080 上启动服务
}

然后访问localhost:8088/upload,有时候结果直接把图片给下载下来了,我们想要的只是显示出来,并不需要下载。有时候居然可以正常显示,不清楚咋回事。

方式二:

package main

import (
	"github.com/gin-gonic/gin"
	"io/ioutil"
)

func main() {
	r := gin.Default()
	r.GET("getImage", func(c *gin.Context) {
		getImage(c)
	})
	r.Run(":8088") // 监听并在 0.0.0.0:8088 上启动服务
}

func getImage(c *gin.Context){ //显示图片的方法
	imageName := c.Query("imageName") //截取get请求参数,也就是图片的路径,可是使用绝对路径,也可使用相对路径
	file, _ := ioutil.ReadFile(imageName) //把要显示的图片读取到变量中
	c.Writer.WriteString(string(file)) //关键一步,写给前端
}

我们访问localhost:8088/getImage?imageName=./test.png,然后也是可以成功访问的。

我们现在是在本地调试,当项目在服务端跑起来后,前端是可以直接通过 服务器地址:8088/getImage?imageName=./test.png 来拿到图片的,从而展示给用户。

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值