部署Angular 4 IIS错误“403 - 禁止访问:访问被拒绝。”

时间:2017-10-17 19:51:49

标签: angular iis angular-ui-router web-config webdeploy

我正在尝试在IIS服务器上部署Angular 4网站,我收到此错误

“403 - 禁止访问:拒绝访问。”

我正在使用的网址是http://domain/LpPortal2/login/client,而“客户端”不是我的Angular项目中的实际组件,我的登录页面可以知道要在页面上显示哪些徽标和颜色。这是我的app.routes.ts中的代码。

const routes: Routes = [
    {
        path: '',
        redirectTo: 'login',
        pathMatch: 'full'
    },
    {
        path: 'login/:clientCode',
        component: LoginComponent
    },
...

以下是我的web.config,以供您参考:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <system.webServer>
    <modules>
      <remove name="UrlRoutingModule-4.0" />
    <add name="UrlRoutingModule-4.0" 
type="System.Web.Routing.UrlRoutingModule" preCondition="" />
</modules>
    <handlers>
      <remove name="UrlRoutingHandler"/>
    </handlers>
    <rewrite>
      <rules>
        <rule name="Angular" stopProcessing="true">
          <match url=".*" />
          <conditions logicalGrouping="MatchAll">
                        <add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" />
                        <add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true" />
          </conditions>
          <action type="Rewrite" url="/" />
        </rule>
      </rules>
    </rewrite>
     <staticContent>
    <remove fileExtension=".json" />
    <mimeMap fileExtension=".json" mimeType="application/json" />
  </staticContent>
       <defaultDocument>
           <files>
               <remove value="index.php" />
               <remove value="default.aspx" />
               <remove value="iisstart.htm" />
               <remove value="index.htm" />
               <remove value="Default.asp" />
               <remove value="Default.htm" />
            </files>
       </defaultDocument>
  </system.webServer>

感谢您的帮助。

2 个答案:

答案 0 :(得分:1)

所以问题是当我构建我的应用程序时,我需要添加--base-ref / my-domain-name /,如下所示:

ng build -env=dev --base-href /LPPortal2/

另外我需要将重写更新为

<action type="Rewrite" url="/LPPortal2" />

这两件事修复了我的403错误。

答案 1 :(得分:0)

以管理员身份运行IDE以打开Angula文件夹,它将起作用,您可以保存您的工作,因为我遇到同样的问题并运行Visual Studio代码(您可以使用任何类型的您喜欢的IDE)作为管理员解决了问题