我对在WSO2 Commons中使用Fedora DSS和SPARQL查询有一个问题。目前,我正在台式机上运行WSO2 DSS,并将其作为本地主机服务进行访问。我的SPARQL端点是一个远程服务器,它运行一个名为Fedora Commons的开源应用程序,它需要基本身份验证来形成查询,并通过GET或POST请求接受输入,查询内容放在" query“变量中。对于这个示例,我们将假设我试图查询的端点URL如下所示:
http://fedoraAdmin:fedoraPW@fedora-server.yoyodyne.com:8080/fedora/risearch?lang=sparql我尝试运行的查询在Fedora资源索引查询服务测试页面中运行,如下所示:
PREFIX fedora: <info:fedora/fedora-system:def/relations-external#>
SELECT ?pid
FROM <#ri>
WHERE {
?pid fedora:isMemberOfCollection <info:fedora/islandora:root>
}在某种程度上,我想用查询参数替换"islandora:root“的标识符,但目前这并不重要。上述查询的结果如下所示:
<sparql>
<head>
<variable name="pid"/>
</head>
<results>
<result>
<pid uri="info:fedora/islandora:sp_basic_image_collection"/>
</result>
<result>
<pid uri="info:fedora/islandora:sp_large_image_collection"/>
</result>
<result>
<pid uri="info:fedora/islandora:70"/>
</result>
<result>
<pid uri="info:fedora/rick:1"/>
</result>
<result>
<pid uri="info:fedora/islandora:419"/>
</result>
<result>
<pid uri="info:fedora/islandora:420"/>
</result>
</results>
</sparql>考虑到上述情况和数据输出,我在WSO2决策支持系统中创建了一个数据服务,如下所示:
<data name="FedoraSPARQL">
<config id="FedoraDEVServer">
<property name="rdf_datasource">http://fedoraAdmin:fedoraPW@fedora-server.yoyodyne.com:8080/fedora/risearch?lang=sparql</property>
</config>
<query id="getMemberOfCollection" useConfig="FedoraDEVServer">
<sparql><![CDATA[PREFIX fedora: <info:fedora/fedora-system:def/relations-external#> SELECT ?pid FROM <#ri> WHERE {?pid fedora:isMemberOfCollection <info:fedora/islandora:root>}]]></sparql>
<result element="results" rowName="result">
<element column="pid" name="pid" xsdType="string"/>
</result>
<param name="targetPID" sqlType="STRING"/>
</query>
<operation name="getMemberOfCollection">
<description>Returns the collection objects under islandora:root</description>
<call-query href="getMemberOfCollection">
<with-param name="targetPID" query-param="targetPID"/>
</call-query>
</operation>
</data>目前,我遇到了401未授权,可能是由于连接字符串中的拼写错误或格式错误,或者是因为WSO2 DSS可能无法连接到需要身份验证的SPARQL端点。我这里的问题是,在我当前的设置下,如何使上述数据源工作?如果我不能使用DSS进行身份验证,如果WSO2 DSS是从另一台服务器上运行的,我可以选择完全绕过身份验证。假设这可以正常工作,我需要做什么更改才能使用"targetPID“查询参数来代替当前使用的"islandora:root”字符串?
发布于 2013-11-27 01:50:57
啊,我想我看到了这种方法的问题。哇,我完全误解了RDF数据源操作应该做什么。有趣的是,更多的咖啡往往会让事情变得更清晰。
在执行Edit Data Source配置时,我看到配置XML中的属性名称"rdf_datasource“在数据源编辑器向导中作为"RDF File Location”列出。这让我认为DSS并没有像我希望的那样向Fedora服务器发送任何查询,而是(在本地)对它期望从Fedora服务器下载的预先存在的RDF结果执行查询。
我想我需要将其重新构造为Web数据源,以获得我期望的结果。
https://stackoverflow.com/questions/20223046
复制相似问题