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.
custom home cleaning Wilmette ..Step 1:Open WinRAR and browse to the folder with your... Read More
Upgrading your processor will always speed up your computer, but... Read More
IF WE say that it was mainly because of the... Read More
Tip #1. Do a Google search. Don't be to general... Read More
With the bewildering number of digital cameras on the market,... Read More
Good Morning Mr. Sampson. Please type in you Personal Identification... Read More
First and foremost before I begin my ranting it is... Read More
BIOS - Basic Input Output SystemThe central processing unit of... Read More
Just The Facts, Ma'mPalm pilots are all the rage now.... Read More
Time is money. And when you constantly have to divide... Read More
JPEG, GIFF/JIFF, BMP, and TIFF are the most commonly used... Read More
Heading off on vacation soon?Then perhaps you're tempted to take... Read More
What led them to this choice, as all four studios... Read More
Cameras: still known for taking pictures but assumed as digital... Read More
In the years of the dot com boom and bust,... Read More
The year is 1981. IBM has just released the Personal... Read More
Plasma and LCD TVs are the latest trend in home... Read More
Getting a new computer should be an exciting and gratifying... Read More
"Automated Testing" is automating the manual testing process currently in... Read More
Feeling overwhelmed in selecting a new TV? With all the... Read More
If you ask most people what frustrates them most about... Read More
Computer is an electronic machine work on the instructions of... Read More
Below you will find some useful information and comments about... Read More
In Windows Xp, you can install two operating systems on... Read More
Perhaps not yet, but the handwriting might be on the... Read More
same day cleaning service Morton Grove ..The first step is: Start > My DocumentsSo you have... Read More
Have you ever tried to remove Spyware off your PC... Read More
In this era of Internet, most people are frequent users... Read More
Millions have enjoyed recorded music since 1877 when Thomas Edison... Read More
Just The Facts, Ma'mPalm pilots are all the rage now.... Read More
Plasma and LCD TVs are the latest trend in home... Read More
Spyware is the software that collects information about your online... Read More
Below you will find some useful information and comments about... Read More
For many people the computer industry is a seeming unsolvable... Read More
JVC developed and used a high-performance reflective film to produce... Read More
Apache, MysQL and PHP for Windows could be a nice... Read More
Webmasters usually sit at their computers much longer in a... Read More
Tip #1 -- Rebates: A rebate is not always a... Read More
No matter how fast your processor and regardless of how... Read More
CCNA FAQQ. What exams do I have to take to... Read More
Heading off on vacation soon?Then perhaps you're tempted to take... Read More
After another security hole recently surfaced in Microsoft's Windows operating... Read More
Your first step in removing dangerous infections from your computer... Read More
Cookies, not the kind that Mom makes, but the computer... Read More
Google, in their march to stay ahead of the pack... Read More
If you've been kicking around the idea of building your... Read More
With their solid-state technology, compact size, and abundant memory, portable... Read More
With renting methods such as online DVD rental and pay-per-view,... Read More
Do you know how many fonts are currently installed on... Read More
If you have a computer for home use or for... Read More
Personal Technology |