Most of the web applications have a lot of images used in it. These images are usually stored in a web server folder and they are accessed by giving the relative path to the file with respect to the root folder of the website. .Net being the platform for distributed application now, ASP.Net can be used to store images that are small to be stored in a database like SQL Server 2000 and later versions. For this purpose the SQL Server database provides a data type called "image" which is used to store images in the database.
To access these images stored in the database we will be using the ADO.Net classes. To find out how to insert and retrieve an image in to the SQL Server database, you can create a .aspx page which can have a HTMLInputFile control which is used to select the image file that is to be saved in the database. You can also create a textbox control in which you can add the image name or some comment or an image id for the image saved. Use a button control to upload the image to the database. Namespaces like System.Data.SqlClient, System.Drawing, System.Data, System.IO, and System.Drawing.Imaging are used in this task.
In the OnClick property of the button you can write the following code to upload an image to the database.
// create a byte[] for the image file that is uploaded
int imagelen = Upload.PostedFile.ContentLength;
byte[] picbyte = new byte[imagelen];
Upload.PostedFile.InputStream.Read (picbyte, 0, imagelen);
// Insert the image and image id into the database
SqlConnection conn = new SqlConnection (@"give the connection string
here...");
try
{
conn.Open ();
SqlCommand cmd = new SqlCommand ("insert into ImageTable "
+ "(ImageField, ImageID) values (@pic, @imageid)",
conn);cmd.Parameters.Add ("@pic", picbyte);
cmd.Parameters.Add ("@imageid", lblImageID.Text);
cmd.ExecuteNonQuery ();
}
finally
{
conn.Close ();
}
You can also write the above code in a function and call that function in the OnClick event of the upload button. The code given above performs the following steps in the process of inserting an image into the database.
1. Get the content length of the image that is to be uploaded
2. Create a byte[] to store the image
3. Read the input stream of the posted file
4. Create a connection object
5. Open the connection object
6. Create a command object
7. Add parameters to the command object
8. Execute the sql command using the ExecuteNonQuery method of the command object
9. Close the connection object
To retrieve the image from the SQL Database you can perform the following steps.
1. Create a MemoryStream object. The code can be something like, MemoryStream mstream = new MemoryStream ();
2. Create a Connection object
3. Open the connection to the database
4. Create a command object to execute the command to retrieve the image
5. Use the command object's ExecuteScalar method to retrieve the image
6. Cast the output of the ExecuteScalar method to that of byte[] byte[] image = (byte[]) command.ExecuteScalar ();
7. Write the stream mstream.Write (image, 0, image.Length);
8. Create a bitmap object to hold the stream Bitmap bitmap = new Bitmap (stream);
9. Set the content type to "image/gif" Response.ContentType = "image/gif";
10. Use the Save method of the bitmap object to output the image to the OutputStream. bitmap.Save (Response.OutputStream, ImageFormat.Gif);
11. Close the connection
12. Close the stream mstream.Close();
Using the above steps you can retrieve and display the image from the database to the web page.
You can use these algorithms and take advantage of the "image" data type available in the SQLServer 2000 database to store small images that correspond to a particular record in the table of the database. This method of storing avoids the tedious task of tracking the path of the web folder if the images are stored in a web folder.
Visit a guide to .net for a complete introduction to .NET framework. Learn about ASP.NET, VB.NET, C# and other related technologies.
eco-friendly cleaning service Buffalo Grove ..Get started creating web pages using text files and HTML... Read More
In my humble opinion nothing makes a long trip easier... Read More
Simone is exasperated. She has to work on her university... Read More
I recently got an e-mail asking about virtual memory. The... Read More
Do you remember the old saw about how computers would... Read More
CCNAs and CCNA candidates hear it all the time: ???Get... Read More
Music lovers have been carrying around radios and other bulky... Read More
Feeling overwhelmed in selecting a new TV? With all the... Read More
Digital Video Disc or as it is sometimes referred to... Read More
In the first part of this home lab tutorial, CCNA... Read More
The Internet can be a dangerous place.While you're enjoying the... Read More
Enhanced Definition Television ? also known as EDTV ? is... Read More
Each of the items in the checklist below is part... Read More
In the early days, Personal Digital Assistants (PDAs) were not... Read More
It seems like fast never quite rates fast enough.No matter... Read More
I've worked my way from the CCNA to the CCIE,... Read More
Most people download and save so much information on their... Read More
There are soooo many choices. With all the styles and... Read More
The year is 1981. IBM has just released the Personal... Read More
When you think of a help desk, what do you... Read More
Digital cameras ratings are great tools for deciding which camera... Read More
One of the most common questions computer users ask is,... Read More
Up until the recent past, those who wanted to take... Read More
Millions have enjoyed recorded music since 1877 when Thomas Edison... Read More
It's free, it comes with Windows and it's used by... Read More
express cleaning service Arlington Heights ..Using SQL Server 2000 and above versions you can retrieve... Read More
"Aaaaaahhhhhh! I've been invaded by a virus!" Getting a virus... Read More
Here are some tips on how to use screensavers:First of... Read More
IntroOne of the big advantages of PCs over earlier types... Read More
We've all seen them, you've been browsing a website and... Read More
On 21 August 2003 Symantec Security Response upgraded the W32.SOBIG.F... Read More
You don't have to fork out $250 for a super-diggy-whizbang... Read More
Addressing a D2X Digital SLRCoolpix 8800 search, this article provides... Read More
With their solid-state technology, compact size, and abundant memory, portable... Read More
When you think of a help desk, what do you... Read More
If you are a building a website or a forum,... Read More
If you don't have an mp3 player, and even if... Read More
The basic language of the internet is html. If you... Read More
When you turn on your computer, does it act like... Read More
This tip is on sharing files and folders on a... Read More
Heading off on vacation soon?Then perhaps you're tempted to take... Read More
For many people the computer industry is a seeming unsolvable... Read More
Have you ever thought about building your own computer system?... Read More
1. Empty the Temp directory regularly. To do this, make... Read More
I recently took a good look at what was keeping... Read More
When studying for your Cisco CCNA, CCNP, or CCIE exam,... Read More
Do you remember the old saw about how computers would... Read More
"Automated Testing" is automating the manual testing process currently in... Read More
Maybe you always wanted a feature that hasn't been available... Read More
I do a holiday letter every year and send them... Read More
Personal Technology |