Image内容转换为byte[]的问题

asbeforelong 2007-12-16 10:10:58
dr是SqlDataReader
photo是数据库中的Image字段
如果某条记录的photo字段不为空,
则(byte[])dr["photo"]转换不会出错
可是如果photo字段为空,就会报“指定的转换无效。”的错误!

指定的转换无效。
说明: 执行当前 Web 请求期间,出现未处理的异常。
请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。

异常详细信息: System.InvalidCastException: 指定的转换无效。

源错误:
行 169: this.zipcode = dr["zipcode"].ToString();
行 170: this.phone = dr["phone"].ToString();
行 171: this.photo = (byte[])dr["photo"];



...全文
209 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
eyuannet 2008-01-05
  • 打赏
  • 举报
回复
try它
insus 2008-01-05
  • 打赏
  • 举报
回复
if (obj.getMember().Rows.Count > 0) //这里要做判断,如是记录为空,即不会执行下面的语句.
{
DataRow dr = obj.getMember().Rows[0];
this.zipcode = dr["zipcode"].ToString();
this.phone = dr["phone"].ToString();
//...
}

另我,我不知你这个this.Phone是什么?如是byte[]类型的,即可.

byte[] buffer = (byte[])dr["Photo"];
Response.BinaryWrite(buffer);
jnbruce 2007-12-16
  • 打赏
  • 举报
回复
你可以单步调试下,看看当图像没有时,你的if语句到底有没有执行。
asbeforelong 2007-12-16
  • 打赏
  • 举报
回复
行 171: if(dr["photo"]!=null)
行 172: this.photo = (byte[])dr["photo"];


依然出现上面的错误.... :(
zhangjjhua 2007-12-16
  • 打赏
  • 举报
回复
这个当然了,你把空,转换为 byte[] 当然是错的了,你可以先判断一下,是否为空,不为空就转换
Moose 2007-12-16
  • 打赏
  • 举报
回复
if (dr["photo"] != DBNull.Value) {
this.photo = (byte[])dr["photo"];
}


DBNull.Value != null
eastfar 2007-12-16
  • 打赏
  • 举报
回复
你可以单步调试下,

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧