WAR2 DSS中的SPARQL查询问题

时间:2013-11-26 16:48:19

标签: authentication wso2 sparql wso2dss fedora-commons

我在Fedora Commons中使用WSO2 DSS和SPARQL查询时遇到了问题。目前我正在从桌面计算机上运行WSO2 DSS并将其作为本地主机服务进行访问。我的SPARQL端点是一个远程服务器,运行一个名为Fedora Commons的开源应用程序,需要基本身份验证来执行查询并通过GET或POST请求接受输入,并将查询内容放在“query”var中。为了这个例子,我们会说我试图查询的端点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>

目前,由于连接字符串中的拼写错误或格式错误,或者WSO2 DSS可能无法连接到需要身份验证的SPARQL端点,我可能会遇到401 Unauthorized。我的问题是如何根据我当前的设置使上述数据源工作?如果我无法使用DSS进行身份验证,那么如果WSO2 DSS从另一台服务器运行,我可以选择完全绕过身份验证。假设这可以使用,我需要做什么改变才能使用“targetPID”查询参数代替当前使用的“islandora:root”字符串?

1 个答案:

答案 0 :(得分:0)

啊,我想我看到了这种方法的问题。哇,我完全误解了RDF数据源操作应该做什么。有趣的是,咖啡往往会让事情变得更加清晰。

在浏览编辑数据源配置时,我看到配置XML中的“rdf_datasource”属性名称在数据源编辑器向导中列为“RDF文件位置”。这让我觉得DSS没有像我希望的那样向Fedora服务器发送任何查询,而是在预期从Fedora服务器下载的预先存在的RDF结果上执行查询(本地)。

我想我需要将其重组为Web数据源以获得我期望的结果。