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>