Heroku与React-Router和Create-React-App

问题描述 投票:0回答:1

这个问题已经被问过多次了,我一直在阅读类似的问题,并试图解决这个问题而没有运气,所以我发布了代码,看一双新鲜的眼睛是否可以帮助解决我的问题。

我的应用程序在Heroku上可以正常工作,但是在刷新页面或直接导航到非主页的路线时(例如myapp.com/whatever)。 我收到未找到的404。

我的路由在本地工作,因此我知道它与我的应用设置和Heroku有关。 我有一个带有create-react-app客户端和Express服务器后端的MERN应用程序

文件夹结构

client/
server/
package.json
static.json

static.json

{
    "root": "client/build/",
    "clean_urls": false,
    "routes": {
        "/**": "index.html"
    }
}

Router.js

<BrowserRouter basename="/">
    <Fragment>
        <Switch>
            <Route exact path="/" component={Home} />
            <Route extact path="/login" component={Login} />
            <PrivateRoute path="/dashboard" component={Dashboard} />
        </Switch>
    </Fragment>
</BrowserRouter>

Server.js

if (process.env.NODE_ENV === 'production') {
    app.use(express.static('client/build'))

    app.get('*', (req, res) => {
        res.sendFile(path.resolve(__dirname, '../client', 'build', 'index.html'));
    });
}

有人看到我想念的东西吗?

reactjs heroku react-router-v4 react-router-dom
1个回答
0
投票

我在这个问题上也花了很多时间。 如果我没记错的话,您必须在package.json文件中创建一个称为“首页”的新属性。 您可以将其放置在package.json中对象的最后。 该属性的值将是您托管应用程序的URL。 所以对于我的例子是:

{
  "name": "react_movie_db_course",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "react": "^16.4.2",
    "react-dom": "^16.4.2",
    "react-fontawesome": "^1.6.1",
    "react-router-dom": "^4.3.1",
    "react-scripts": "1.1.4"
  },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test --env=jsdom",
    "eject": "react-scripts eject"
  },
   "homepage" : "http://www.weibenfalk.com/react_rmdb/"
}

如果您不是从子文件夹开始的话,也不要认为您在组件上需要基本名称。

甚至可能是这样,您也必须在服务器上编辑.htaccess文件。 这就是我的.htaccess文件的样子。

RewriteEngine On
RewriteCond %{DOCUMENT_ROOT}%{REQUEST_URI} -f [OR]
RewriteCond %{DOCUMENT_ROOT}%{REQUEST_URI} -d
RewriteRule ^ - [L]

# Fallback all other routes to index.html
RewriteRule ^ /react_rmdb/index.html [L]

我还知道,路由可能要花24个小时才能开始在服务器上正常工作。

© www.soinside.com 2019 - 2024. All rights reserved.