无法从Express.js和SQL Server创建的api获得任何响应?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (1)
  • 关注 (0)
  • 查看 (61)

我正在尝试学习如何使用Node和Express.js构建api。我已经找到了下一步:点击这里

并创建了一个非常相似的版本,但我的数据:

var express = require("express");
var bodyParser = require("body-parser");
var sql = require("mssql");
var app = express();

app.use(bodyParser.json());

app.use(function (req, res, next) {
    res.header("Access-Control-Allow-Origin", "*");
    res.header("Access-Control-Allow-Methods", "GET,HEAD,OPTIONS,POST,PUT");
    res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, contentType,Content-Type, Accept, Authorization");
    next();
});

 var server = app.listen(process.env.PORT || 8080, function () {
    var port = server.address().port;
    console.log("App now running on port", port);
 });

 var dbConfig = {
     user:  "myUser",
     password: "myPass",
     server: "myServer",
     database: "MyDB"
 };

var  executeQuery = function(res, query){
     sql.connect(dbConfig, function (err) {
         if (err) {
                     console.log("Error al conectarse a la base :- " + err);
                     res.send(err);
                  }
                  else {
                         // create Request object
                         var request = new sql.Request();
                         // query to the database
                         request.query(query, function (err, res) {
                           if (err) {
                                      console.log("Error al correr query en la base :- " + err);
                                      res.send(err);
                                     }
                                     else {
                                       res.send(res);
                                            }
                               });
                       }
      });
}

//GET API
app.get("/api/ApiRequestData", function(req, res){
                var query = "select * from [RequestData]";
                executeQuery (res, query);
});

创建server.js doc后,执行npm install并运行node server.js,我使用下一个url在邮递员上打开:http://localhost:8080/api/ApiRequestData并收到错误消息:“无法获得任何响应”。在Node命令提示符下,我收到消息:

TypeError:res.send不是C:\ Users \ API \ server.js:43:44中的函数,位于C:\ Users \ API \ node_modules \ mssql \ lib \ main.js:1588:20,位于Request.userCallback( C:\ Users \ API \ node_modules \ mssql \ lib \ tedious.js:853:61)在Connection的Request.callback(C:\ Users \ API \ node_modules \ tedious \ lib \ request.js:33:27)。在Connection.dispatchEvent(C:\ Users \ API \ node_modules \ tedious \ lib \ connection.js:519:45)处的消息(C:\ Users \ API \ node_modules \ tedious \ lib \ connection.js:1179:27)at MessageIO。(C:\ Users \ API \ node_modules \ tedious \ lib \ connection.js:439:23)在DiscoveryablePacketStream的MessageIO.emit(events.js:208:7)的emitNone(events.js:106:13)处。(C:\ Users \用户API \ node_modules \乏味\ lib中\消息io.js:92:15)

有人知道为什么要显示这条消息?

希望您能够帮助我。

提问于
用户回答回答于

你是遮蔽res从线var executeQuery = function(res, query){...res从行request.query(query, function (err, res) {...。只需将最后一个重命名res为其他内容,您就不会收到此错误:

request.query(query, function (err, result) {
  if (err) {
    console.log("Error al correr query en la base :- " + err);
    res.send(err);
  }
  else {
    res.send(result);
  }
});

热门问答

如何设置物联网通信的规则引擎转发到微信小程序?

DylanRichard

腾讯 · 产品经理 (已认证)

万物互联的时代,欢迎来到IoT的世界
推荐

正如参考文章所述,通过规则引擎述是将设备上行数据转发到服务端而不是直接到小程序,需要开发者基于API SDK用于服务端开发,并于小程序进行上下行通信。

在房间内切出app/闪退后还继续收费吗?

腾讯音视频小蔡

深圳市腾讯科技 · 软件开发工程师 (已认证)

QQ:471381568
推荐
1、切出app调用pause的时候是在房间的话,会一直收费。 2、比如A在程序闪退后,如果没有重连,90秒后A会自动退出房间。 3、扣费有疑问可以先看下运营指引:https://cloud.tencent.com/document/product/607/17448 如果对扣费还...... 展开详请

腾讯IM web端sdk 1.7版本,更新到当前最新,在哪里可以查看有什么改动呢?

使用微信小程序也可以做腾讯云的标准视频直播吗?使用微信小程序做腾讯云的视频直播和im即时通讯可行吗?

美女视频一起走向共同富裕
推荐
支持的 IM部分,集成云通信 https://cloud.tencent.com/document/product/269/36838 标准直播部分,使用live-pusher和live-player标签,然后用云直播即可 https://cloud.tencent.com/do...... 展开详请

为什么我通过控制台vnc看到的界面和用vnc viewer看的的界面不一样???

HappyLau谈云计算专注于公有云,私有云解决方案,在kubernetes,openstack,kvm,ceph,linux,shell有丰富的实战经验。
推荐

控制台页面使用的是novnc,novnc是一种基于web页面使用的vnc客户端,详情可参考https://github.com/novnc/noVNC介绍,常规的vnc viewer是图形的客户端,所使用的依赖库有所不同,因此显示也不一样。

API获取域名列表一直AuthFailure,code:4100?

zqfan

腾讯 · 高级工程师 (已认证)

推荐
推荐使用SDK进行调用:https://github.com/QcloudApi/qcloudapi-sdk-python 如果要自己写,也请参考下签名文档中python的代码示例,或者SDK中的源码:https://github.com/QcloudApi/qcloudapi-...... 展开详请

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励