Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 869
  • Last Modified:

Images created using ASP.NET won't open in photoshop

I am using asp.net C# to generate thumbnails of photos that I upload.  

With any photo that is created by ASP.NET - the following happens:

1) The thumbnails display fine on the web in both IE and and Firefox when show with an img tag
2) If I try to access the thumbnail directly by URL in IE then it shows up as blank.
3) If I save the images to my computer - or access them directly from the server
     a) In photoshop I get the following error :
               Could not open "thumb23.jpg" because an unknown or invalid JPEG marker type is found
     b) In ACDSee it opens fine.
     c) In Microsoft Paint - it opens fine
     d) In Microsoft Phot Editor It opens fine
     e) Doing "Open With" Internet Explorer - it produces a broken image icon
     f) Opening directly in Firefox works
 

Any ideas on what is causing the invalid JPEG marker and how to fix this problem (i.e. how to stop it from occuring?)

Here is the code I am using :

string fileName = Path.GetFileName(UploadedPhoto.PostedFile.FileName); // get current filename
// Save the photo to the web photos directory
UploadedPhoto.PostedFile.SaveAs(Path.Combine(serverDestDir, "Photo" + newPhotoID + fileName.ToLower().Substring(fileName.Length - 4, 4)));

// Create an image object holding the photo so we can work on it
System.Drawing.Image newPhoto = System.Drawing.Image.FromFile(Path.Combine(serverDestDir, "Photo" + newPhotoID + fileName.ToLower().Substring(fileName.Length - 4, 4)));

// Determine the thumbnail width and height
int newHeight = 75; // fixed
double tempWidth = newPhoto.Width * ((double)newHeight / (double)newPhoto.Height);
int newWidth = (int)tempWidth; // proportional based on image size

// Now create the thumbnail
CreateThumbnail(newPhoto, newWidth, newHeight, Server.MapPath(thumbDestDir + "thumb" + newPhotoID + fileName.ToLower().Substring(fileName.Length - 4, 4)));

// Dispose of newPhoto image object now that thumbnail is created
newPhoto.Dispose();


void CreateThumbnail(System.Drawing.Image Photo, int width, int height, string ThumbPath)
{
      // Callback - does nothing, but required for compatibility
      System.Drawing.Image.GetThumbnailImageAbort tnCallBack = new System.Drawing.Image.GetThumbnailImageAbort(tnCallbackMethod);

      // Get the thumbnail image - witdth, height.  3rd and 4th params are not used, but needed for compatibility
      System.Drawing.Image ThumbnailImage = Photo.GetThumbnailImage(width, height, tnCallBack, IntPtr.Zero);
      
      // Save the thumbnail
      ThumbnailImage.Save(ThumbPath);
      
      // Dispose of Thumbnail Image object
      ThumbnailImage.Dispose();
}

// Must be called when creating a thumbnail, but not used
bool tnCallbackMethod()
{
      return false;
}


Note that in the above code the photo itself will have no error since it is not being created on the fly, but the thumbnail will.
0
mrichmon
Asked:
mrichmon
  • 2
1 Solution
 
ThogekCommented:
Have you tried replacing
    ThumbnailImage.Save(ThumbPath);
with
    ThumbnailImage.Save(ThumbPath, System.Drawing.Imaging.ImageFormat.Jpeg);
0
 
mrichmonAuthor Commented:
No, I will try that.

Thanks for the suggestion - I will post the results...
0
 
mrichmonAuthor Commented:
Worked perfectly thanks!
0
 
daz_oldhamCommented:
I'm about to test this too as I have the same problem... fingers crossed :)  

daz@redstarcreative.co.uk
0

Featured Post

What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now