Я разрабатываю одно приложение Angular 5, развернутое в Служба приложений Azure .Моя проблема в том, что когда я пытаюсь получить доступ по прямой ссылке, мое приложение перенаправляет меня на домашнюю страницу.
Это маршруты моего приложения:
// Imports
@NgModule({
declarations: [
// declaratins
],
imports: [
// modules
RouterModule.forRoot([
{ path: 'login', component: LoginComponent },
{ path: 'home', component: HomeComponent, canActivate: [AuthGuard] },
{ path: 'search', component: SearchComponent, canActivate: [AuthGuard] },
{ path: '', redirectTo: 'home', pathMatch: 'full', canActivate: [AuthGuard] }
]),
// modues
],
providers: [
// Imports
],
bootstrap: [AppComponent]
})
export class AppModule { }
Я следовал за Инструкция по развертыванию angular изменение web.config следующим образом:
<configuration>
<system.webServer>
<rewrite>
<rules>
<rule name="Angular Routes" 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="/index.html" />
</rule>
</rules>
</rewrite>
</system.webServer>
</configuration>
Когда я перемещаюсь внутри приложения, я могу правильно просмотреть изменение URL, но если я пытаюсь перейти непосредственно по ссылке, напримерhttps://host/search Я перенаправлю на https://host/home.
Как я могу решить эту проблему?Спасибо