批量查询到Web服务返回“Uri字符串太长”

时间:2013-01-24 15:05:23

标签: c# web-services http-post wcf-data-services http-get

我正在尝试向服务器发送大请求并获取大数据。所以我使用批量请求到数据服务。此请求的URI看起来像“hxxp://company/Test.svc/$batch”。我正在使用.Net 4.0

我发送有效的POST请求:

DataServiceRequest[] Request = new DataServiceRequest[]{new DataServiceRequest<TTable>((query).RequestUri)};
try
{
    DataServiceResponse dsr = WebService.ExecuteBatch(Request);
    foreach (QueryOperationResponse qr in dsr)
    {
        if (qr.Query.ElementType == typeof(TTable))
        {
            foreach (TTable item in qr) { list.Add(item); }
        }
    }
}

并收到错误消息:

<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<error xmlns="http://schemas.microsoft.com/ado/2007/08/dataservices/metadata">
  <code></code>
  <message xml:lang="ru-RU">An error occurred while processing this request.</message>
  <innererror>
    <message>Invalid URI: The Uri string is too long.</message>
    <type>System.UriFormatException</type>
    <stacktrace>   at System.Uri.CreateThis(String uri, Boolean dontEscape, UriKind uriKind)&#xD;
   at System.Uri..ctor(String uriString, UriKind uriKind)&#xD;
   at System.Data.Services.RequestUriProcessor.GetAbsoluteUriFromReference(String reference, Uri absoluteServiceUri)&#xD;
   at System.Data.Services.BatchServiceHost..ctor(Uri absoluteServiceUri, BatchStream batchStream, String contentId, String boundary, StreamWriter writer)&#xD;
   at System.Data.Services.DataService`1.BatchDataService.CreateOperationContextFromBatchStream(Uri absoluteServiceUri, BatchStream batchStream, HashSet`1 contentIds, String boundary, StreamWriter writer)&#xD;
   at System.Data.Services.DataService`1.BatchDataService.HandleBatchContent(Stream responseStream)</stacktrace>
  </innererror>
</error>

似乎服务器端异常,在尝试解析大uri时发生。如何避免这种限制?

MODIFIED(2013年1月28日16:00)

IIS配置:

<?xml version="1.0"?>
<configuration>
  <system.webServer>
    <security>
      <requestFiltering>
        <requestLimits maxAllowedContentLength="500000000" maxQueryString="209715000" maxUrl="2000000"></requestLimits>
      </requestFiltering>
    </security>
    <directoryBrowse enabled="true"/>
    <httpErrors errorMode="Detailed"/>
    <caching enabled="false" enableKernelCache="false"/>
  </system.webServer>
  <system.web>
    <httpRuntime executionTimeout="4800"
      maxQueryStringLength="2097150" 
      maxUrlLength="2097150"
      relaxedUrlToFileSystemMapping="true"
       maxRequestLength="500000000"
      requestValidationMode="4.0"/>
    <customErrors mode="Off"/>
    <compilation debug="true" targetFramework="4.0">
      <assemblies>
        <add assembly="System.Data.Entity, Version=4.0.0.0, Culture=neutral, PublicKeyToken=B77A5C561934E089" />
        <add assembly="System.Data.Services, Version=4.0.0.0, Culture=neutral, PublicKeyToken=B77A5C561934E089" />
        <add assembly="System.Data.Services.Client, Version=4.0.0.0, Culture=neutral, PublicKeyToken=B77A5C561934E089" />
      </assemblies>
    </compilation>
  </system.web>
</configuration>

1 个答案:

答案 0 :(得分:0)

如果您使用的是IIS,我相信您可以通过转到请求过滤&gt;来增加最大网址大小。编辑功能设置&gt;最大URL长度。

以下指南可以帮助您进一步:http://www.iis.net/configreference/system.webserver/security/requestfiltering/requestlimits