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