0

我正在开发一个应用程序来遍历邮政编码和业务类型列表,然后通过我为这些参数构造的 url 创建对 Google Places API(文本搜索)的调用。

网址看起来像这样

https://maps.googleapis.com/maps/api/place/textsearch/json?key=MY_API_KEY_HERE&sensor=false&query=57783+dentist

为每个请求调用以下函数:

    private static StreamReader MakeWebRequest(string sURL)
    {
        HttpWebRequest request = (HttpWebRequest)WebRequest.Create(sURL);
        HttpWebResponse response = (HttpWebResponse)request.GetResponse();
        Stream responseStream = response.GetResponseStream();
        StreamReader objReader = new StreamReader(responseStream);
        return objReader;
    }

我遇到的问题是,在 3 到 5 次迭代后,响应对象超时(System.Net.WebException = "The operation has timed out")。我的第一个想法是请求被快速发送,所以我在循环中插入了一个 Sleep(2000) ,但这似乎没有效果。我检查了失败的 url 并将它们粘贴到浏览器中,它们确实返回了正确的数据。

据我了解,此 api 调用的唯一限制是我使用未经验证的帐户每天获得 1000 次。我错过了什么?

编辑:这是程序块的其余部分:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Net;
using System.IO;
using System.Web;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
using GooglePlacesJSONGenerator.Models;

namespace GooglePlacesJSONGenerator
{
class Program
{
    static void Main(string[] args)
    {
        //set up a list of zips
        List<string> zipcodeList = new List<string>();
        zipcodeList.Add("57754");
        zipcodeList.Add("57783");
        zipcodeList.Add("57785");

        //setup a list of business types
        List<string> businessTypeList = new List<string>();
        businessTypeList.Add("restaurants");
        businessTypeList.Add("dentist");
        businessTypeList.Add("gym");

        //main data set
        GooglePlaceDataSet places = new GooglePlaceDataSet();

        //base url
        string urlBase = "https://maps.googleapis.com/maps/api/place/textsearch/json?key=MY_API_KEY_HERE&sensor=false&query=";
        string nextUrlBase = urlBase + "&pagetoken=";
        Stream objStream;
        //loop on zip codes
        foreach (string zip in zipcodeList)
        {
            Console.WriteLine("looping on zip " + zip);

            //loop on business type
            foreach (string type in businessTypeList)
            {
                Console.WriteLine("loop on type " + type);

                string sURL;
                string query = HttpUtility.UrlEncode(zip + " " + type);
                sURL = urlBase + query;
                Console.WriteLine("Query String: " + query);
                while (sURL != "")
                {

                    Console.WriteLine("Our URL:  " + sURL);
                    Console.WriteLine("");

                    StreamReader objReader = MakeWebRequest(sURL);

                    JsonTextReader reader = new JsonTextReader(objReader);

                    JsonSerializer se = new JsonSerializer();
                    string parsedData = se.Deserialize(reader).ToString();
                    GooglePlaceDataSet gSet = JsonConvert.DeserializeObject<GooglePlaceDataSet>(parsedData);

                    foreach (GooglePlaceData place in gSet.results)
                    {
                        places.results.Add(place);
                    }

                    if (gSet.next_page_token != null)
                        sURL = nextUrlBase + gSet.next_page_token;
                    else
                    sURL = "";

                    System.Threading.Thread.Sleep(2000);
                }
            }
        }
        Console.ReadLine();
    }
4

2 回答 2

2

答案是“不要忘记显而易见的事情”。StreamReader 对象需要关闭。一旦我关闭它,上面的代码就起作用了。

于 2012-07-23T14:02:14.490 回答
0

这可能是超出服务提供商允许的来自同一源地址的最大同时连接数的阈值的结果。您必须通过 using 或 try/finally 正确 Dispose() 资源,否则连接将保持打开状态,直到垃圾收集器处理资源。请参阅C# .NET 中的 Web 响应不工作超过几次C# https 登录和下载文件,其中有相关内容。

于 2012-07-17T18:37:57.317 回答