“输入字符串的格式不正确。” C#

时间:2012-03-21 01:11:24

标签: c# razor casting error-handling asp.net-webpages

groupID是一些复选框。我正在尝试创建逗号分隔的UserID列表。 GroupID标识具有多个用户的组作为成员。所以我有:

      string groupIds = Request.Form["groupID"];
        if (groupIds!=null){
            string[] arrayOfGroupIds = groupIds.Split(','); //possible error here if only one checkbox is ticked?
            foreach (string id in arrayOfGroupIds){
                var users = db.Query("SELECT guestID FROM userGroups WHERE id = @0", id);
                foreach(var user in users){
                    userIds += user.guestID + ",";
                }
            }
        }   
        userIds += Request.Form["userId"] + "," + yourID;

在我的下一页,我然后打电话:

string userIDs = Request.Form["userIDs"];
string[] userIdsArray = userIDs.Split(',');
foreach(string userID in userIdsArray){
if(Convert.ToInt32(userID) == loggedID) { //ERROR HERE
        db.Execute("INSERT INTO Membership(GroupId,UserId) VALUES (@0, @1)", groupID, userID);
    }

导致标题出错。

导致这种情况的原因是什么?

1 个答案:

答案 0 :(得分:2)

显然,错误行中的userID无法转换为整数。您可以添加断点,查看变量的实际值,然后修改代码。

顺便说一下,你可以用更安全的方式进行转换。像

int userIDInt;
if (int.TryParse(userID, out userIDInt))
{
    if (userIDInt == loggedID)
       // ...
}
else
    // handle the error