j ai besoin de votre aide mes amis .. j ai trouvé une difficulté lors d afficher les fichiers dans la base lorsque leurs valeurs sont nulle ..
je ne sais pas comment gérer l exception !!
voici le code
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
  protected void DownloadFile(object sender, EventArgs e)
        { 
 
 
            int id = int.Parse((sender as LinkButton).CommandArgument);
            byte[] bytes;
            string fileName, contentType;
 
            using (SqlConnection con = new SqlConnection("Data Source=OUSSAMA-PC;Initial Catalog=eva;Integrated Security=True"))
            {
                using (SqlCommand cmd = new SqlCommand())
                {
                    cmd.CommandText = "select id,soins,date_sejour,civilite,nom,prenom,date_naissance,email,gsm,adresse,code_postal,ville,pays,accompagnant,nbr_accompagnant,commentaire,connu_evamedica,Name,ContentType,Data from devis where id=@id";
                    cmd.Parameters.AddWithValue("@id", id);
                    cmd.Connection = con;
                    con.Open();
                    using (SqlDataReader sdr = cmd.ExecuteReader())
                    {
 
                        sdr.Read();
                        bytes = (byte[])sdr["Data"];
                        contentType = sdr["ContentType"].ToString();
                        fileName = sdr["Name"].ToString();
 
                    }
                    con.Close();
                }
            }
            Response.Clear();
            Response.Buffer = true;
            Response.Charset = "";
            Response.Cache.SetCacheability(HttpCacheability.NoCache);
            Response.ContentType = contentType;
            Response.AppendHeader("Content-Disposition", "attachment; filename=" + fileName);
            Response.BinaryWrite(bytes);
            Response.Flush();
            Response.End();
        }
            }
            }
le message d erreur c'est Impossible d'effectuer un cast d'un objet de type 'System.DBNull' en type 'System.Byte[]'.
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
Ligne 57 :                     {
Ligne 58 :                         sdr.Read();
Ligne 59 :                         bytes = (byte[])sdr["Data"];
Ligne 60 :                         contentType = sdr["ContentType"].ToString();
Ligne 61 :                         fileName = sdr["Name"].ToString();