使用 go 服务启动前端dist包

本文介绍了如何将前端打包的dist包与Go后端服务结合,实现在一个exe中启动并访问单一端口,便于小型项目部署。步骤包括构建dist包、整合静态资源和一键运行服务。

一般的前后端分离,都是前端部署一份,后端部署一份。对于小型的项目,可以将两个合在一起打成一个exe启动,使用一个端口号。步骤如下:

一、构建出来前端的dist包

   按照前端的打包流程输出dist包,基本目录如下:

二、将 dist 包与go服务整合

1、将 dist 文件放到 go 服务中,与 main.go 同目录下;

2、在 go 服务中加载 dist 中的静态文件:

package main

import (
	"github.com/gin-contrib/static"
	"github.com/gin-gonic/gin"
	"io/ioutil"
	_ "net/http/pprof"
	"strings"
)

func main() {
	app := gin.Default()
	//加载静态资源
	app.Use(static.Serve("/", static.LocalFile("dist", true)))
	app.NoRoute(func(c *gin.Context) {
		accept := c.Request.Header.Get("Accept")
		flag := strings.Contains(accept, "text/html")
		if flag {
			content, err := ioutil.ReadFile("dist/index.html")
			if (err) != nil {
				c.Writer.WriteHeader(404)
				c.Writer.WriteString("Not Found")
				return
			}
			c.Writer.WriteHeader(200)
			c.Writer.Header().Add("Accept", "text/html")
			c.Writer.Write((content))
			c.Writer.Flush()
		}
	})
	app.Run("0.0.0.0:8888")
}

三、运行服务

 按照上述步骤操作之后,就可以在编译器中运行了。

直接运行服务,访问 http://localhost:8888/ 就可以访问到前端页面

四、在服务器上运行服务

1、打包构建 go 服务

        go build -o 别名.exe main.go   

2、建一个目录,将 dist 与go生成的exe 放在一个目录下,双击exe即可运行

3、访问 http://localhost:8888/ 就可以访问到前端页面。配置如下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值