我对在 Fedora Commons 中使用 WSO2 DSS 和 SPARQL 查询有疑问。目前我正在从我的台式机运行 WSO2 DSS 并将其作为 localhost 服务访问。我的 SPARQL 端点是一个远程服务器,运行一个名为 Fedora Commons 的开源应用程序,需要基本身份验证来执行查询并通过 GET 或 POST 请求接受输入,查询的内容被放置在“查询”变量中。为了这个示例,我们将说我尝试查询的端点 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 DSS 中创建了一个类似于以下内容的数据服务:
<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 Unauthorized 可能是由于连接字符串中的拼写错误或格式错误,或者 WSO2 DSS 可能无法连接到需要身份验证的 SPARQL 端点。我的问题是如何根据我当前的设置使上述数据源工作?如果我无法使用 DSS 进行身份验证,如果 WSO2 DSS 从另一台服务器运行,我确实可以选择完全绕过身份验证。假设这可以工作,我需要进行什么更改才能使用“targetPID”查询参数代替当前使用的“islandora:root”字符串?