2012-01-04 42 views
7

我有我的aspx页面显示图像使用ashx的处理程序

<td> 
<asp:Image ID="LargeImage" runat="server" Height="100" Width="100" />" 

</td> 

在我的aspx.cs,分配IMAGEURL到该图像

protected void uploadimage_Click(object sender, System.EventArgs e) 
     { 

      ImageUtils.uploadImage(Titletxt.Text, FileUpload.FileContent); 
      LargeImage.ImageUrl = "~/AvatarImageFetch.ashx?memberid=" + memberid.ToString(); 
} 

出于某种原因,图像没有按以下图片没有出现。这是我的ashx

public void ProcessRequest(HttpContext context) 
     { 
      SqlConnection myConnection = new SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings["FMMImages"].ConnectionString); 

      myConnection.Open(); 
      string sql = "select largeimage from images_temp where [email protected]"; 
      SqlCommand cmd = new SqlCommand(sql, myConnection); 
      int param; 
      int.TryParse(context.Request.QueryString["memberid"], out param); 
      cmd.Parameters.Add("@memberid", SqlDbType.Int).Value = param; 
      //cmd.Parameters.Add("@GuID", SqlDbType.UniqueIdentifier).Value = context.Request.QueryString["UID"].ToString(); 

      cmd.CommandType = System.Data.CommandType.Text; 

      SqlDataReader dReader = cmd.ExecuteReader(); 
      dReader.Read(); 
      context.Response.BinaryWrite((byte[])dReader["largeimage"]); 
      dReader.Close(); 
      myConnection.Close(); 


     } 

另外,我在ashx处理程序中有一个断点。看起来处理程序没有开火。

+0

的是,在ashx的文件本身,还是后面的代码(即.ashx.cs文件)? – Richard 2012-01-04 20:58:46

回答

6

尝试在你的ProcessRequest方法如下:

context.Response.ContentType = "image"; 

using (System.IO.MemoryStream str = new System.IO.MemoryStream(objData.ToArray(), true)) 
{ 
     str.Write(objData.ToArray(), 0, objData.ToArray().Length); 
     Byte[] bytes = str.ToArray(); 
     context.Response.BinaryWrite(bytes); 
} 

其中objData是你从数据库中读取值

+0

感谢二进制写! – 2012-07-03 03:56:00

1

ImageUrl仅替换了中的波浪号(〜)控制标记。

试试这个:

string imageUrl = "~/AvatarImageFetch.ashx?memberid=" + memberid.ToString(); 
LargeImage.ImageUrl = Page.ResolveUrl(imageUrl); 
+0

哦,你还需要context.Response.ContentType =“image”部分。 – Richard 2012-01-04 21:08:38

相关问题