如何解决错误HRESULT:使用Node.js Express和IISnode在Azure中部署时,0x6d HTTP 500子状态为1013?

时间:2020-08-29 19:56:24

标签: node.js angular express iis iisnode

当我尝试从联系表进行POST时,我的应用程序中不断出现错误。这是启动程序,它可以在我的开发环境中(使用localhost)工作(以接收电子邮件)。当我从主机桌面将其部署到vm Windows Server时,它甚至可以接收电子邮件。但是,当我在Azure Windows Server上部署它时,它不起作用,我的vm服务器和Azure在IIS中具有相同的设置,并安装了node.js和IISnode。 对于整个node.js / express和IISnode开发来说,这是新的东西,对使其正常工作和解决的任何帮助将不胜感激。

error screenshot.

web.config

<configuration>
    <system.webServer>
        <handlers>
            <add name="iisnode" path="server.js" verb="*" modules="iisnode" />
        </handlers>
        <!-- <httpErrors existingResponse="PassThrough"> -->
        <iisnode nodeProcessCommandLine="C:\Program Files\nodejs\node.exe" logDirectory="C:\inetpub\logs\abc\iisnode" loggingEnabled="true" />
        <modules runAllManagedModulesForAllRequests="false">
            <remove name="WebDAVModule"/>
        </modules>
        <rewrite>
            <rules>
                <rule name="abc_test">
                    <match url="api/*" />
                    <action type="Rewrite" url="server.js" />
                </rule>
            </rules>
        </rewrite>
    </system.webServer>
</configuration>

server.js

const PORT = process.env.PORT || 3003`
const app = require('./app')
app.listen(PORT, function(){
     `console.log("Server Listening On Port: ", PORT);
})

app.js

const express = require('express');
const bodyParser = require('body-parser');
const cors = require('cors');
const app = express();
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: true}));`
app.use(cors({origin: "*"}));
const generalRoutes = require('./api/route/general');
app.use('/'+'abc_backend/api/general/', generalRoutes);
module.exports = app;

general.js

const express = require('express');
const router = express.Router();
const gController = require('../controller/generalController');
router.post('/contacting', gController.sendingMail);
module.exports = router;

generalController.js

const express = require('express');
const bodyParser = require('body-parser');
const nodemailer = require('nodemailer');
const app = express();
const sendingMail = async(req, res) => {
 let user = req.body;
 let transporter = nodemailer.createTransport({
 host: "smtp.gmail.com",
 port: 465,
 secure: true, // true for 465, false for other ports
 auth: {
  user: "aasome.fakemailzz@gmail.com",
  pass: "somefakepass"
 }
});
let mailOptions = {
 from: "contact@somefakedomain.io",
 to: "fakename@somefakedomain.com",
 subject: "New Contact Message",
 html: <b>Name: </b> ${user.userName} <br>
 <b>Email: </b> ${user.email} <br>
 <b>Phone: </b> ${user.address.postalCode} <br>
 <b>Message: </b> ${user.address.city}
};
let info = await transporter.sendMail(mailOptions);
 res.send(info);
}
module.exports = {
 sendingMail
}

contacting.service.ts

export class ContactingService {
 public url:string;
 constructor(private _http: HttpClient) {
  this.url = environment.backendAPIurl + "/general/";
 }
 contactSubmit(userName: string, email: string, postalCode: string, city: string){
  const bodyData = {
   userName:userName,
   email: email,
   address:{
    postalCode:postalCode,
    city: city
   }
  }
  return this._http.post<any>(this.url +"contacting",bodyData);
 }
}

1 个答案:

答案 0 :(得分:0)

解决了。启用IIS_USr将日志写入web.config中的目录后,查看错误日志。该错误表明它是Google身份验证产品,如果传入的请求服务器不安全/ SSL,则在生产服务器上Google将无法正常工作。

还发现了提到相同概念的stackoverflow链接。 iisnode encountered an error when processing the request. HRESULT: 0x6d HTTP status: 500 HTTP subStatus: 1013

通过单击此链接解决,并使用来自nodemailer.createTransport({})的帐户登录以允许它。 https://accounts.google.com/b/0/DisplayUnlockCaptcha