从数据库 C# 下载照片
本文关键字:照片 下载 数据库 | 更新日期: 2023-09-27 18:36:16
我尝试从数据库中下载照片。在数据库中,字段类型为图像。该 ID 的类型为唯一标识符。我的代码
public void ProcessRequest (HttpContext context) {
ConnectTodatabase conection = new ConnectTodatabase();
conection.makeConnection();
// Create SQL Command
SqlCommand cmd = new SqlCommand("Select ID,photo from profile where ID=@ID", conection.Connection);
SqlParameter ImageID = new SqlParameter("@ID", System.Data.SqlDbType.UniqueIdentifier);
ImageID.Value = context.Request.QueryString["ID"];
cmd.Parameters.Add(ImageID);
SqlDataReader dReader = cmd.ExecuteReader();
dReader.Read();
context.Response.BinaryWrite((byte[])dReader["photo"]);
dReader.Close();
context.Response.ContentType = "text/plain";
context.Response.Write("test 123456");
}
异常是 InvalidCastException。"无法将参数值从字符串转换为 GUID。"如何将图像ID传递给正确的类型?谢谢!!!
调用处理程序
foreach (DataRow theRow in thisDataSet.Tables["Profile"].Rows)
{
resultCounter++;
double x, y;
x = Convert.ToDouble(theRow["lat"]);
y = Convert.ToDouble(theRow["lng"]);
string id = Convert.ToString(theRow["ID"]);
GLatLng latlng = new GLatLng(x, y);//sintetagmenes shmeiou
//dimiourgia ton 2 ipomenou gia kathe shmeio
GInfoWindowTabs iwTabs = new GInfoWindowTabs();
iwTabs.point = latlng;
System.Collections.Generic.List<GInfoWindowTab> tabs = new System.Collections.Generic.List<GInfoWindowTab>();
tabs.Add(new GInfoWindowTab("Profile Info:", "<table> <tr> <td><b>Name: </b> </td><td>" + theRow["fname"] + "</td></tr><tr><td><b>Lastname: </b></td><td>" + theRow["lname"] + "</td></tr><tr><td><b>Affiliation: </b></td><td>" + theRow["affiliation"] + "</td></tr><tr><td><b>Address: </b></td><td>" + theRow["address"] + "</td></tr><tr><td><b>Country: </b></td><td>" + theRow["country"] + "</td></tr><tr><td><b>Email: </b></td><td>" + theRow["email"] + "</td></tr><tr><td><b>Role: </b></td><td>" + theRow["role"]));
tabs.Add(new GInfoWindowTab("Profile Photo:", "<img src=Handler.ashx?ID=" + theRow["ID"] + "border=1>"));
试试这个,看看它是否有效:
SqlParameter ImageID = new SqlParameter("@ID", System.Data.SqlDbType.UniqueIdentifier);
ImageID.Value = System.Data.SqlTypes.SqlGuid.Parse(context.Request.QueryString["ID"]);
此处的关键是将字符串转换为 GUID。
编辑
我注意到您所做的编辑包括您的调用处理程序。 我在调用处理程序中看到的两个明显问题是,您创建了一个 id 变量来保存转换后的 GUID,但您没有准确使用它。 此外,您没有使用与号正确分隔边界查询参数:&
更改此设置:
tabs.Add(new GInfoWindowTab("Profile Photo:", "<img src=Handler.ashx?ID=" + theRow["ID"] + "border=1>"));
对此:
tabs.Add(new GInfoWindowTab("Profile Photo:", "<img src=Handler.ashx?ID=" + id + "&border=1>"));
因此,从本质上讲,您将其作为您的 ID:5a6b4047-e2dc-40d8-9c58-8609278154f4border=1
发送,这不是有效的 GUID。
作为提示,我会这样做,这可能会更容易发现您的 Type-O:
tabs.Add(new GInfoWindowTab("Profile Photo:", string.Format("<img src=Handler.ashx?ID={0}&border=1>", id)));
Guid ImageGUID = new Guid(context.Request.QueryString["ID"]);
ImageID.Value = ImageGUID;