今天部署react项目到iis服务器,因为使用的是browserrouter,遇到了一些问题,希望可以给遇到相同问题苦恼的人提供一点思路

1.在iis新建名为"wmsapp"应用程序,具体细节可以自行搜索(也有部署到现有程序的子文件夹下,可参考其它文章)
2.准备打包要部署的react项目
3.在react项目中的public文件夹下新建 web.config 文件
内容如下

<?xml version="1.0" encoding="UTF-8"?>
    <configuration>
      <system.webServer>
      <rewrite>
        <rules>
          <rule name="ReactRouter Routes" stopProcessing="true">`在这里插入代码片`
            <match url=".*" />
            <conditions logicalGrouping="MatchAll">
              <add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" />
              <add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true" />
              <add input="{REQUEST_URI}" pattern="^/(docs)" negate="true" />
            </conditions>
            <action type="Rewrite" url="index.html" />
          </rule>
        </rules>
      </rewrite>
    </system.webServer>
    </configuration>

(新建web.config的原因是因为browserrouter需要服务端做配合,感兴趣可以自行搜索)
2.在App.js下的browserrouter节点新增 basename属性,如下图
在这里插入图片描述
3.配置package.json
在这里插入图片描述

在cmd窗口中切到项目根目录下 执行npm run build打包文件 ,然后放到iis应用程序对应的文件夹下

附:
如果有”前端React项目遇到【Uncaught SyntaxError: Unexpected token ‘<’】错误的解决方式“这个问题可以参考此文章

Logo

腾讯云面向开发者汇聚海量精品云计算使用和开发经验,营造开放的云计算技术生态圈。

更多推荐