FormUrlEncodedContent
内部使用Uri.EscapeDataString
:从反射,我可以看到,这种方法有限制请求长度的常量。
可能的解决方案是通过使用System.Net.WebUtility.UrlEncode
(.net 4.5)来绕过此限制创建FormUrlEncodedContent
的新实现。
public class MyFormUrlEncodedContent : ByteArrayContent
{
public MyFormUrlEncodedContent(IEnumerable<KeyValuePair<string, string>> nameValueCollection)
: base(MyFormUrlEncodedContent.GetContentByteArray(nameValueCollection))
{
base.Headers.ContentType = new MediaTypeHeaderValue("application/x-www-form-urlencoded");
}
private static byte[] GetContentByteArray(IEnumerable<KeyValuePair<string, string>> nameValueCollection)
{
if (nameValueCollection == null)
{
throw new ArgumentNullException("nameValueCollection");
}
StringBuilder stringBuilder = new StringBuilder();
foreach (KeyValuePair<string, string> current in nameValueCollection)
{
if (stringBuilder.Length > 0)
{
stringBuilder.Append('&');
}
stringBuilder.Append(MyFormUrlEncodedContent.Encode(current.Key));
stringBuilder.Append('=');
stringBuilder.Append(MyFormUrlEncodedContent.Encode(current.Value));
}
return Encoding.Default.GetBytes(stringBuilder.ToString());
}
private static string Encode(string data)
{
if (string.IsNullOrEmpty(data))
{
return string.Empty;
}
return System.Net.WebUtility.UrlEncode(data).Replace("%20", "+");
}
}
要发送大内容,最好使用StreamContent。
Post'StreamContent' –
我很困惑......当你使用任何类型的'HttpContent'(包括'FormUrlEncodedContent')时,数据在主体中,而不在Url ..所以你为什么要在Url中看到数据? –
当我拨打以下电话时, dict.Add(new KeyValuePair(“Base64FileData”,image)); (其中image是base 64转换后的字符串)。抛出异常。 –
Muraad