4

ここに私のコードがあります: これはフィドラーによって呼び出される関数です:

http://localhost:3334/Service/Login/?json={'username':'cara','password':'password'}

public ActionResult Login(JObject JSON)
{
    var response = JsonResponse.OKResponse();
    var username = JSON["username"].ToString();
    var password = JSON["password"].ToString();

    var helper = new MemberHelper();

    //goes into here and never returns
    if (helper.ValidateUser(username, password))
    {
        MongoCollection<User> users = db.GetCollection<User>();
        var usr = users.FindAll().FirstOrDefault(u => u.UserName.Equals(username));
        response.data.Add(usr);
    }
    else
    {
        return Json(JsonResponse.ErrorResponse("Invalid username or password provided!"), JsonRequestBehavior.AllowGet);
    }

    return Json(response, JsonRequestBehavior.AllowGet);
}

MemberHelper 内の validateUser メソッド:

public override bool ValidateUser(string username, string password)
{
    var hash = Encoding.ASCII.GetBytes(password);
    var provider = new SHA256CryptoServiceProvider();
    for (int i = 0; i < 1024; i++) // 1024 round SHA256 is decent
         hash = provider.ComputeHash(hash);
    var pass = Convert.ToBase64String(hash);


    MongoCollection<User> users = db.GetCollection<User>();

    //***The following statement is where the program just stops***    
    var usr = users.FindAll().FirstOrDefault(u => u.UserName.Equals(username) && u.Password.Equals(pass));
   ...
}

そしてgetCollection....

public MongoCollection<T> GetCollection<T>(string name = null)
{
    string collectionName = name; 
    if (collectionName == null) { 
        collectionName = typeof(T).Name; 
    }
    return Database.GetCollection<T>(collectionName); 
}

何がうまくいかないのか本当にわかりません。私はlinqを初めて使用するので、破っている黄金律があるかどうかはわかりません。助けてください!他に追加する必要がある場合はお知らせください。

4

2 に答える 2

0

問題は確かに GetCollection<>() メソッド内にあり、次のコードに置き換えると、問題なく機能しました。

public MongoCollection<T> GetCollection<T>(string name = null)
        {
            string collectionName = name;
            if (collectionName == null)
                collectionName = typeof(T).Name;
            if (Database.CollectionExists(collectionName) == false)
                Database.CreateCollection(collectionName);
            return Database.GetCollection<T>(collectionName);
        }
于 2012-05-16T18:09:29.533 に答える
0

次のように変更することもできます

var usr = users.AsQueryable().Where(u => u.UserName.Equals(username)).FirstOrDefault();
于 2012-05-14T19:53:06.767 に答える