验证用户输入C#

时间:2014-03-19 18:51:04

标签: c# sql validation user-input

如何检查用户是否在文本字段中输入了数字?如果他们确实输入了除文本之外的数据,我想要显示错误消息并循环返回以再次输入他们的输入..任何帮助将不胜感激。感谢。

以下是代码:

myCmd.CommandText = "INSERT INTO Guest(Guest_First_Name, Guest_Surname, Guest_Address, Guest_Postcode, Guest_Telephone, [Guest_E-mail])" + "VALUES(@Fname, @Sname, @Address, @Postcode, @Telephone, @Email)";

        myCmd.Parameters.Add("@Fname", OleDbType.Char).Value = firstName.Text;
        myCmd.Parameters.Add("@Sname", OleDbType.Char).Value = surname.Text;
        myCmd.Parameters.Add("@Address", OleDbType.Char).Value = address.Text;
        myCmd.Parameters.Add("@Postcode", OleDbType.Char).Value = postcode.Text;
        myCmd.Parameters.Add("@Telephone", OleDbType.Char).Value = telephone.Text;
        myCmd.Parameters.Add("@Email", OleDbType.Char).Value = email.Text;

        connect.Open();
        int rowsChanged = myCmd.ExecuteNonQuery();
        connect.Close();

        if (rowsChanged == 1)
        {
            MessageBox.Show("Record Inserted");
        }
        else
        {
            MessageBox.Show("Error: Record Not Inserted");
        }

3 个答案:

答案 0 :(得分:2)

让我们假设textField是字段的名称。然后,您可以在C#中执行以下操作: -

int num=0;
if(!(Int32.TryParse(textField,out num)))
{
Console.WriteLine("Error");
return;  // return an error at this point
}

您还可以尝试以下(未经测试): -

int num=0;
if(!(Int32.TryParse(textField,NumberStyles.None,CultureInfo.InvariantCulture,out num)))
{
Console.WriteLine("Error");
return;  // return an error at this point
}

在第一个示例中,NumberStyles默认为Integer。将其更改为无可能会有所帮助。

答案 1 :(得分:1)

可以使用这样的东西:

private void textBox1_TextChanged(object sender, EventArgs e)
{
    textBox1.Text = string.Concat(textBox1.Text.Where(char.IsLetter));
}

这不会显示任何错误;除了字母以外的任何内容都会被删除。

答案 2 :(得分:0)

int result;
if (int.TryParse(input.Text, out result))
{
    // it's a valid integer => you could use the result variable here
}

或者如果你想在按键中验证,

private void txtbox1_KeyPress(object sender, KeyPressEventArgs e)
{
    if (e.KeyChar >= '0' && e.KeyChar <= '9' || e.KeyChar == '')  
    {
        e.Handled = false; //Do not reject the input
    }
    else
    {
        e.Handled = true; //Reject the input
    }
}