Подавать файлы html, css, js по подпути в go mux

Я хочу отобразить скомпилированный угловой проект по подпути (например, http://localhost:3000/app/) с помощью go mux

Он работает, как и ожидалось, без подпути "приложение/"

Но когда я добавляю подпуть с помощью http.StripPrexix("/app/, ..) Обработчик находит и отображает только индексный html, но без всех файлов css, js..

Тестовый код

package main

import (
    "log"
    "net/http"

    "github.com/gorilla/mux"
)

func main() {

    mux := mux.NewRouter()

    fs := http.FileServer(http.Dir("./static/"))

    // Serve static files
    mux.PathPrefix("/app/").Handler(http.StripPrefix("/app/", fs))

    log.Println("Listening...")
    http.ListenAndServe(":3000", mux)
}

index.html

<!doctype html>
<html lang = "en">
<head>
  <meta charset = "utf-8">
  <title>TestProject</title>
  <base href = "/">
  <meta name = "viewport" content = "width=device-width, initial-scale=1">
  <link rel = "icon" type = "image/x-icon" href = "favicon.ico">
<link rel = "stylesheet" href = "styles.3ff695c00d717f2d2a11.css"></head>
<body>
  <h1>Should work</h1>
  <app-root></app-root>
<script src = "runtime.359d5ee4682f20e936e9.js" defer></script><script src = "polyfills.bf99d438b005d57b2b31.js" defer></script><script src = "main.5dd083c1a27b2a7e410a.js" defer></script></body>
</html>

Скачать рабочий проект

Этот проект также включает статические файлы для обслуживания

https://filehorst.de/d/dubJmmsz

Цель

Служите разным проектам разными путями

В продолжение этого вопроса

Что я делаю не так?

Как обслуживать весь проект, например: localhost: 3000/app/

Поскольку вы хотите, чтобы корень вашего SPA был основан на подкаталоге, вам также необходимо внести изменения в HTML/JS. Базовый каталог должен быть переменной, которая будет такой же, как префикс SPA. Я считаю, что это больше проблема дизайна.

Abhijit-K 11.12.2020 12:01
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Введение в CSS
Введение в CSS
CSS является неотъемлемой частью трех основных составляющих front-end веб-разработки.
Как выровнять Div по центру?
Как выровнять Div по центру?
Чтобы выровнять элемент <div>по горизонтали и вертикали с помощью CSS, можно использовать комбинацию свойств и значений CSS. Вот несколько методов,...
Навигация по приложениям React: Исчерпывающее руководство по React Router
Навигация по приложениям React: Исчерпывающее руководство по React Router
React Router стала незаменимой библиотекой для создания одностраничных приложений с навигацией в React. В этой статье блога мы подробно рассмотрим...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
Toor - Ангулярный шаблон для бронирования путешествий
Toor - Ангулярный шаблон для бронирования путешествий
Toor - Travel Booking Angular Template один из лучших Travel & Tour booking template in the world. 30+ валидированных HTML5 страниц, которые помогут...
0
2
596
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

В документах gorilla mux упоминается, как обрабатывать приложения Angular SPA.

Однако, поскольку вы хотите разместить корневой каталог SPA в подкаталоге, вам также необходимо внести изменения в HTML/JS. Базовый каталог должен быть переменной, которая будет такой же, как префикс SPA. Это больше проблема дизайна, я считаю

В противном случае, поскольку ваши остальные файлы, кроме индекса, разрешаются в корне, вам нужно вернуться к «/» для остальных файлов и настроить оба.

router.PathPrefix("/app").Handler(spa)
router.PathPrefix("/").Handler(spa)

Итак, попробуйте, как показано ниже. Я попробовал вашу статическую папку со следующим:

package main

import (
    "log"
    "net/http"
    "os"
    "path/filepath"
    "time"

    "github.com/gorilla/mux"
)

type spaHandler struct {
    staticPath string
    indexPath  string
}

func (h spaHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
    // get the absolute path to prevent directory traversal
    path, err := filepath.Abs(r.URL.Path)
    if err != nil {
        // if we failed to get the absolute path respond with a 400 bad request
        // and stop
        http.Error(w, err.Error(), http.StatusBadRequest)
        return
    }

    // prepend the path with the path to the static directory
    path = filepath.Join(h.staticPath, path)

    // check whether a file exists at the given path
    _, err = os.Stat(path)
    if os.IsNotExist(err) {
        // file does not exist, serve index.html
        http.ServeFile(w, r, filepath.Join(h.staticPath, h.indexPath))
        return
    } else if err != nil {
        // if we got an error (that wasn't that the file doesn't exist) stating the
        // file, return a 500 internal server error and stop
        http.Error(w, err.Error(), http.StatusInternalServerError)
        return
    }

    // otherwise, use http.FileServer to serve the static dir
    http.FileServer(http.Dir(h.staticPath)).ServeHTTP(w, r)
}

func main() {
    router := mux.NewRouter()

    spa := spaHandler{staticPath: "static", indexPath: "index.html"}
    router.PathPrefix("/app").Handler(spa)

    srv := &http.Server{
        Handler: router,
        Addr:    ":3000",
        // Good practice: enforce timeouts for servers you create!
        WriteTimeout: 15 * time.Second,
        ReadTimeout:  15 * time.Second,
    }

    log.Fatal(srv.ListenAndServe())
}

Спасибо .. у меня странное поведение, что он работает только в моем хроме с режимом инкогнито .. но должна быть другая проблема .. не распознал это

Philipp Schartlmüller 11.12.2020 12:01

Возможно, файлы кэшируются. Если ваш SPA загружает остальные файлы из root /, тогда вам нужно с этим справиться ИЛИ лучше, чтобы SPA имел другую базу, например /app

Abhijit-K 11.12.2020 12:29

Я считаю, что вам нужно иметь тот же базовый каталог ссылок в вашем Angular spa. Передний конец разработчик должен сделать это

Abhijit-K 11.12.2020 14:18

да ... пришлось изменить URL-адреса в index.html ... но у меня также есть более крупный проект с активами, загруженными из файла поли-заполнений ... сложная проблема

Philipp Schartlmüller 12.12.2020 00:06

Другие вопросы по теме