查询,网址和正文参数未在塞内卡与seneca-web正确合并

时间:2016-11-04 12:25:45

标签: javascript node.js express seneca

我遇到塞内卡和塞内卡网络问题。我真是个初学者。

到目前为止,这是我的代码:

"use strict";

var express = require('express');
var Web = require("seneca-web");
var bodyParser = require('body-parser')

var plugin = require('./products_actions/products_actions');

module.exports = plugin;

var entities = require('seneca-entity')
var seneca = require('seneca')();

seneca.use(plugin);
seneca.use(entities);

seneca.use('mysql-store', {
    name : 'ecrm',
    host : 'localhost',
    user : 'root',
    password : 'ecrm',
    port : 3306
})

seneca.ready(function(err) {


    var Routes = [ {
        pin : 'area:product,action:fetch,criteria:*',

        prefix : '/products/fetch',

        map : {
            byId : {
                GET : true,
                suffix : "/:id"
            }
        }

    }, {
        pin : 'area:product,action:*',

        prefix : '/products',

        map : {
            fetch : {
                GET : true
            },

            add : {
                GET : false,
                PUT : true
            }
        }

    } ];

    var app = express();
    app.use(bodyParser.json());

    var config = {
        routes : Routes,
        adapter : require('seneca-web-adapter-express'),
        context : app,
        options : {
            parseBody : false
        }
    }

   seneca.use(Web, config);

   app.listen(3000);
});

以下是定义塞内卡行动的代码:

module.exports = function(options) {
var seneca = this;

// ADD
seneca.add({
    area : "product",
    action : "add"
}, function(req, done) {
    var products = this.make$("prodotti");

    var args = req.args.body;

    console.log(args);

    products.nome = args.nome;
    products.categoria = args.categoria;
    products.descrizione = args.descrizione;
    products.prezzo = args.prezzo;

    products.save$(function(err, product) {
        done(err, products.data$(false));
    });
});



// get by Id  , PROBLEM!!!
seneca.add({
    area : "product",
    action : "fetch",
    criteria : "byId"
}, function(req, done) {
    console.log("HERE");

    var id = req.args.params.id;

    var product = this.make("prodotti");
    product.load$(id, done);
});

// LIST ALL
seneca.add({
    area : "product",
    action : "fetch"
}, function(args, done) {
    var products = this.make("prodotti");
    products.list$({}, done);
});


}

问题在于getbyId处理程序(route / products / fetch / byId / id_of_the product)。

到目前为止的代码有效,但我想得到id_of_the产品所代表的id变量,而不是var id = req.args.params.id; 但是我希望它在req对象中合并,我想做var id = req.id;

在ADD处理程序中,我做了var args = req.args.body;但我希望看到正如我在书中看到的那样,身体在req对象中合并 David Gonzales在“node.js中开发微服务”。

问题出现在处理程序中我想调用另一个传递产品ID的seneca操作。在这种情况下,id可用于req对象,而不是url参数。 当然我可以测试变量是否在req.args.params中定义,如果没有使用req对象中的变量,但它不是一个干净的解决方案。

当前版本的塞内卡和塞内卡网可以实现这一目标吗?我从npm安装了它们,我有这些版本: seneca 3.2.2和seneca-web 2.0.0;

提前致谢!

1 个答案:

答案 0 :(得分:0)

您应该整理您感兴趣的信息,验证其有效性,并仅使用该信息调用基础操作。在点击您的实际服务之前,role:web可以成为用户输入进行一般健全性检查的良好守门人。

请记住,用户可以传递任何路径参数,正文,查询字符串等。必须注意清理用户提供的信息,并仅将有效信息发送到基础操作中。

seneca.add('role:web,domain:product,action:getById', function (msg, done) {
  const id = parseInt(msg.args.params.id, 10)
  if (isNaN(id)) {
    return done(new Error('needs to be numeric'))
  }
  seneca.act('role:entity,domain:product,action:getById', {id}, done)
})

seneca.add('role:entity,domain:product,action:getById', function (msg, done) {
  this.make$('product').load$(msg.id, done)
})

msg.args中检索有关请求的信息是seneca-web中游戏的名称 - 这是获取该信息的唯一方式。