我们需要使用buggy的Http内容协商来查询服务器(它不理解Accept中的Q参数)。因此,我们需要将查询发送到
Accept:application/rdf+xml
而不是耶娜的默认
Accept: text/turtle,application/n-triples;q=0.9,application/rdf+xml;q=0.7,application/trig,application/n-quads;q=0.9,text/x-nquads;q=0.8,application/x-trig;q=0.7,application/ld+json;q=0.6,*/*;q=0.5
下面是我们当前用于设置Jena的Http处理的Java代码:
static {
HttpOp.setDefaultHttpClient(createHttpClient(1000, 4000));
}
protected static HttpClient createHttpClient(final int connectTimeout, final int readTimeout) {
final RequestConfig requestConfig = RequestConfig.custom()
.setConnectTimeout(connectTimeout)
.setSocketTimeout(readTimeout)
.setContentCompressionEnabled(true)
.setRedirectsEnabled(true)
.build();
final HttpHost gndHost = new HttpHost("host.net", 80);
final PoolingHttpClientConnectionManager connMgr = new PoolingHttpClientConnectionManager();
connMgr.setDefaultMaxPerRoute(10);
connMgr.setMaxTotal(50);
connMgr.setMaxPerRoute(new HttpRoute(gndHost), 2);
return HttpClientBuilder.create()
.setConnectionManager(connMgr)
.setDefaultRequestConfig(requestConfig)
.build();
}是否可以更改这个常规设置,以便对所有请求使用HttpQuery.setAccept("application/rdf+xml")?
发布于 2016-05-19 09:06:58
函数QueryExecutionFactory.sparqlService返回一个QueryExecution对象,它实际上是一个QueryEngineHTTP,它有set*ContentType方法。
如果您想进入真正详细的控件,可以将HttpOp直接与将输入流传递给RDFDataMgr的HttpResponseHandler一起使用。
发布于 2016-05-19 13:35:06
此代码完成了以下工作:
private Model fetchRemoteData(final String uri, final Boolean ignoreErrors) throws HttpException, TitleDataInvalidException {
try {
final Model rdfModel;
if (uri.startsWith("http://d-nb.info")) {
final Model tmpModel = ModelFactory.createDefaultModel();
final TypedInputStream is = HttpOp.execHttpGet(uri, "application/rdf+xml");
tmpModel.read(is, null);
rdfModel = tmpModel;
} else {
rdfModel = RDFDataMgr.loadModel(uri);
}
return rdfModel;
} catch (RiotException ex) {
...https://stackoverflow.com/questions/37316642
复制相似问题