首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Apache web服务器不允许我在/about上刷新,但在本地主机上它可以正常工作

Apache web服务器不允许我在/about上刷新,但在本地主机上它可以正常工作
EN

Stack Overflow用户
提问于 2015-08-22 07:24:11
回答 2查看 24.2K关注 0票数 29

我捆绑了我的一个项目,它工作得很好。但是,当在路由/about上单击刷新时,它会显示请求的/about未在此服务器上找到。然而,当我在本地主机上的web服务器上运行时,它在刷新和前进/后退按钮上运行良好。我正在使用react-router进行客户端路由。

这里是客户端路由,但我怀疑这是问题所在

代码语言:javascript
复制
 Router.run(routes, Router.HistoryLocation, function (Handler) {
    React.render(<Handler/>, app);
 });

我的路线就在那里:

代码语言:javascript
复制
let routes = (
<Route>
  <Route name = "App" path="/" handler = {App}>
    <Route name="About" path="/about" handler = {About}/>
    <DefaultRoute name="Projects" handler = {Projects}/>
  </Route>
</Route>
        );

这就是我认为我打破了的

代码语言:javascript
复制
<Directory /var/www/>
                # This directive allows us to have apache2's default start page
                # in /apache2-default/, but still have / go to the right place
Require all granted
                #RedirectMatch ^/$ /apache2-default/
        </Directory>

kkotwal.me.conf:

代码语言:javascript
复制
<VirtualHost *:80>
        # The ServerName directive sets the request scheme, hostname and port that
        # the server uses to identify itself. This is used when creating
        # redirection URLs. In the context of virtual hosts, the ServerName
        # specifies what hostname must appear in the request's Host: header to
        # match this virtual host. For the default virtual host (this file) this
        # value is not decisive as it is used as a last resort host regardless.
        # However, you must set it for any further virtual host explicitly.
        #
        ServerName kkotwal.me
        ServerAlias www.kkotwal.me
        ServerAdmin webmaster@localhost
        DocumentRoot /var/www/kkotwal.me/public_html

        # Available loglevels: trace8, ..., trace1, debug, info, notice, warn,
        # error, crit, alert, emerg.
        # It is also possible to configure the loglevel for particular
        # modules, e.g.
        #LogLevel info ssl:warn

        ErrorLog ${APACHE_LOG_DIR}/error.log
        CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-08-22 07:51:50

嘿,这实际上是一件很常见的事情。

实际情况是,您需要让您的apache服务器忽略任何嵌套路径,而只是将所有请求/*发送到根目录。这样,您的前端javascript就可以在客户端拾取路由并显示正确的视图。

在不同的This服务器中,这有时被称为"HTML5模式“。

在apache中,执行此操作的方法是添加如下规则:

代码语言:javascript
复制
  RewriteEngine On  
  RewriteCond %{DOCUMENT_ROOT}%{REQUEST_URI} -f [OR]
  RewriteCond %{DOCUMENT_ROOT}%{REQUEST_URI} -d
  RewriteRule ^ - [L]

  RewriteRule ^ /index.html [L]

这样做的目的是告诉Apache为任何存在的文件提供服务,但如果它们不存在,则只提供/index.html,而不是404not found。

票数 70
EN

Stack Overflow用户

发布于 2018-02-21 18:24:20

在laravel的情况下,您需要呈现为react文件写入所有路由的相同视图。Laravel路由写成:

=>::get(‘{url}’,function () { return view(‘欢迎’);})->where('url‘.*');

欢迎刀片文件是:

代码语言:javascript
复制
<!doctype html> 
<html lang="{{ app()->getLocale() }}">
    <head>
         <meta charset="utf-8">
         <meta http-equiv="X-UA-Compatible" content="IE=edge">
         <meta name="viewport" content="width=device-width, initial-scale=1">
         <title>Laravel</title>
         <link href="{{asset('css/app.css')}}" rel="stylesheet" type="text/css">
    </head>
    <body>
         <div id="root"></div>
         <script src="{{asset('js/app.js')}}" ></script>
    </body> 
</html>

路由的app.js文件

代码语言:javascript
复制
 <Route>
     <Route name = "App" path="/" handler = {App}>
     <Route name="About" path="/about" handler = {About}/>
     <DefaultRoute name="Projects" handler = {Projects}/>
   </Route> 

因此,每次刷新about路由时,它都会在app.js文件中显示欢迎刀片及其各自的路由

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32150653

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档