我编写了这段代码,开始连接到我的 MongoDB 服务器,并在这样的连接中执行 Web 服务代码。
这是最佳还是安全的方式?有什么更好的方法来实现这一点?
var express = require("express");
var mongodb = require("mongodb");
var servidor = new express();
var BSON = mongodb.BSONPure;
servidor.use(express.static(__dirname+"/publico"));
servidor.use(express.bodyParser());
var cliente_mongodb = mongodb.MongoClient;
cliente_mongodb.connect("mongodb://localhost/db_escuela", function(err, db_escuela){
if(err){
console.log("Error de conexion"+err);
}else{
console.log("Se ha conectado a la base de datos");
var cl_alumnos = db_escuela.collection("cl_alumnos");
servidor.get("/alumnos",function(peticion, respuesta){
cl_alumnos.find().toArray(function(err,respuesta_db){
respuesta.send(respuesta_db);
});
});
servidor.get("/alumnos/:id",function(peticion,respuesta){
var id = new BSON.ObjectID(peticion.params.id);
cl_alumnos.findOne({'_id':id},function(err,respuesta_db){
respuesta.send(respuesta_db);
});
});
servidor.post("/alumnos",function(peticion,respuesta){
var nuevo_alumno={
nombre:peticion.body.nombre,
edad:peticion.body.edad,
promedio:peticion.body.promedio
};
cl_alumnos.insert(nuevo_alumno,function(err,respuesta_db){
console.log("Se ha insertado: "+JSON.stringify(respuesta_db));
respuesta.send(respuesta_db);
});
});
servidor.delete("/alumnos/:id",function(peticion,respuesta){
var alumno_eliminar = {
_id : new BSON.ObjectID(peticion.params.id)
}
cl_alumnos.remove(alumno_eliminar,function(err,respuesta_db){
if(err)
console.log("No se ha podido eliminar el registro");
else
respuesta.send("Registro Eliminado");
});
});
servidor.put("/alumnos/:id",function(peticion,respuesta){
var id_editado={
_id : new BSON.ObjectID(peticion.params.id)
};
var alumno_editado={
nombre:peticion.body.nombre,
edad:peticion.body.edad,
promedio:peticion.body.promedio
};
cl_alumnos.update(id_editado, alumno_editado, function(err, respuesta_db){
if(err)
{
console.log("Error:"+err);
}
else
{
console.log("Resultado "+respuesta_db);
respuesta.send("Actualizacion Exitosa");
}
});
});
servidor.listen(8080,function(){
console.log("El servidor esta escuchando en el puerto 8080");
});
}
});