Я написал очень простой веб-сервис, который возвращает XML-документ.
В настоящее время заголовок этого документа <?xml version="1.0" encoding="utf-8" ?>
, и я хотел бы, чтобы он возвращал <?xml version="1.0" encoding="utf-16" ?>
Как изменить выходную кодировку по умолчанию в .asmxили файл .cs?
smo.asmx
<%@ WebService Language="C#" Class="smo" %>
smo.asmx
using <blah>
[WebService(Namespace="http://www.bl.uk/webservices/")]
public class smo : WebService
{
[XmlRoot(ElementName = "SQLServer")]
public class CDatabaseBackup
{
public string ServerName;
public string DatabaseCount;
}
//
// Generic SMO query processor
//
[WebMethod(Description = "WMIClassProperty: ", EnableSession = false, CacheDuration=60)]
public CDatabaseBackup smoDatabaseBackupStatus(string SQLServerName)
{
CDatabaseBackup result = new CDatabaseBackup();
Server svr;
<blah>
return result;
}
В конечном итоге этот веб-сервис будет использоваться в функции SQL Server и преобразовываться в тип данных xml
.Согласно документации это должно быть UTF-16
.
alter
procedure monitor_sqlbackupaudit
as
begin
declare @l_xml_result nvarchar(max)
set @l_xml_result = ( select dbo.uspSMODatabaseBackup('sqlprod1vs') )
--set @l_xml_result = replace(@l_xml_result,'UTF-8','UTF-16');
declare @l_xml xml
set @l_xml = @l_xml_result
end
go
exec monitor_sqlbackupaudit
Msg 9402, Level 16, State 1, Procedure monitor_sqlbackupaudit, Line 15
XML parsing: line 1, character 38, unable to switch the encoding