Angular 2 azure deploy refresh error: ресурс, который вы ищете, удален, изменилось его имя или временно недоступно

У меня есть приложение Angular 2 rc-2 с базовой маршрутизацией. Пути /path1 - это путь по умолчанию и /path2. Домашний путь / перенаправляется на /path1. Когда я запускаю его локально (Lite-сервер), все работает нормально. Мне удалось развернуть это приложение в веб-приложении Azure. Приложение работает ОК, но если я обновляю страницу, когда я в /path1 или /path2, я получаю эту ошибку: The resource you are looking for has been removed, had its name changed, or is temporarily unavailable.

Возможным подходом является реализация перезаписи URL. Я добавил файл web.config в свой проект

<?xml version="1.0" encoding="UTF-8"?>

<configuration>
    <system.webServer>
        <rewrite>
        <rules>
        <clear />

         <!-- check if its path1 url and navigate to default page -->
        <rule name="Path1 Request" enabled="true" stopProcessing="true">
        <match url="^path1" />
        <action type="Redirect" url="/index.html" logRewrittenUrl="true" />
        </rule>

         <!-- check if its path2 url and navigate to default page -->
        <rule name="Path2 Request" enabled="true" stopProcessing="true">
        <match url="^path2" />
        <action type="Redirect" url="/index.html" logRewrittenUrl="true" />
        </rule>

         </rules>
        </rewrite>
    </system.webServer>
</configuration>

В этом случае я могу сделать обновление без получения этого сообщения об ошибке. Но любое обновление перенаправляет меня на URL-адрес по умолчанию. Я обновляюсь от /path2 и перенаправляет меня на /path1 (по умолчанию url).

Любые мысли улучшить обновление?:)

Ответы

Ответ 1

Вам нужно добавить файл web.config в корневое приложение Angular2. Как работают серверы Azure (IIS Server).

Я использую webpack, поэтому я помещаю его в папку src. Не забудьте скопировать его в папку dist при развертывании. Я использовал CopyWebpackPlugin, чтобы настроить мой веб-пакет, чтобы скопировать его.

Это файл web.config:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <system.webServer>
        <rewrite>
            <rules>
                <clear />
                <rule name="Redirect to https" stopProcessing="true">
                    <match url="(.*)" />
                    <conditions>
                        <add input="{HTTPS}" pattern="off" ignoreCase="true" />
                    </conditions>
                    <action type="Redirect" url="https://{HTTP_HOST}{REQUEST_URI}" redirectType="Permanent" appendQueryString="false" />
                </rule>
                <rule name="AngularJS 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="/" />
                </rule>
            </rules>
        </rewrite>
    </system.webServer>
</configuration>

Он имеет 2 правила:

Первое правило - перенаправить все вызовы на https. Удалите его, если вы не используете https.

Второе правило - исправить вашу проблему. Я получил ссылку на 2-ое правило здесь (спасибо пользователю gravityaddiction от www.reddit.com):

https://www.reddit.com/r/Angular2/comments/4sl719/moving_an_angular_2_app_to_a_real_server/ p >

Ответ 2

Я также столкнулся с этой проблемой и обошел эту ошибку, используя следующий код:

import { NgModule }      from '@angular/core';
import { BrowserModule } from '@angular/platform-browser'; 
import { FormsModule }   from '@angular/forms';
import { AppComponent }  from './app.component';
import { routing }       from './app.routes';
import {AgmCoreModule} from 'angular2-google-maps/core';
import { LocationStrategy, HashLocationStrategy } from '@angular/common';

@NgModule({
  imports: [ BrowserModule, FormsModule, routing, AgmCoreModule.forRoot() ],
  declarations: [ AppComponent ],
  bootstrap: [ AppComponent ],
  providers: [{provide: LocationStrategy, useClass: HashLocationStrategy}]
})

export class AppModule { }

Подробнее о HashLocationStrategy вы можете узнать здесь: https://angular.io/docs/ts/latest/api/common/index/HashLocationStrategy-class.html

Ответ 3

Простейшая версия метода @Guilherme Teubl. Это отлично сработало для меня.

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <system.webServer>
    <rewrite>
      <rules>
        <rule name="Angular4" 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>
  </system.webServer>
</configuration>