Asp.net mvc 4 OAuthWebSecurity.VerifyAuthenticationIssuccessful返回false如何确定原因?
我正在将DotNetOpenAuth与MVC4应用程序一起使用。Google auth突然出现故障(MS正在工作)。股票代码执行以下操作:Asp.net mvc 4 OAuthWebSecurity.VerifyAuthenticationIssuccessful返回false如何确定原因?,asp.net-mvc-4,dotnetopenauth,Asp.net Mvc 4,Dotnetopenauth,我正在将DotNetOpenAuth与MVC4应用程序一起使用。Google auth突然出现故障(MS正在工作)。股票代码执行以下操作: [AllowAnonymous] public ActionResult ExternalLoginCallback(string returnUrl) { var result = OAuthWebSecurity.VerifyAuthentication(Url.Action("ExternalLoginCallback", new { Retu
[AllowAnonymous]
public ActionResult ExternalLoginCallback(string returnUrl)
{
var result = OAuthWebSecurity.VerifyAuthentication(Url.Action("ExternalLoginCallback", new { ReturnUrl = returnUrl }));
if (!result.IsSuccessful)
{
return RedirectToAction("ExternalLoginFailure");
}
我知道result.issusccessful
是假的,但是我如何才能得到原因呢<代码>结果。错误为空
我还研究了如何使用log4net。我确实在本地dev box上获得了日志,但在将其部署到远程服务器时却没有
log4net网络配置:
<log4net>
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
<file value="RelyingParty.log" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="10" />
<maximumFileSize value="100KB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date (GMT%date{%z}) [%thread] %-5level %logger - %message%newline" />
</layout>
</appender>
<!-- Setup the root category, add the appenders and set the default level -->
<root>
<level value="INFO" />
<appender-ref ref="RollingFileAppender" />
</root>
<!-- Specify the level for some specific categories -->
<logger name="DotNetOpenAuth">
<level value="ALL" />
</logger>
</log4net>
编辑我还尝试将log4net添加到sql db,但它仍然没有记录任何内容我最终找到了答案。我收到的实际错误消息:
Protocol error: This message has a timestamp of 10/23/2012 12:19:33 PM,
which is beyond the allowable clock skew for in the future.
结果表明,服务器崩溃后,时区设置不正确。这导致验证/令牌从google端失败
AdoNetAppender
未工作,因为bufferSize
设置为100。将其设置为1后,它开始获取日志。这是我用的adonetappender
<log4net>
<appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender">
<bufferSize value="1" />
<connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
<connectionStringName value="CONNECTIONSTRINGNAME" />
<commandText value="INSERT INTO Log4Net ([Date],[Thread],[Level],[Logger],[Message],[Exception]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception)" />
<parameter>
<parameterName value="@log_date" />
<dbType value="DateTime" />
<layout type="log4net.Layout.RawTimeStampLayout" />
</parameter>
<parameter>
<parameterName value="@thread" />
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%thread" />
</layout>
</parameter>
<parameter>
<parameterName value="@log_level" />
<dbType value="String" />
<size value="50" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%level" />
</layout>
</parameter>
<parameter>
<parameterName value="@logger" />
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%logger" />
</layout>
</parameter>
<parameter>
<parameterName value="@message" />
<dbType value="String" />
<size value="4000" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%message" />
</layout>
</parameter>
<parameter>
<parameterName value="@exception" />
<dbType value="String" />
<size value="2000" />
<layout type="log4net.Layout.ExceptionLayout" />
</parameter>
</appender>
<root>
<level value="Debug" />
<appender-ref ref="AdoNetAppender" />
</root>
<logger name="DotNetOpenAuth">
<level value="ALL" />
</logger>
</log4net>
解决问题时,应将
bufferSize
设置回100。我也有同样的问题,但我没有使用log4net。那我怎么解决这个问题呢?嗯。。安装log4net?log4net是DotNetOpenAuth记录任何问题的方式。然后,要么就此提出问题,要么从日志中解决问题