数据不会在 mongodb 中使用 angularJS 删除

Data is not delete in mongodb with angularJS

本文关键字:angularJS 删除 mongodb 数据      更新时间:2023-09-26

服务器端代码:

var User = require("./models/user");
var express = require('express'),
app = express(),
Account = require("./models/account"),
mongoose = require('mongoose'),
passport = require("passport"),
basicAuth = require('basic-auth'),
bodyParser = require("body-parser"),
LocalStrategy = require("passport-local"),
passportLocalMongoose = require("passport-local-mongoose");  //libraries

mongoose.connect("mongodb://localhost/test");
app.set('view engine', 'ejs'); //using engine of ejs file
app.use(bodyParser.urlencoded({extended: true}));
app.use(require("express-session")({
secret: "kiss my ass",
resave: false,
saveUninitialized: false
}));
app.use(passport.initialize());
app.use(passport.session());
passport.use(new LocalStrategy(Account.authenticate()));
passport.serializeUser(Account.serializeUser());
passport.deserializeUser(Account.deserializeUser());

// AUTH Routes

//create account success
app.get('/success', function (req, res) {
  res.render('success');
});
// deleteUser form
app.get("/delete", function(req, res, next) {
   res.render("deleteuser"); 
});

app.get("/viewall", function(req, res, next) {
   res.render("viewall"); 
});
//view all User form
app.get('/view', function (req, res) {
console.log('getting all user');
Account.find({})
.exec(function(err, results) {
if(err) {
    res.send('error has occured');
}else{
    console.log(results);
    res.json(results);
}
});
});
app.get('/viewall/:id', function (req, res) {
console.log('getting one user');
Account.findOne({
    _id:req.params.id
})
.exec(function(err, account) {
if(err) {
    res.send('error occured');
}else{
    console.log(account);
    res.json(account);
}
})
})
// LOGIN for user
// render login form
app.get("/", function(req, res) {
res.render("login"); 
});
//login for user
//middleware
 app.post("/login", passport.authenticate("local", {
successRedirect: "http://localhost:8082/viewImage.html",
failureRedirect: "http://localhost:8081/error" 
}), function(req, res) {
});
//logout from basicauth
app.get('/logout', function (req, res) {
 res.set('WWW-Authenticate', 'Basic realm=Authenticate Required');
 return res.sendStatus(401);
// res.send("<a href='/login'>Show Users</a>");
});
//basicauth for admin login
var auth = function (req, res, next) {
  function unauthorized(res) {
    res.set('WWW-Authenticate', 'Basic realm=Authenticate Required');
    return res.send(401);
  };
  var user = basicAuth(req);
  if (!user || !user.name || !user.pass) {
    return unauthorized(res);
  };
  if (user.name === 'admin' && user.pass === 'admin123') {
    return next();
  } else {
    return unauthorized(res);
  };
 };
//LOGIN for admin
//render login form
app.get("/register", auth, function(req, res) {
 res.render("register"); 

});
// register post
app.post("/register", function(req,res){
Account.register(new Account({username: req.body.username}),  req.body.password, function(err, user){
    if(err){
        console.log(err);
        return res.render('/register');
    }
    passport.authenticate("local")(req, res, function(){
       res.redirect("/success"); 
    });
});
});
app.listen(8081, function () {
console.log('ImageViewer listening on port 8081!');
});

JS代码:

$scope.delete = function (data) {
      if (confirm('Do you really want to delete?')){
      $window.location.reload();
        $http['delete']('/viewall/' + data._id).success(function() {
          $scope.users.splice($scope.users.indexOf(data), 1);
        });
      }
    };

网页代码:

<tr ng-repeat="user in users | filter:searchBox | orderBy:'+username'">            
     <td>{{user._id}}</td>
        <td>{{user.username}}</td>
        <td><button class="btn btn-primary" ng-click="delete(user)">Delete</button></td>

这是我得到的错误:

DELETE 
XHR 
http://localhost:8081/viewall/5784919136ccb93d0ba78d4b [HTTP/1.1 404 Not  Found 8ms]

但是当我运行 http://localhost:8081/viewall/5784919136ccb93d0ba78d4b 的 url 并且它确实给了我数据:

{"_id":"5784919136ccb93d0ba78d4b","username":"qs","__v":0}

有人可以帮助我吗? 不知道当我能够获取数据时错误404是怎么回事。

你没有DELETE动词'/viewall/:id'的路线。因此,您应该使用动词添加DELETE路由。喜欢

app.delete('/viewall/:id',function(req,res){
  // rest of code here
  // assume your model name Account
  Account.remove({ _id: req.params.id },function(err,doc) {
      if(err) {
         return res.status(400).send({msg: 'Error occurred during delete account'});
      }
      return res.status(200).send({msg: 'Successfully deleted'});
  });
}

并且您应该在成功后重新加载您的角度控制器。

$http['delete']('/viewall/' + data._id).then(function(response) {
  $scope.users.splice($scope.users.indexOf(data), 1);
  $window.location.reload();
});