React 使用browserHistory项目访问404问题解决
程序员文章站
2024-02-02 23:08:10
最近项目里面用到了react但是发布到iis站点之后,路由地址 刷新访问直接404错误。查阅资料之后发现是iis缺少配置url重写 的问题导致的。下面我们来图形化配置,简单...
最近项目里面用到了react但是发布到iis站点之后,路由地址 刷新访问直接404错误。查阅资料之后发现是iis缺少配置url重写 的问题导致的。下面我们来图形化配置,简单的配置下iis
打开iis使用 web平台安装程序
搜索 url
关键字,您会看到
直接安装
关掉iis 重新打开iis在站点右边的控制面板可以看到一个url重写的功能
新增配置如下
也可以直接 使用我的配置
配置如下 关键节点是: 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>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。