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);
}
导致标题出错。
导致这种情况的原因是什么?
答案 0 :(得分:2)
显然,错误行中的userID
无法转换为整数。您可以添加断点,查看变量的实际值,然后修改代码。
int userIDInt;
if (int.TryParse(userID, out userIDInt))
{
if (userIDInt == loggedID)
// ...
}
else
// handle the error