NET:ERR_CONNECTION_CLOSE

t9aqgxwy  于 2022-10-24  发布在  Angular
关注(0)|答案(2)|浏览(551)

嗨,我一直面临着一个铬合金的问题。我不知道是我的代码错误还是Chrome错误。错误之处在于

加载资源失败:NET::ERR_CONNECTION_CLOSED

我的QSTNURLconst app = angular.module('myapp',["ngRoute"]);app.value("QSTNURL","https://localhost:12345/api/insertQuestion");

来自客户端的控制程序.js是

app.controller('myctrl',function($scope,userFactory,QSTNURL){
  $scope.pushData = function(){
  var qstn = $scope.qstn;
  var opt1 = $scope.opt1;
  var opt2 = $scope.opt2;
  var opt3 = $scope.opt3;
  var opt4 = $scope.opt4;
  var ans = $scope.ans;
  const qstnObject = {
      "qstn":qstn,
      "opt1":opt1,
      "opt2":opt2,
      "opt3":opt3,
      "opt4":opt4,
      "ans":ans
  }
  console.log('doAjax');
  var promise = userFactory.doAjax(QSTNURL,qstnObject);
  promise.then(function(response){
      $scope.data = response;
   },function(error){
      $scope.error = error;
  });
 }

});

我对服务器的AJAX调用是

app.factory("userFactory",function($http,$q){
  var userObject = {
    doAjax(QSTNURL,qstnObject){
        console.log('doAjax()');
            var defer = $q.defer();
            $http.get(QSTNURL,qstnObject).then(function(response){
                defer.resolve(response);
                console.log("doAjax 2");
            },function(error){
                defer.reject(error);
            });
            return defer.promise;

    }
  };
   return userObject;
});

Server.js

const express = require("express");
 var expressSession = require('express-session');
 const app = express();
 var path = require("path");
 var bodyParser = require('body-parser');
 const userRoutes = require("./routes/userroutes");
 app.set('views', path.join(__dirname, 'views'));
 app.set('view engine', 'ejs');

 app.use(express.static(path.join(__dirname, 'public')));
 app.use(expressSession({secret: 'mySecretKey'}));

 app.use('/api',userRoutes);

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

 app.use('/',userRoutes);
 app.listen(12345,()=>{
 console.log("Server Start...");
});

我的所有静态文件(如:-用于生成SPA的所有js文件,例如app.js、控制器、工厂等)位于公用文件夹中,而视图部件位于视图文件夹中

我的路线代码是

router.get('/insertQuestion',(req,response)=>{
  console.log("insertQuestion");
  var qstn = req.body.qstn;
  var opt1 = req.body.opt1;
  var opt2 = req.body.opt2;
  var opt3 = req.body.opt3;
  var opt4 = req.body.opt4;
  var ans = req.body.ans;
  var qstnObject = new Insert(qstn,opt1,opt2,opt3,opt4,ans);
  userOperation.insertQuestion(qstnObject,response,req);
  response.json("question inserted");
});
qyzbxkaa

qyzbxkaa1#

只有在12345端口上没有正在运行的服务器时,才会出现此错误。
您正在呼叫https://localhost:12345/dashboard/insertQuestion。因此,您还应该考虑您使用的是https方案,因此请确保您的服务器支持HTTPS方案,并且端口正确。
如果您尚未将您的节点应用程序/服务器应用程序配置为在HTTPS上运行,则只需替换

https://localhost:12345/dashboard/insertQuestion

使用

http://localhost:12345/dashboard/insertQuestion
mspsb9vt

mspsb9vt2#

嘿,我得到了答案,整个问题都在QSTNURL中。我不应该传递这个URL https://localhost:12345/api/insertQuestion,而只将api/insertQuestion直接传递给AJAX调用,如下所示

app.factory("userFactory",function($http,$q){
var userObject = {
doAjax(QSTNURL,qstnObject){
    console.log('doAjax()');
        var defer = $q.defer();
        $http.get('/api/insertQuestion',qstnObject).then(function(response){
            defer.resolve(response);
            console.log("doAjax 2");
        },function(error){
            defer.reject(error);
        });
        return defer.promise;

}
};
return userObject;
});

我不知道为什么会这样。但它解决了我的问题

相关问题