欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

React 使用browserHistory项目访问404问题解决

程序员文章站 2024-02-02 23:08:10
最近项目里面用到了react但是发布到iis站点之后,路由地址 刷新访问直接404错误。查阅资料之后发现是iis缺少配置url重写 的问题导致的。下面我们来图形化配置,简单...

最近项目里面用到了react但是发布到iis站点之后,路由地址 刷新访问直接404错误。查阅资料之后发现是iis缺少配置url重写 的问题导致的。下面我们来图形化配置,简单的配置下iis

打开iis使用 web平台安装程序

搜索 url 关键字,您会看到

React 使用browserHistory项目访问404问题解决 

直接安装

关掉iis 重新打开iis在站点右边的控制面板可以看到一个url重写的功能

新增配置如下

React 使用browserHistory项目访问404问题解决

也可以直接 使用我的配置

配置如下 关键节点是: rewrite

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <system.webserver>
    <rewrite>
      <rules>
        <rule name="reactrouter" patternsyntax="ecmascript" stopprocessing="true">
          <match url=".*" />
          <conditions>
            <add input="{http_method}" pattern="^get$" />
            <add input="{http_accept}" pattern="^text/html" />
            <add input="{request_filename}" matchtype="isfile" negate="true" />
          </conditions>
          <action type="rewrite" url="/index.html" />
        </rule>
      </rules>
    </rewrite>
  </system.webserver>
</configuration>

附:其他http-server配置说明 nginx

server {
  server_name react.yahui.wang
  listen 80;

  root /wwwroot/reactdemo/dist;
  index index.html;
  location / {
    try_files $uri /index.html;
  }
}

tomcat

找到conf目录下的web.xml文件,然后加上一句话让他定位回来

<error-page>
  <error-code>404</error-code>
  <location>/index.html</location>
</error-page>

apache

.htaccess 文件配置如下

<ifmodule mod_rewrite.c>

 rewriteengine on
 rewritebase /
 rewriterule ^index\.html$ - [l]
 rewritecond %{request_filename} !-f
 rewritecond %{request_filename} !-d
 rewritecond %{request_filename} !-l
 rewriterule . /index.html [l]

</ifmodule>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。