HttpResponseMessageProperty.SuppressPreamble Propriedade
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Obtém ou define se o preâmbulo da mensagem é suprimido.
public:
property bool SuppressPreamble { bool get(); void set(bool value); };
public bool SuppressPreamble { get; set; }
member this.SuppressPreamble : bool with get, set
Public Property SuppressPreamble As Boolean
Valor de Propriedade
true se o preâmbulo da mensagem for suprimido; caso contrário, false.
Observações
A SuppressPreamble propriedade permite aos utilizadores escrever conteúdo a OutputStream partir do corpo de uma operação WCF. Isto aplica-se apenas em cenários alojados na web. A SuppressPreamble propriedade é false por defeito.
Warning
Se a SuppressPreamble propriedade estiver definida para true, tens de definir os cabeçalhos, o tipo de conteúdo e o código de estado na resposta porque o WCF já não o faz.
O código seguinte mostra um exemplo de como fazer isto.
public class Service1 : IService1
{
public void GetData()
{
HttpContext hc = HttpContext.Current;
string str = @"<?xml version=""1.0"" encoding=""utf-8"" ?>";
var buffer = new byte[str.Length];
buffer = ASCIIEncoding.UTF8.GetBytes(str);
// Enable the property.
var responseProperty = new HttpResponseMessageProperty();
responseProperty.SuppressPreamble = true;
OperationContext.Current.OutgoingMessageProperties[HttpResponseMessageProperty.Name] = responseProperty;
// Set the response.
hc.Response.StatusCode = 200;
hc.Response.ContentType = "text/xml; charset=utf-8";
hc.Response.ClearContent();
hc.Response.Flush();
hc.Response.OutputStream.Write(buffer, 0, buffer.Length);
hc.Response.Flush();
}
}