尝试使用iisnode在iis中托管nuxt.js和express.js演示。 我获得了404的nuxt页面路由,但快速api路由工作正常。
nuxt所做的一切都是为了处理它的路线。不知道为什么这不起作用。
我已经使用iisnode处理程序设置了我的web.config,并且还包含了url rewrite config以将所有内容路由到server.prod.js
'use strict';
var Nuxt = require('nuxt');
var app = require('express')();
var host = process.env.HOST || '127.0.0.1';
var port = process.env.PORT || 3000;
app.set('port', port);
// Import API Routes
app.use('/api', require('./api/index'));
// Import and Set Nuxt.js options
var config = require('./nuxt.config.js');
config.dev = !(process.env.NODE_ENV === 'production');
// Init Nuxt.js
var nuxt = new Nuxt(config);
app.use(nuxt.render);
// Build only in dev mode
if (config.dev) {
nuxt.build().catch(function (error) {
console.error(error); // eslint-disable-line no-console
process.exit(1);
});
}
// Listen the server
app.listen(port, host);
console.log('Server listening on ' + host + ':' + port); // eslint-disable-line no-console
<configuration>
<system.webServer>
<handlers><add name="iisnode" path="server.prod.js" verb="*" modules="iisnode" /></handlers>
<rewrite>
<rules>
<rule name="myapp">
<match url="/*" />
<action type="Rewrite" url="server.prod.js" />
</rule>
<!-- Don't interfere with requests for node-inspector debugging -->
<rule name="NodeInspector" patternSyntax="ECMAScript" stopProcessing="true">
<match url="^app.js\/debug[\/]?" />
</rule>
</rules>
</rewrite>
<directoryBrowse enabled="true" />
<iisnode devErrorsEnabled="true" debuggingEnabled="true" loggingEnabled="true" nodeProcessCommandLine="C:\Program Files\nodejs\node.exe" />
<!-- exclude node_modules directory and subdirectories from serving
by IIS since these are implementation details of node.js applications -->
<security>
<requestFiltering>
<hiddenSegments>
<add segment="node_modules" />
</hiddenSegments>
</requestFiltering>
</security>
</system.webServer>
</configuration>
答案 0 :(得分:0)
IIS节点使用命名管道,因此服务器渲染对locahost tcp端口80的api调用失败... 服务器端需要一个完整的URL才能工作。