Все предыдущие ответы описывают проблему, не предоставляя решения. Вот метод расширения, который решает проблему, позволяя вам установить любой заголовок через его строковое имя.
Использование
HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest;
request.SetRawHeader("content-type", "application/json");
Класс расширения
public static class HttpWebRequestExtensions
{
static string[] RestrictedHeaders = new string[] {
"Accept",
"Connection",
"Content-Length",
"Content-Type",
"Date",
"Expect",
"Host",
"If-Modified-Since",
"Keep-Alive",
"Proxy-Connection",
"Range",
"Referer",
"Transfer-Encoding",
"User-Agent"
};
static Dictionary<string, PropertyInfo> HeaderProperties = new Dictionary<string, PropertyInfo>(StringComparer.OrdinalIgnoreCase);
static HttpWebRequestExtensions()
{
Type type = typeof(HttpWebRequest);
foreach (string header in RestrictedHeaders)
{
string propertyName = header.Replace("-", "");
PropertyInfo headerProperty = type.GetProperty(propertyName);
HeaderProperties[header] = headerProperty;
}
}
public static void SetRawHeader(this HttpWebRequest request, string name, string value)
{
if (HeaderProperties.ContainsKey(name))
{
PropertyInfo property = HeaderProperties[name];
if (property.PropertyType == typeof(DateTime))
property.SetValue(request, DateTime.Parse(value), null);
else if (property.PropertyType == typeof(bool))
property.SetValue(request, Boolean.Parse(value), null);
else if (property.PropertyType == typeof(long))
property.SetValue(request, Int64.Parse(value), null);
else
property.SetValue(request, value, null);
}
else
{
request.Headers[name] = value;
}
}
}
Сценарии
Я написал оболочку для HttpWebRequest
и не хотел показывать все 13 ограниченных заголовков в качестве свойств в моей оболочке. Вместо этого я хотел использовать простой Dictionary<string, string>
.
Другим примером является HTTP-прокси, где вам нужно взять заголовки в запросе и перенаправить их получателю.
Существует множество других сценариев, в которых просто нецелесообразно или невозможно использовать свойства. Принуждение пользователя устанавливать заголовок с помощью свойства - очень негибкая конструкция, поэтому необходимо отражение. Положительным моментом является то, что отражение отвлекается, оно все еще быстрое (0,001 секунды в моих тестах), а метод расширения выглядит естественным.
Примечания
Имена заголовков нечувствительны к регистру в RFC, http://www.w3.org/Protocols/rfc2616/rfc2616-sec4.html#sec4.2