1

我正在尝试通过 Ajax 向 dbperdia 发送查询。它工作正常,但如果搜索词中有特殊字符,我总是会收到一条错误消息。

我的代码看起来像

var IKS_QUERY = "PREFIX ontology: <http://dbpedia.org/ontology/>  PREFIX property: <http://dbpedia.org/property/> PREFIX resource: <http://dbpedia.org/resource/> PREFIX position:<http://www.w3.org/2003/01/geo/wgs84_pos#> SELECT DISTINCT ?Abstract ?ThumbnailURL WHERE { resource:"+where+"  ontology:abstract  ?Abstract.  resource:"+where+" ontology:thumbnail ?ThumbnailURL. FILTER (lang(?Abstract)=\"en\")}";
var IKS_URL = "http://dbpedia.org/sparql?default-graph-uri=http%3A%2F%2Fdbpedia.org&query=" + escape(IKS_QUERY) + "&format=json";

并且在搜索词中有特殊字符我收到以下错误消息。

Virtuoso 37000 Error SP030: SPARQL compiler, line 3: syntax error at ',' before '_Italy'

    SPARQL query:
    define sql:big-data-const 0 
    #output-format:application/sparql-results+json
    define input:default-graph-uri <http://dbpedia.org> PREFIX ontology: <http://dbpedia.org/ontology/>  PREFIX property: <http://dbpedia.org/property/> PREFIX resource: <http://dbpedia.org/resource/> PREFIX position:<http://www.w3.org/2003/01/geo/wgs84_pos#> SELECT DISTINCT ?Abstract ?ThumbnailURL WHERE { resource:Venice,_Italy  ontology:abstract  ?Abstract.  resource:wherePlaceHolder ontology:thumbnail ?ThumbnailURL. FILTER (lang(?Abstract)="en")}

有什么建议么?

提前致谢!

4

1 回答 1

3

您生成的查询无效,这与您通过 AJAX 发送它无关。请注意,Virtuoso 错误消息中的查询包含诸如resource:Venice,_Italy非法 SPARQL 语法之类的内容。

一种解决方法是在这里使用完整的 URI,而不是像当前的 JS 那样使用构建 QNames,而是应该构建完整的 URI,例如

<http://dbpedia.org/resource/" + where + ">

而不是像您目前所做的 QNames:

resource:" + where + "
于 2012-02-15T18:10:36.107 回答