2016-08-18 45 views
-1

当我尝试执行此函数时,出现错误 “System.InvalidCastException:指定的强制转换无效。”C#请求处理程序错误System.InvalidCastException:指定的强制转换无效

System.InvalidCastException: Specified cast is not valid. 
    at server.mihail.credits.HandleRequest() in F:\Users\Mihail\Documents\new-sentients-2016\server\mihail\credits.cs:line 34 
    at server.RequestHandler.HandleRequest(HttpListenerContext context) in F:\Users\Mihail\Documents\new-sentients-2016\server\RequestHandlers.cs:line 37 
    at server.Program.ProcessRequest(HttpListenerContext context) in F:\Users\Mihail\Documents\new-sentients-2016\server\Program.cs:line 156 

这是函数: 我尝试用GUID作为我的电子邮件地址和参数的援助与它的头号参数来执行它。

请帮助我,我一直试图整天修复它。

class credits : RequestHandler 
{ 
    protected override void HandleRequest() 
    { 
     string status = "403"; 
     using (Database db = new Database()) 
     { 
     NameValueCollection query = HttpUtility.ParseQueryString(Context.Request.Url.Query); 
     MySqlCommand cmd = db.CreateQuery(); 
     cmd.CommandText = "SELECT id FROM accounts WHERE [email protected]"; 
     cmd.Parameters.AddWithValue("@uuid", query["guid"]); 
     object id = cmd.ExecuteScalar(); 
     if (id != null) 
     { 
     int amount = int.Parse(query["aid"]); 
     cmd = db.CreateQuery(); 
     cmd.CommandText = "UPDATE stats SET credits = credits + @amount WHERE [email protected]"; 
       cmd.Parameters.AddWithValue("@accId", (int) id); 
       cmd.Parameters.AddWithValue("@amount", amount); 
       int result = cmd.ExecuteNonQuery(); 
       if (result > 0) 
        status = "400"; 
       else 
        status = "500"; 
      } 
      else 
       status = "404"; 
     } 
     byte[] res = Encoding.UTF8.GetBytes(
      status); 
     Context.Response.OutputStream.Write(res, 0, res.Length); 
    } 
} 
+2

哪一行是抛出异常?我不会计算'时间:) – SledgeHammer

+0

@LaneL你可以,如果它确实是一个盒装诠释。如果OP无法告诉我们什么是线路抛出异常,那么猜测什么是问题是没有意义的。 – Jakotheshadows

回答

1

根据您所提供的信息有限,它看起来像问题是与线cmd.Parameters.AddWithValue("@accId", (int) id);,因为这是与铸造中唯一的一行。

检查您的数据库中accounts.id列的类型,我怀疑它是不是一个INT,所以你需要改变投(括号内的类型)这是什么类型。一个SMALLINT是C#中的shortBIGINTlongTINYINTbyte(或sbyte),并且你需要看的文件,看看有什么MEDIUMINT地图,但它可能int

1

我注意到我有(int)在id之前,但它不是必需的,所以我只在ID之前删除了(int)。

这样我就可以

cmd.Parameters.AddWithValue("@accId", id); 
0

该行折腾这个错误我猜替换该行

cmd.Parameters.AddWithValue("@accId", (int) id); 

我可以看到从你的id变量发生的从对象到int的转换。

下可以显示你的问题

[TestMethod] 
    public void ObjectToInt() 
    { 
     object a = 2; 
     object b = "3"; 
     int aa = (int)a; 
     int bb = (int)b; // this throws the same error 
     var x = 1; 
    } 

也许使INT可空与诠释?或者看看对象的价值究竟是什么。

希望这会有所帮助。

相关问题