gpt4 book ai didi

c# - 当操作返回元页面 html 时,如何更好地诊断 WCF 服务?

转载 作者:行者123 更新时间:2023-11-30 12:51:22 27 4
gpt4 key购买 nike

我有一个托管在 IIS7.5 (.NET 4) 中的 WCF 服务应用程序 (wsHttpBinding),我可以在浏览器中导航 .svc 文件,元数据页面成功显示,并且可以从 wsdl 生成客户端。

我已经添加了我自己的自定义服务行为来记录未处理的异常(下面的“ErrorHandling”),并且我正在使用 MembershipProvider 作为服务凭证。这是我完整的 system.serviceModel 配置:

<system.serviceModel>
<diagnostics wmiProviderEnabled="true">
<messageLogging
logEntireMessage="true"
logMalformedMessages="true"
logMessagesAtServiceLevel="true"
logMessagesAtTransportLevel="true"
maxMessagesToLog="3000"
maxSizeOfMessageToLog="-1" />
</diagnostics>
<extensions>
<behaviorExtensions>
<add name="ErrorHandling" type="MyCompany.MyProduct.Services.ErrorHandlerBehavior, MyCompany.MyProduct.Services" />
</behaviorExtensions>
</extensions>
<services>
<service name="MyCompany.MyProduct.Services.ApplicationService" behaviorConfiguration="MyProductServiceBehavior">
<endpoint bindingConfiguration="MyProductWsHttpBinding" binding="wsHttpBinding" contract="MyCompany.MyProduct.Services.IApplicationService" />
</service>
<service name="MyCompany.MyProduct.Services.AccountService" behaviorConfiguration="MyProductServiceBehavior">
<endpoint bindingConfiguration="MyProductWsHttpBinding" binding="wsHttpBinding" contract="MyCompany.MyProduct.Services.IAccountService" />
</service>
<service name="MyCompany.MyProduct.Services.InvoiceService" behaviorConfiguration="MyProductServiceBehavior">
<endpoint bindingConfiguration="MyProductWsHttpBinding" binding="wsHttpBinding" contract="MyCompany.MyProduct.Services.IInvoiceService" />
</service>
<service name="MyCompany.MyProduct.Services.ReportService" behaviorConfiguration="MyProductServiceBehavior">
<endpoint bindingConfiguration="MyProductWsHttpBinding" binding="wsHttpBinding" contract="MyCompany.MyProduct.Services.IReportService" />
</service>
<service name="MyCompany.MyProduct.Services.PaymentService" behaviorConfiguration="MyProductServiceBehavior">
<endpoint bindingConfiguration="MyProductWsHttpBinding" binding="wsHttpBinding" contract="MyCompany.MyProduct.Services.IPaymentService" />
</service>
</services>
<bindings>
<wsHttpBinding>
<binding name="MyProductWsHttpBinding">
<security mode="Message">
<message clientCredentialType="UserName" establishSecurityContext="true" negotiateServiceCredential="true" />
</security>
</binding>
</wsHttpBinding>
</bindings>
<behaviors>
<serviceBehaviors>
<behavior name="MyProductServiceBehavior">
<serviceMetadata httpGetEnabled="true" />
<serviceDebug includeExceptionDetailInFaults="true" />
<serviceCredentials>
<serviceCertificate findValue="MyProductServices" storeLocation="CurrentUser" storeName="My" x509FindType="FindBySubjectName" />
<userNameAuthentication userNamePasswordValidationMode="MembershipProvider" membershipProviderName="AspNetSqlMembershipProvider" />
</serviceCredentials>
<ErrorHandling />
<serviceSecurityAudit auditLogLocation="Application" suppressAuditFailure="false" serviceAuthorizationAuditLevel="SuccessOrFailure" messageAuthenticationAuditLevel="SuccessOrFailure" />
</behavior>
</serviceBehaviors>
</behaviors>
<serviceHostingEnvironment multipleSiteBindingsEnabled="true" aspNetCompatibilityEnabled="true" />
</system.serviceModel>

您可以看到我还启用了安全审核,但是事件日志中除了显示消息日志记录已打开的消息外什么都没有显示。因此,当客户端调用操作时,它似乎永远不会进入身份验证阶段。

我还启用了跟踪功能,如下所示:

<system.diagnostics>
<sources>
<source name="System.ServiceModel"
switchValue="All"
propagateActivity="true" >
<listeners>
<add name="xml"/>
</listeners>
</source>
<source name="System.ServiceModel.MessageLogging" switchValue="All">
<listeners>
<add name="xml"/>
</listeners>
</source>
<source name="myUserTraceSource"
switchValue="Information, ActivityTracing">
<listeners>
<add name="xml"/>
</listeners>
</source>
</sources>
<sharedListeners>
<add name="xml"
type="System.Diagnostics.XmlWriterTraceListener"
initializeData="C:\Users\Public\Documents\services.svclog" />
</sharedListeners>
</system.diagnostics>

当客户端调用主要服务中的主要操作时,它会收到带有此消息的协议(protocol)异常:

内容类型text/html;响应消息的 charset=UTF-8 与绑定(bind)的内容类型不匹配(application/soap+xml;charset=utf-8)。如果使用自定义编码器,请确保正确实现 IsContentTypeSupported 方法。响应的前 1024 个字节是:'#content{ FONT-SIZE: 0.7em;底部填充:2em;边距-左:30px}主体{边距-顶部:0px;左边距:0px;颜色:#000000;字体系列:Verdana; BACKGROUND-COLOR: white}P{MARGIN-TOP: 0px;底部边距:12px;颜色:#000000;字体系列:Verdana}PRE{BORDER-RIGHT:#f0f0e0 1px solid;填充右:5px;边框顶部:#f0f0e0 1px 实心;边距顶部:-5px;填充-左:5px;字体大小:1.2em;底部填充:5px;左边框:#f0f0e0 1px 纯色;填充顶部:5px; BORDER-BOTTOM:#f0f0e0 1px 实心;字体系列:Courier New;背景颜色:#e5e5cc}.heading1{MARGIN-TOP: 0px;左填充:15px;字体粗细:正常;字体大小:26px;底部边距:0px;底部填充:3px;左边距:-30px;宽度:100%;颜色:#ffffff;填充顶部:10px;字体系列:Tahoma; BACKGROUND-COLOR: #003366}.intro{MARGIN-LEFT: -15px}ApplicationService 服务'。

当您浏览到 .svc 文件时,这是您看到的元数据页面的 html。因此,服务似乎正在返回该页面作为对操作的响应。

查看 services.svclog 说明了同样的情况,实际上日志是格式错误的 xml,因为此响应包含在其中而没有转义标签。跟踪中没有任何有用的信息。

服务器上没有抛出异常,日志没有任何内容。这一切都在我设置的另一台服务器上的 IIS6 上运行,只是为了测试它,错误日志记录也在那里运行。

哪些工具和技术可以帮助我找出根本问题所在?

更新:这是服务器端跟踪来自新生成的控制台应用程序客户端的单个请求的 svclog(经过清理以删除个人信息),请注意它在末尾如何被截断: http://pastebin.com/mksL0FFY

最佳答案

由于事件日志为空,您应该检查 IIS 日志以确保调用成功。我遇到过类似的错误消息,问题通常与权限有关。检查用于应用程序池和网站的帐户是否具有足够的权限。我认为如果在成员(member)提供者身份验证时出现问题,您会看到一条事件日志消息。此外,尝试使用 WcfTestClient 应用程序调用该方法,以便您可以看到以各种方式传输的 XML。

关于c# - 当操作返回元页面 html 时,如何更好地诊断 WCF 服务?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7208293/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com