Graphdb.js node.js一台server.repository通过Rest API连接多个查询

我正在使用nodejs和graphdbjs。我的问题是我是否可以激活一个存储库并设置两个查询(在本例中为有效负载),这些查询将作为REST APis按需运行。例如

const server = new ServerClient(serverConfig);
const readTimeout = 30000;
const writeTimeout = 30000;
const repositoryClientConfig = new RepositoryClientConfig(['http://localhost:7200/repositories/V2'],{},'',readTimeout,writeTimeout);
server.getRepository('V2',repositoryClientConfig).then(repository => {  
  repository.registerParser(new SparqlJsonResultParser());

    const payload = new GetQueryPayload()
      .setQuery('select * where {?s ?p ?o}')
      .setQueryType(QueryType.SELECT)
      .setResponseType(RdfmimeType.SParqL_RESULTS_JSON)
      .setLimit(100);
    repository.query(payload).then((stream) => {
       stream.on('data',(bindings) => {
            var test = Object.values(bindings);
         var element = {id: test[0].id.replace(/['"]+/g,''),name: test[1].id.replace(/['"]+/g,'')}
        });
        stream.on('end',() => {          
        restapp.get('/getallIDs',function(req,res)  {
        res.send(element);
        });
        restapp.listen(3000,function () {
             console.log('App listening on port 3000!');
        });
        }); 
});




const payload2 = new GetQueryPayload()
  .setQuery('select * where {?s ?p ?o}')
  .setQueryType(QueryType.SELECT)
  .setResponseType(RdfmimeType.SParqL_RESULTS_JSON)
  .setLimit(100);
  repository2.query(payload2).then((stream2) => {
    stream2.on('data',(bindings2) => {
    var test2 = Object.values(bindings2);
    var i2=0;
    test2.forEach(function(key,value){
      if (i2%2==1){
      return true;}
      var element2 = {id: test2[0].id.replace(/['"]+/g,name: test2[1].id.replace(/['"]+/g,'')}
      i++;
      head2.table.push(element2);
    });       
    });
    stream2.on('end',() => {
    restapp2.get('/getidby',res)  {
      res.send(head2);
    });
    restapp2.listen(3000,function () {
       console.log('App listening on port 3000!');
    });
    });       

我只希望有一个会话和多个有效负载,并且如果用户点击了正确的URL,则它将返回json。到目前为止,我得到一个错误,我无法解释:

{"level":"error","time":1572863035018,"name":"RDFRepositoryClient","repositoryUrl":"http://localhost:7200/repositories/V2","msg":"Cannot retry execution","v":1}
Error: Request failed with status code 400
    at createError (/home/estathop/eclipse-workspace/test/node_modules/axios/lib/core/createError.js:16:15)
    at settle (/home/estathop/eclipse-workspace/test/node_modules/axios/lib/core/settle.js:17:12)
    at RedirectableRequest.handleResponse (/home/estathop/eclipse-workspace/test/node_modules/axios/lib/adapters/http.js:211:9)
    at RedirectableRequest.emit (events.js:210:5)
    at RedirectableRequest._processResponse (/home/estathop/eclipse-workspace/test/node_modules/follow-redirects/index.js:269:10)
    at ClientRequest.RedirectableRequest._onNativeResponse (/home/estathop/eclipse-workspace/test/node_modules/follow-redirects/index.js:50:10)
    at Object.onceWrapper (events.js:300:26)
    at ClientRequest.emit (events.js:210:5)
    at HTTPParser.parserOnIncomingClient [as onIncoming] (_http_client.js:583:27)
    at HTTPParser.parserOnHeadersComplete (_http_common.js:115:17) 

对实现我要做什么的任何帮助?我的下一步是从静态服务获取ID并相应地形成有效负载 谢谢,很抱歉,如果我的问题是假的,但我是这个领域的新手

ZYTLXJ 回答:Graphdb.js node.js一台server.repository通过Rest API连接多个查询

据我所知,您要实现的目标没有概念上的问题。 现在,根据错误,我认为这可能与您针对rest api restapp.get('/getallIDs',function(req,res) {...}执行的GET请求有关 您可以确认repository.query(payload)调用返回正确的响应吗?我想您可以简单地将记录器放在stream.on('data')之前,看看是否已打印,这将确认graphdbjs请求可能是正确的。 我可以给您一个稍微改进但仍然相似的示例,该示例似乎可以正确传输查询结果:

const {ServerClient,ServerClientConfig} = require('graphdbjs').server;
const {RepositoryClientConfig} = require('graphdbjs').repository;
const {RDFMimeType} = require('graphdbjs').http;
const {SparqlJsonResultParser} = require('graphdbjs').parser;
const {GetQueryPayload,QueryType} = require('graphdbjs').query;

const serverConfig = new ServerClientConfig('http://localhost:7200/',{
    'Accept': RDFMimeType.SPARQL_RESULTS_JSON
});
const server = new ServerClient(serverConfig);
const readTimeout = 30000;
const writeTimeout = 30000;
const repositoryClientConfig = new RepositoryClientConfig(['http://localhost:7200/repositories/testrepo'],{},'',readTimeout,writeTimeout);

server.getRepository('testrepo',repositoryClientConfig).then(function(repository) {  

    console.log('REPO:',repository);
    repository.registerParser(new SparqlJsonResultParser());

    const payload = new GetQueryPayload()
        .setQuery('select * where {?s ?p ?o}')
        .setQueryType(QueryType.SELECT)
        .setResponseType(RDFMimeType.SPARQL_RESULTS_JSON)
        .setLimit(100);
    return repository.query(payload);

})
.then(function(stream) {
    console.log('SELECT:');
    stream.on('data',function(bindings) {
        var test = Object.values(bindings);
        console.log('DATA');
        // var element = {id: test[0].id.replace(/['"]+/g,''),name: test[1].id.replace(/['"]+/g,'')}
    });
    stream.on('end',function() {
        console.log('END');
        // restapp.get('/getallIDs',res)  {
        //     res.send(element);
        // });
        // restapp.listen(3000,function () {
        //     console.log('App listening on port 3000!');
        // });
    });
})
.catch(function(error) {
    console.log('ERROR',error);
});

您可以解决的另一件事是res.send(element);调用,正如我所见,由于undefined的作用范围是element回调,因此实际上将发送stream.on('data'。因此,您可以通过在var element;行之前定义stream.on('data'来使其可用。

,

最好的结构化方法是拥有不同的文件,其中一个是主节点app.js

    var express = require('express');
var restapp = express();
var queryController = require('./controllers/queryController')

restapp.use(queryController)

restapp.listen(3001,function () {
    console.log('Αpp listening on port 3001!');
});

并暗示您导入了queryController.js,其中包括对graphdb服务器执行所需的每个不同查询的代码

var express = require('express');
var router = express.Router()

const {ServerClient,ServerClientConfig} = require('graphdb').server;
const {RDFMimeType} = require('graphdb').http;
const {RepositoryClientConfig} = require('graphdb').repository;
const {SparqlJsonResultParser} = require('graphdb').parser;
const {GetQueryPayload} = require('graphdb').query;
const {QueryType}= require('graphdb').query;
const serverConfig = new ServerClientConfig('http://localhost:7200',{
    'Accept': RDFMimeType.SPARQL_RESULTS_JSON
});

router.get('/hi',(req,res) => {
      res.send('hi')
})



router.get('/getallids',res) => {
    head = {};
    table = [];
    head.table = table;
    const server = new ServerClient(serverConfig);
    const readTimeout = 30000;
    const writeTimeout = 30000;
    const repositoryClientConfig = new RepositoryClientConfig(['http://localhost:7200/repositories/V2'],writeTimeout);
    server.getRepository('V2',repositoryClientConfig).then(repository => {  
        repository.registerParser(new SparqlJsonResultParser());     
        const payload = new GetQueryPayload()
        .setQuery('select * where {?p ?o ?k}')
        .setQueryType(QueryType.SELECT)
        .setResponseType(RDFMimeType.SPARQL_RESULTS_JSON)
        .setLimit(100);
        repository.query(payload).then((stream) => {
                stream.on('data',(bindings) => {
                var test = Object.values(bindings);
                var i=0;
                test.forEach(function(key,value){
                    test2 = Object.values(key);
                    if (i%2==1){
                    return true;}
                    var element = {id: test[0].id.replace(/['"]+/g,'')}
                    i++;
                    head.table.push(element);
                });       
            });
            stream.on('end',() => {  
                    res.send(head);   
            });       
        }).catch(err => console.log(err));
    });
})


router.get('/getid/:id',res) => {
    const params = req.params;
    head = {};
    table = [];
    head.table = table;
    const server = new ServerClient(serverConfig);
    const readTimeout = 30000;
    const writeTimeout = 30000;
    const repositoryClientConfig = new RepositoryClientConfig(['http://localhost:7200/repositories/V2'],repositoryClientConfig).then(repository => {  
        repository.registerParser(new SparqlJsonResultParser());     
        const payload = new GetQueryPayload()
        .setQuery('select'+Object.values(params)+'where {?p ?o ?k}')
        .setQueryType(QueryType.SELECT)
        .setResponseType(RDFMimeType.SPARQL_RESULTS_JSON)
        .setLimit(100);
        repository.query(payload).then((stream) => {
                stream.on('data',value){
                    test2 = Object.values(key);
                    if (i%2==1){
                    return true;}
                    var element = {key: test[0].id.replace(/['"]+/g,value: test[1].id.replace(/['"]+/g,() => {
                    res.send(head);  
            });       
        }).catch(err2 => console.log(err2));
    });
})
module.exports = router;
本文链接:https://www.f2er.com/3167531.html

大家都在问