首页 > 解决方案 > 为什么我的变量没有在 node.js 中更新?

问题描述

我已经使用 node.js 构建了一个 webapp,以通过 POST 请求从 SNS 主题接收消息并将它们记录到控制台,然后将它们显示在网页上,如果我向我的主题发布消息,我会在控制台中打印消息但什么也没有我的网页上的更新?

这是我的代码app.js

const express = require("express");
const request = require('request')
const bodyParser = require('body-parser')
const app = express();
app.use(express.static('public'));
app.set("view engine", "ejs")


app.get('/', function (req, res) {
  let subject = "Your Subject Will Appear Here";
  let message = "Your Message Will Appear Here";
  res.render("index", {subject:subject, message:message});
})

app.use(bodyParser.urlencoded({ extended: false }))
app.use(bodyParser.json())

app.post('/', (req, res) => {
  let body = ''
  req.on('data', (chunk) => {
    body += chunk.toString()
  })  
  req.on('end', () => {
    let payload = JSON.parse(body)
    if (payload.Type === 'Notification') {
      console.log(payload.Message);
      let subject = payload.Subject;
      let message = payload.Message;
      res.render("index", {subject:subject, message:message});
    }
  });
});

app.listen(80, process.env.IP, function(request, response){
    console.log("## SERVER STARTED ##");
});

这是我的代码index.js

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title>title</title>
    <link rel="stylesheet" type="text/css" href="/css/style.css">
    <link href='https://fonts.googleapis.com/css?family=Open+Sans:300' rel='stylesheet' type='text/css'>
  </head>
  <body>
    <div class="container">
      <fieldset>
        <% if(subject !== null){ %>
            <p>SNS Subject: <%= subject %></p>
          <% } %>
        <% if(message !== null){ %>
            <p>SNS Message: <%= message %></p>
          <% } %>
      </fieldset>
    </div>
  </body>
</html>

标签: javascriptnode.jsembedded-javascript

解决方案


因为您的变量是和回调函数中的局部变量。如果您希望它们在这些回调的范围之外持续存在,则需要将它们移动到回调返回时不会消失的范围。getpost

例如,这使它们成为全局模块,但是对于每个 POST,无论它来自谁,更改无关 GET 的内容似乎都很奇怪(请参阅***评论):

// *** Declared at module scope
let subject = "Your Subject Will Appear Here";
let message = "Your Message Will Appear Here";

app.get('/', function (req, res) {
  // *** Not declared here
  res.render("index", {subject:subject, message:message});
})

// ...

app.post('/', (req, res) => {
  let body = ''
  req.on('data', (chunk) => {
    body += chunk.toString()
  })  
  req.on('end', () => {
    let payload = JSON.parse(body)
    if (payload.Type === 'Notification') {
      console.log(payload.Message);
      subject = payload.Subject; // <======= *** no `let`, we're not declaring here
      message = payload.Message; // <======= *** same
      res.render("index", {subject:subject, message:message});
    }
  });
});

但同样,这可能没有意义。您可能需要某种每用户或每会话存储机制(例如数据库,或过期的内存缓存等)。


推荐阅读