Rumah >pembangunan bahagian belakang >Golang >Isu menggunakan pengendali aset raungan dengan penghala tersuai
Saya cuba menggunakan pemultipleks tersuai dengan pengendali aset raungan, tetapi apabila cuba mendapatkan apa-apa, saya terus mendapat halaman index.html. Saya menambah pernyataan cetakan di bahagian atas fungsi servehttp muxer, tetapi ini hanya dipanggil sekali apabila favicon.ico diambil pada permulaan program.
Saya mempunyai fail induk berikut:
package main import ( "embed" "fmt" "github.com/nigel2392/router/v3" "github.com/nigel2392/router/v3/request" "github.com/wailsapp/wails/v2" "github.com/wailsapp/wails/v2/pkg/options" "github.com/wailsapp/wails/v2/pkg/options/assetserver" ) var router *router.router = router.newrouter(true) func init() { router.get("/about", func(r *request.request) { fmt.println("about") r.writestring("about") }) } //go:embed all:frontend/dist var assets embed.fs func main() { // create an instance of the app structure app := newapp() // create application with options err := wails.run(&options.app{ title: "new", width: 1024, height: 768, assetserver: &assetserver.options{ assets: assets, handler: router, }, backgroundcolour: &options.rgba{r: 27, g: 38, b: 54, a: 1}, onstartup: app.startup, bind: []interface{}{ app, }, }) if err != nil { println("error:", err.error()) } }
Saya dapat melihat output berikut dalam terminal:
deb | [externalassethandler] loading 'http://localhost:3000/favicon.ico' deb | [externalassethandler] loading 'http://localhost:3000/favicon.ico' failed, using assethandler # print statement at the top of the servehttp function, # prints the requested path, and the available router paths. path: /favicon.ico get /about -> deb | [externalassethandler] loading 'http://localhost:3000/about' to develop in the browser and call your bound go methods from javascript, navigate to: http://localhost:34115 deb | [externalassethandler] loading 'http://localhost:3000/@vite/client' deb | [externalassethandler] loading 'http://localhost:3000/node_modules/vite/dist/client/env.mjs' deb | [externalassethandler] loading 'http://localhost:3000/about' deb | [externalassethandler] loading 'http://localhost:3000/@vite/client' deb | [externalassethandler] loading 'http://localhost:3000/node_modules/vite/dist/client/env.mjs' deb | [externalassethandler] loading 'http://localhost:3000/about'
Apabila cuba mendapatkan halaman yang dipersoalkan untuk ujian, seperti yang diterangkan dalam dokumentasi pelayan aset raungan, saya mendapatkan halaman indeks:
let resp = await fetch("/about") undefined await resp.text() '<!DOCTYPE html>\n<html lang="en">\n<head>\n \x3Cscript type="module" src="/@vite/client">\x3C/script>\n\n <meta charset="UTF-8"/>\n <meta content="width=device-width, initial-scale=1.0" name="viewport"/>\n <meta name="wails-options" content="noautoinject" />\n \x3Cscript src="/wails/ipc.js">\x3C/script>\n \x3Cscript src="/wails/runtime.js">\x3C/script>\n <title>new</title>\n</head>\n<body>\n <h1>Index!</h1>\n <a href="/about">Go To About!</a>\n</body>\n</html>\n'
Mengapa fungsi servehttp tidak dipanggil?
Log menunjukkan bahawa perkhidmatan externalassethandler
。这意味着使用外部前端开发服务器。所有资源请求都会首先转发到外部前端开发服务器。仅当外部前端开发服务器响应 404
或 405
状态代码时,才会使用 assetserver.options
中指定的处理程序。如今,大多数 spa 前端开发服务器都为非资产请求提供 index.html
digunakan. Inilah sebabnya anda melihat tingkah laku ini.
Penyelesaian adalah untuk mengkonfigurasi pelayan pembangunan bahagian hadapan luaran untuk memintas permintaan ini. Untuk vite, ubah suai fail konfigurasi dan tambah kandungan berikut:
export default defineConfig({ server: { proxy: { '/about': { bypass: function () { // Return false to produce a 404 error for the request. return false; }, }, // or for all the requests that start with "/api/" '/api/': { bypass: function () { return false; }, }, }, }, });
Tetapi saya syorkan untuk tidak melakukan ini. Kerana pengendali aset, seperti namanya, menyediakan perkhidmatan untuk aset dinamik. wails mempunyai cara memanggil kaedah bound go sendiri. Anda patut mencubanya.
Rujukan:
frontend:dev:serverurl
位于 wails.json
server.proxy
pilihanerrskipproxy
dalam
Atas ialah kandungan terperinci Isu menggunakan pengendali aset raungan dengan penghala tersuai. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!