0

1 日か 2 日に 1 回、Web サイトがスローされ始め、ユーザーがログインしようとするとエラーが発生し、IIS を再起動するまで誰もログインできなくなります。Any() でこれを行うにはどうすればよいですか? また、修正するにはどうすればよいですか?

例外をスローする関数は次のとおりです。

        public override bool ValidateUser(string username, string password)
    {
        var db = Access.Context;
        var query =
            from p in db.Players
            where p.PlayerName == username
                && p.Password == password 
            select p
        ;
        return query.Any();
    }

他の LINQ to SQL クエリは問題なく動作します。これがスタックトレースです。

InvalidOperationException: Sequence contains no elements 

   System.Data.Linq.SqlClient.SqlProvider.Execute(Expression query, QueryInfo queryInfo, IObjectReaderFactory factory, Object[] parentArgs, Object[] userArgs, ICompiledSubQuery[] subQueries, Object lastResult) +1151
    System.Data.Linq.SqlClient.SqlProvider.ExecuteAll(Expression query, QueryInfo[] queryInfos, IObjectReaderFactory factory, Object[] userArguments, ICompiledSubQuery[] subQueries) +113
    System.Data.Linq.SqlClient.SqlProvider.System.Data.Linq.Provider.IProvider.Execute(Expression query) +344
    System.Data.Linq.DataQuery`1.System.Linq.IQueryProvider.Execute(Expression expression) +23
    System.Linq.Queryable.Any(IQueryable`1 source) +243
    FortyTwoAccess.PlayerProvider.ValidateUser(String username, String password) in C:\dev\FortyTwo\FortyTwoAccess\PlayerProvider.cs:114
    FortyTwoClient.Models.AccountMembershipService.ValidateUser(String userName, String password) in C:\dev\FortyTwo\FortyTwoClient\Models\AccountModels.cs:117
    FortyTwoClient.Controllers.AccountController.LogOn(LogOnModel model, String returnUrl) in C:\dev\FortyTwo\FortyTwoClient\Controllers\AccountController.cs:42
    lambda_method(Closure , ControllerBase , Object[] ) +157
    System.Web.Mvc.ActionMethodDispatcher.Execute(ControllerBase controller, Object[] parameters) +17
4

2 に答える 2

0

これに対する修正は、コンテキストを保存するためにクラス変数を使用せず、代わりにusingでラップされた各メソッドでコンテキストをローカルにインスタンス化することでした。

于 2013-01-30T04:39:57.113 に答える
0

これは機能しますか?

public override bool ValidateUser(string username, string password)
{
    var db = Access.Context;
    return db.Players.Any(p => p.PlayerName == username && p.Password == password);
}
于 2013-01-08T13:36:54.453 に答える