0

0

使用 Angular 前端和 Go 后端在 Heroku 上部署应用程序

霞舞

霞舞

发布时间:2025-11-16 13:19:01

|

240人浏览过

|

来源于php中文网

原创

使用 angular 前端和 go 后端在 heroku 上部署应用程序

本文档旨在帮助开发者解决在使用 Angular 前端和 Go 后端在 Heroku 上部署应用程序时,静态资源访问路径不正确的问题。通过修改 Go 后端的文件服务目录配置,确保应用程序能够从根路径正确加载 Angular 应用。本文将提供详细的配置方法和原理说明,助你成功部署应用。

问题描述

在使用 Angular 作为前端,Go 作为后端,并将应用程序部署到 Heroku 上时,可能会遇到 Angular 应用没有部署到根目录的问题。例如,期望应用程序在 foobar.herokuapp.com 访问,但实际却只能在 foobar.herokuapp.com/app/#/ 访问。这通常是由于 Go 后端的文件服务配置不正确导致的。

解决方案

要解决这个问题,需要修改 Go 后端代码中文件服务器的目录配置。关键在于指定正确的静态资源(Angular 应用)的根目录。

修改 server.go 文件

在你的 server.go 文件中,找到处理静态资源的部分。通常,这部分代码使用了 http.FileServer 函数。你需要修改传递给 http.Dir 函数的参数,以指定正确的目录。

立即学习前端免费学习笔记(深入)”;

原始代码可能如下所示:

http.Handle("/", logHandler(http.FileServer(http.Dir("../app/"))))

正确的配置应该是:

芝麻乐开源众筹cms系统
芝麻乐开源众筹cms系统

芝麻乐开源众筹系统采用php+mysql开发,基于MVC开发,适用于各类互联网金融公司使用,程序具备模板分离技术,您可以根据您的需要进行应用扩展来达到更加强大功能。前端使用pintuer、jquery、layer等....系统易于使用和扩展简单的安装和升级向导多重业务逻辑判断,预防出现bug后台图表数据方式,一目了然后台包含但不限于以下功能:用户认证角色管理节点管理管理员管理上传配置支付配置短信平

下载
http.Handle("/", logHandler(http.FileServer(http.Dir("app/"))))

或者,使用绝对路径:

http.Handle("/", logHandler(http.FileServer(http.Dir("/app/app/"))))

代码解释:

  • http.Handle("/", ...):这行代码将根路径 / 映射到后面的处理器
  • http.FileServer(http.Dir("app/")):这行代码创建了一个文件服务器,它将服务于指定目录下的文件。http.Dir("app/") 指定了文件服务器的根目录为 app/。
  • logHandler(...):这是一个自定义的日志处理器,用于记录请求信息。

原理解释

在 Heroku 上,当你执行 Procfile 命令时,项目根目录会被设置为工作目录,其绝对路径为 /app。因此,../app/ 会将目录向上移动一级,回到项目根目录,而 app/ 则直接指向项目根目录下的 app 文件夹,这正是 Angular 应用所在的目录。

完整示例

以下是一个完整的 server.go 文件的示例:

package main

import (
    "github.com/gorilla/handlers"
    "log"
    "net/http"
    "os"
)

func main() {
    log.Println("Starting Server")
    http.Handle("/", logHandler(http.FileServer(http.Dir("app/"))))

    log.Println("Listening...")
    panic(http.ListenAndServe(":"+os.Getenv("PORT"), nil))
}

func logHandler(h http.Handler) http.Handler {
    return handlers.LoggingHandler(os.Stdout, h)
}

注意事项

  • 目录结构: 确保你的 Angular 应用确实位于项目根目录下的 app 文件夹中。
  • Procfile: 确保你的 Procfile 文件配置正确,通常包含类似 web: server 的内容,其中 server 是你的 Go 可执行文件的名称。
  • Heroku 部署: 每次修改代码后,都需要重新部署到 Heroku,以使更改生效。
  • 缓存问题: 浏览器可能会缓存旧版本的静态资源。在部署新版本后,尝试清除浏览器缓存或使用无痕模式访问。

总结

通过修改 Go 后端的文件服务目录配置,可以轻松解决 Angular 应用部署到 Heroku 后访问路径不正确的问题。理解 Heroku 的工作目录原理以及 http.FileServer 的用法是解决此类问题的关键。确保你的目录结构正确,并遵循上述步骤,即可成功部署你的 Angular 和 Go 应用程序。

相关专题

更多
http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

324

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

401

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

1561

2024.03.12

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1926

2024.08.16

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

78

2026.01.09

c++框架学习教程汇总
c++框架学习教程汇总

本专题整合了c++框架学习教程汇总,阅读专题下面的文章了解更多详细内容。

46

2026.01.09

学python好用的网站推荐
学python好用的网站推荐

本专题整合了python学习教程汇总,阅读专题下面的文章了解更多详细内容。

121

2026.01.09

学python网站汇总
学python网站汇总

本专题整合了学python网站汇总,阅读专题下面的文章了解更多详细内容。

12

2026.01.09

python学习网站
python学习网站

本专题整合了python学习相关推荐汇总,阅读专题下面的文章了解更多详细内容。

15

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Node.js 教程
Node.js 教程

共57课时 | 8.4万人学习

CSS3 教程
CSS3 教程

共18课时 | 4.4万人学习

Vue 教程
Vue 教程

共42课时 | 6.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号