我正在将vuejs
应用托管在Asp.net Core 2.0应用的WWWROOT
文件夹中。
当我尝试使用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 <
我正在按以下步骤在应用程序的Web配置文件中重写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();
}
在VueJ中,我正在使用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
数据已正确填充。
任何建议或帮助将不胜感激。
答案 0 :(得分:2)
我在网络配置上使用了以下代码,从而解决了上述问题。我已经将所有标签张贴在这里作为答案。希望这可以帮助遇到类似问题的人。
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<system.webServer>
<rewrite>
<rules>
<rule name="wwwroot-static" stopProcessing="true">
<match url="([\S]+[.](html|htm|svg|js|css|png|gif|jpg|jpeg))" />
<action type="Rewrite" url="wwwroot/{R:1}" />
</rule>
<rule name="empty-root-index" stopProcessing="true">
<match url="^$" />
<action type="Rewrite" url="wwwroot/index.html" />
</rule>
<!--
Make sure you have a <base href="/" /> tag to fix the root path
or all relative links will break on rewrite
-->
<rule name="AngularJS-Html5-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="^/.well-known/openid-configuration" negate="true" />
<add input="{REQUEST_URI}" pattern="^/.well-known/jwks" negate="true" />
<add input="{REQUEST_URI}" pattern="^/api(.*)" negate="true" />
<add input="{REQUEST_URI}" pattern="^/account(.*)" negate="true" />
<add input="{REQUEST_URI}" pattern="^/connect(.*)" negate="true" />
</conditions>
<action type="Rewrite" url="wwwroot/index.html" />
</rule>
</rules>
</rewrite>
<handlers>
<add name="StaticFileModuleHtml" path="*.htm*" verb="*" modules="StaticFileModule" resourceType="File" requireAccess="Read" />
<add name="StaticFileModuleSvg" path="*.svg" verb="*" modules="StaticFileModule" resourceType="File" requireAccess="Read" />
<add name="StaticFileModuleJs" path="*.js" verb="*" modules="StaticFileModule" resourceType="File" requireAccess="Read" />
<add name="StaticFileModuleCss" path="*.css" verb="*" modules="StaticFileModule" resourceType="File" requireAccess="Read" />
<add name="StaticFileModuleJpeg" path="*.jpeg" verb="*" modules="StaticFileModule" resourceType="File" requireAccess="Read" />
<add name="StaticFileModuleJpg" path="*.jpg" verb="*" modules="StaticFileModule" resourceType="File" requireAccess="Read" />
<add name="StaticFileModulePng" path="*.png" verb="*" modules="StaticFileModule" resourceType="File" requireAccess="Read" />
<add name="StaticFileModuleGif" path="*.gif" verb="*" modules="StaticFileModule" resourceType="File" requireAccess="Read" />
<add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModule" resourceType="Unspecified" />
</handlers>
<aspNetCore processPath="dotnet" arguments=".\MyApp.dll" stdoutLogEnabled="false"
stdoutLogFile=".\logs\stdout" forwardWindowsAuthToken="false" />
</system.webServer>
</configuration>
答案 1 :(得分:0)
我认为这里的问题是,默认情况下,Vue假设您的应用托管在您的域(https://admin.myapp.com
)的基础上。但是,当您将其部署为ASP.NET项目的一部分时,它最终会坐在一个文件夹(https://admin.myapp.com/wwwroot
)中。当请求应用程序文件时,IIS Rewrite不会将它们检测为现有文件(因为相对于基础文件而言不是),而是被重写为index.html。
尝试将Vue配置中的baseUrl值更改为“ / wwwroot /”。
(注意:我正在处理的应用程序实际上有一个单独的API项目/站点,所以我的解决方案是直接托管Vue前端,而不是将其嵌入ASP.NET项目中。就是答案。)