Я размещаю vuejs
приложение в папке WWWROOT
приложения Asp.net Core 2.0.
Когда я пытаюсь запустить приложение с URL:
https://admin.myapp.com или https://admin.myapp.com/index, когда в браузере нажата https://admin.myapp.com, приложение должно быть перенаправлено на ../index, но ничего не происходит. Их всегда ниже ошибка на консоли браузера.
manifest.c93377026a31fd19d204.js:1 Uncaught SyntaxError: Unexpected token <
vendor.ce0b0308730c78917196.js:1 Uncaught SyntaxError: Unexpected token <
app.09cbf8437d50e73c0697.js:1 Uncaught SyntaxError: Unexpected token <
Я переписываю URL следующим образом в файлах веб-конфигурации приложения.
Web Config
За пределами папки wwwroot.
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<system.webServer>
<rewrite>
<rules>
<rule name="VueJs 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="^/(api)" negate="true" />
<add input="{REQUEST_URI}" pattern="^/(account)" negate="true" />
</conditions>
<action type="Rewrite" url="/" />
</rule>
</rules>
</rewrite>
<handlers>
<add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModule" resourceType="Unspecified" />
</handlers>
<aspNetCore processPath="dotnet" arguments=".\MyApp.dll" stdoutLogEnabled="false" stdoutLogFile="C:\logs\MYApp\logs\stdout" />
</system.webServer>
</configuration>
Мой класс запуска:
public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory)
{
loggerFactory.AddConsole(Configuration.GetSection("Logging"));
loggerFactory.AddDebug();
loggerFactory.AddSerilog();
//app.UseHangfireDashboard();
//app.UseHangfireServer();
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
InitializeAsync(app.ApplicationServices, CancellationToken.None).GetAwaiter().GetResult();
app.UseCors("CorsPolicy");
app.UseAuthentication();
app.UseDefaultFiles();
app.UseStaticFiles();
//app.UseMiddleware(typeof(ErrorHandlingMiddleware));
app.UseMvc();
}
В VueJs я использую режим history
.
Это небольшой фрагмент кода, который я использую в своем Route.js
const router = new Router({
mode: "history",
linkActiveClass: "open active",
scrollBehavior: () => ({ y: 0 }),
routes: [
{
path: "/",
redirect: "/index",
name: "Home",
component: Full
Когда я пытаюсь просмотреть приложение, используя URL-адрес (api URL), например
https://admin.myapp.com/account/getdata
https://admin.myapp.com/api/list/state
данные заполнены правильно.
Любое предложение или помощь будут оценены.