2

我正在使用 WebClient.DownloadString() 方法下载一些数据。我正在使用以下代码:

static void Main(string[] args)
    {
        string query = "select+%3farticle+%3fmesh+where+{+%3farticle+a+npg%3aArticle+.+%3farticle+npg%3ahasRecord+[+dc%3asubject+%3fmesh+]+.+filter+regex%28%3fmesh%2c+\"blood\"%2c+\"i\"%29+}";
        NameValueCollection queries = new NameValueCollection();
        queries.Add("query", query);
        //queries.Add("output", "sparql_json");
        using (WebClient wc = new WebClient())
        {
            wc.Headers.Add("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.2; .NET CLR 1.0.3705;)");
            wc.QueryString = queries;
            string result = wc.DownloadString("http://data.nature.com/sparql");
            Console.WriteLine(result);
        }
        Console.ReadLine();
    }

使用此代码, tt 可以正常工作并给我一个 xml 字符串作为输出。但我想得到一个 JSON 输出,因此我取消了该行的注释

queries.Add("output", "sparql_json");

并执行了相同的程序,它似乎正在从服务器获取错误消息。

但是,如果我尝试使用 Web 浏览器并使用相同的 url(如下所示),它会按预期给我一个 JSON: URL that works in browsers

我想知道问题可能是什么。特别是当它在浏览器中工作而不使用网络客户端时。网络客户端在这里做了什么不同的事情吗?

请注意,我还尝试将查询指定为

query + "&output=sparql_json"

但这也不起作用。

有人可以告诉我可能是什么问题吗?

谢谢

4

1 回答 1

6

添加wc.Headers.Add("Accept","application/json");. 这是我测试的完整来源

string query = "select ?article ?mesh where { ?article a npg:Article . ?article npg:hasRecord [ dc:subject ?mesh ] . filter regex(?mesh, \"blood\", \"i\") }";
NameValueCollection queries = new NameValueCollection();
queries.Add("query", query);
queries.Add("output", "sparql_json");
using (WebClient wc = new WebClient())
{
    wc.Headers.Add("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.2; .NET CLR 1.0.3705;)");
    wc.Headers.Add("Accept","application/json");
    wc.QueryString = queries;
    string result = wc.DownloadString("http://data.nature.com/sparql");
    Console.WriteLine(result);
}
Console.ReadLine();
于 2012-04-05T17:15:16.563 回答