Serving Information Simply

Tuesday, 19 February 2013

Showing Uploaded image in grid view in C#.net


In my last article I had explained about how to upload image and audio file in asp.net using C# image and audio file uploading.

In this article I will let you know about how to show uploaded images in grid view control and also I will explain about how to use file upload control in this grid view row editing. For example if a Website user uploaded image save that image in the server path and display in grid view with use image control, after that editing that image using file upload control in grid view edit item template.

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title> Showing Uploaded image in grid view </title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <table width="1000" align="center">
            <tr>
                <td colspan="2">
                    <asp:Label ID="lblText" runat="server" Text=""></asp:Label>
                </td>
            </tr>
            <tr>
                <td>
                    Select File to be upload
                </td>
                <td>
                    <asp:FileUpload ID="fuImage" runat="server" />
                </td>
            </tr>
            <tr>
                <td>
                    Description of the file
                </td>
                <td>
                    <asp:TextBox ID="txtDesc" runat="server"></asp:TextBox>
                </td>
            </tr>
            <tr>
                <td colspan="2" align="center" class="style1">
                    <asp:Button ID="btnUpload" runat="server" Text="Upload" OnClick=" btnUpload _Click" />
                </td>
            </tr>
            <tr>
                <td colspan="2" height="250" align="center">
                    <asp:GridView ID="GridView1" runat="server" DataKeyNames="ID" AutoGenerateColumns="false"  OnRowCancelingEdit="GridView1_RowCancelingEdit" OnRowDeleting="GridView1_RowDeleting" OnRowEditing="GridView1_RowEditing" OnRowUpdating="GridView1_RowUpdating">
                        <Columns>
                            <asp:TemplateField HeaderText="File Name">
                                <ItemTemplate>
                                    <asp:Image ID="Image1" runat="server" ImageUrl='<%#Eval("fpath")%>' />
                                </ItemTemplate>
                                <EditItemTemplate>
                                    <asp:FileUpload ID="FileUpload2" runat="server" />
                                </EditItemTemplate>
                            </asp:TemplateField>
                            <asp:TemplateField HeaderText="Description">
                                <ItemTemplate>
                                    <%#Eval("desc1")%>
                                </ItemTemplate>
                                <EditItemTemplate>
                                    <asp:TextBox ID="txtdesc" runat="server" Text='<%#Eval("desc1")%>'></asp:TextBox>
                                </EditItemTemplate>
                            </asp:TemplateField>
                            <asp:CommandField HeaderText="Modify" ShowEditButton="true" EditText="Edit">
                                <ControlStyle Width="50" />
                            </asp:CommandField>
                            <asp:TemplateField HeaderText="Delete">
                                <ItemTemplate>
                                    <asp:LinkButton ID="lnkDelete" CommandName="Delete" runat="server" OnClientClick="return confirm('Are you sure you want to delete this record?');">Delete</asp:LinkButton>
                                </ItemTemplate>
                            </asp:TemplateField>
                        </Columns>
                    </asp:GridView>
                </td>
            </tr>
        </table>
    </div>
    </form>
</body>
</html>

Server side Coding

Note: - Here you will use your own connection string name that you have mentioned into web config file.if you do not know how to declare connection string in web.config then go through  my last article image and audio file uploading.

using System.Data.SqlClient;
using System.Configuration;
using System.Data;

public partial class _Default : System.Web.UI.Page
{
    SqlConnection sqlcon = new SqlConnection(ConfigurationManager.ConnectionStrings["Abhinav"].ConnectionString);
    SqlCommand sqlcmd = new SqlCommand();
    SqlDataAdapter da = new SqlDataAdapter();
    DataTable dt = new DataTable();
    String fname, fpath, desc;
    String spath;
    protected void Page_Load(object sender, EventArgs e)
    {
        lblText.Text = "";
        if (!Page.IsPostBack)
        {
            LoadGrid();
        }
    }
    protected void btnUpload_Click(object sender, EventArgs e)
    {
        if (fuImage.HasFile)
        {
            //Check File is available in Fileupload control and then upload to server path
            fname = FuImage.FileName;
            spath = @"~\Uploaded\" + FuImage.FileName;
            fpath = Server.MapPath("Uploaded");
            fpath = fpath + @"\" + FuImage.FileName;
            desc = TxtDesc.Text;
            if (System.IO.File.Exists(fpath))
            {
                LblText.Text = "File Name already exists!";
                return;
            }
            else
            {
                FuImage.SaveAs(fpath);
            }
            //Store details in the SQL Server table
            StoreDetails();
            TxtDesc.Text = "";
            LoadGrid();
        }
        else
        {
            LblText.Text = "Please select file!";
        }
    }
    void StoreDetails()
    {
        String Insertquery;
        Insertquery = "insert into fileDet(fname,fpath,desc1) values('" + fname + "','" + spath + "','" + desc + "')";
        sqlcon.Open();
        sqlcmd = new SqlCommand(Insertquery, sqlcon);
        sqlcmd.CommandType = CommandType.Text;
        sqlcmd.ExecuteNonQuery();
        sqlcon.Close();
        LoadGrid();
    }
    void LoadGrid()
    {
        sqlcon.Open();
        sqlcmd = new SqlCommand("select * from fileDet", sqlcon);
        da = new SqlDataAdapter(sqlcmd);
        dt.Clear();
        da.Fill(dt);
        if (dt.Rows.Count > 0)
        {
            GridView1.DataSource = dt;
            GridView1.DataBind();
        }
        else
        {
            GridView1.DataBind();
        }
        sqlcon.Close();
    }
    protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)
    {
        GridView1.EditIndex = e.NewEditIndex;
        LoadGrid();
    }
  protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
    {
        GridView1.EditIndex = -1;
        LoadGrid();
    }

    protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e)
    {
        String ID;
        ID = GridView1.DataKeys[e.RowIndex].Value.ToString();
        sqlcmd = new SqlCommand("select * from fileDet where ID='" + ID + "'", sqlcon);
        sqlcon.Open();
        da = new SqlDataAdapter(sqlcmd);
        da.Fill(dt);

        if (dt.Rows.Count > 0)
        {
            if (System.IO.File.Exists(Server.MapPath(dt.Rows[0][2].ToString())))
            {
                System.IO.File.Delete(Server.MapPath(dt.Rows[0][2].ToString()));
            }
        }
        sqlcmd = new SqlCommand("delete from fileDet where ID='" + ID + "'", sqlcon);
        sqlcmd.ExecuteNonQuery();
        sqlcon.Close();
        LoadGrid();
    }
    protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
    {
        GridViewRow row = GridView1.Rows[e.RowIndex];
        string ID;

        ID = GridView1.DataKeys[e.RowIndex].Value.ToString();

        FileUpload flname = (FileUpload)row.FindControl("FileUpload2");

        if (flname.HasFile)
        {

            fname = flname.FileName;
            spath = @"~\Uploaded\" + flname.FileName;
            fpath = Server.MapPath("Uploaded");
            fpath = fpath + @"\" + flname.FileName;
            if (System.IO.File.Exists(fpath))
            {
                LblText.Text = "File Name already exists!";
                return;
            }
            else
            {
                flname.SaveAs(fpath);
            }
        }
        else
        {
            LblText.Text = "Please select file!";
        }

        TextBox desc1 = (TextBox)row.FindControl("txtdesc");
        string query;
        query = "update fileDet set fname='" + fname + "',fpath='" + spath + "',desc1='" + desc1.Text + "' where ID='" + ID + "'";
        sqlcon.Open();
        sqlcmd = new SqlCommand(query, sqlcon);
        sqlcmd.CommandType = CommandType.Text;
        sqlcmd.ExecuteNonQuery();
        sqlcon.Close();
        GridView1.EditIndex = -1;
        LoadGrid();
    }
}

Then Implement the code and See the output...Thanks ...Keep Visiting ...:)
If you like this article then Join this Site.

Sunday, 10 February 2013

Image and Audio File uploading in asp.net using c#

In My last post I was described about array programming in C# and .NET arrays-in-c#.net-programming
This tutorial describes image uploading in C# and .NET. Here you will get a step by step guide to complete your goal of learning about uploading the image in dotnet technology...

(A)How to upload Image:

In my case, I use  a FileUpload Control(Id:->FileUpload1), an ImageButton(ImageButton1) or you can use the Image,  a Button Control(Id:->Updatebttn) to upload my Image, Button Control(Id:->Addbttn) to add my Image in database, an image(which I want to upload), add a new folder (Image) in my WebForm.

Steps:

step1. Create a table in the database (abc) :->

Create table Image1
(
Id int identity (1, 1),
Image1 varchar (100)
);

step2. Coding for connectionstring in web.config

<connectionStrings>
    <add name="conn" connectionString="Data Source=AbhinavPC\SQLEXPRESS;Initial Catalog=abc;Integrated Security=True;"/>
</connectionStrings>

step 3. in My WebForm (Page1.aspx.cs):

ProviderName:

using System.Data;
using System.Data.SqlClient;

Connectionstring:

SqlConnection conn1 = newSqlConnection(ConfigurationManager.ConnectionStrings["conn"].ConnectionString);

step 4. Uploadbttn Coding:

if (FileUpload1.HasFile)
{
    string fileName = FileUpload1.FileName.ToString();
    string uploadFolderPath = "~/Image/";
    string filePath = HttpContext.Current.Server.MapPath(uploadFolderPath);
    FileUpload1.SaveAs(filePath + "\\" + fileName);
    ImageButton1.ImageUrl ="~/Image/" + "/" + FileUpload1.FileName.ToString();
}

step 5. Addbttn Coding:

conn1.Open();
SqlCommand cmd3 = new SqlCommand("insert into Image1(image1) values('" + ImageButton1.ImageUrl + "')", conn1);
cmd3.ExecuteNonQuery();
conn1.Close();

(b) How to upload  Audio File:

Create a table in the database(abc):

create table Audio1
(
id int identity(1,1),
audio1 varchar(100)
);

Use FileUpload Control and a Button(Id:->Uploadbttn)

In this case add a folder(Audio) in WebForm

Uploadbttn Coding:

if(FileUpload1.HasFile)
{
    string fileName = FileUpload1.FileName.ToString();
    string uploadFolderPath = "~/Audio/";
    string filePath = HttpContext.Current.Server.MapPath(uploadFolderPath);
    FileUpload1.SaveAs(filePath + "\\" + fileName);
}

                         thanks guys ......keep visiting.

Saturday, 9 February 2013

Arrays in C#.net Programming.



This tutorial describes array programming in C# and .NET. It starts with the discussion of simple arrays and then proceeds into more complex topics such as jagged and multi-dimensional arrays.

Introduction

In C#, an array index starts at zero. That means the first item of an array starts at the 0th position. The position of the last item on an array will total number of items - 1. So if an array has 10 items, the last 10th item is at 9th position.

In C#, arrays can be declared as fixed length or dynamic.
fixed length array can store a predefined number of items.
dynamic array does not have a predefined size. The size of a dynamic array increases as you add new items to the array. You can declare an array of fixed length or dynamic. You can even change a dynamic array to static after it is defined.
Let's take a look at simple declarations of arrays in C#. The below code defines the simplest dynamic array of integer types that does not have a fixed size.
int[] intArray;

The following code snippet declares an array that can store 5 items only starting from index 0 to 4.
int[] intArray;
intArray = new int[5];

Defining arrays of different types

In the previous code snippet, we saw how to define a simple array of integer type. Similarly, we can define arrays of any type such as double, character, and string.
In C#, arrays are objects. That means that declaring an array doesn't create an array. After declaring an array, you need to instantiate an array by using the "new" operator.
The following code snippet defines arrays of double, char, bool, and string data types.
double[] doubleArray = new double[5];
char[] charArray = new char[5];
bool[] boolArray = new bool[2];
string[] stringArray = new string[10];

Initializing Arrays

// Initialize a fixed array
int[] staticIntArray = new int[3] {1, 3, 5};

Alternative, we can also add array items one at a time as listed in the following code snippet.

// Initialize a fixed array one item at a time
int[] staticIntArray = new int[3];
staticIntArray[0] = 1;
staticIntArray[1] = 3;
staticIntArray[2] = 5;

The following code snippet declares a dynamic array with string values.

// Initialize a dynamic array items during declaration
string[] strArray = new string[] { "Abhinav Bajpai""Amiya bajpai""Raj Kumar""vikash Kumar""Sharad Kumar" };

Accessing Arrays

We can access an array item by passing the item index in the array.

// Initialize a fixed array one item at a time
int[] staticIntArray = new int[3];
staticIntArray[0] = 1;
staticIntArray[1] = 3;
staticIntArray[2] = 5;

// Read array items one by one
Console.WriteLine(staticIntArray[0]);
Console.WriteLine(staticIntArray[1]);
Console.WriteLine(staticIntArray[2]);

This method is useful when you know what item you want to access from an array. If you try to pass an item index greater than the items in array, you will get an error.

Accessing an array using a foreach Loop

The foreach control statement (loop) is used to iterate through the items of an array.

// Initialize a dynamic array items during declaration
string[] strArray = new string[] { "Abhinav Bajpai""Amiya bajpai""Raj Kumar""vikash Kumar""Sharad Kumar" };

// Read array items using foreach loop
foreach (string str in strArray)
{
    Console.WriteLine(str);
}

Note:-This approach is used when you do not know the exact index of an item in an array and needs to loop through all the items.

Types of array

*         Single-dimensional arrays
*         Multidimensional arrays or rectangular arrays
*         Jagged arrays
*         Mixed arrays.

Single Dimension Arrays

Single-dimensional arrays are the simplest form of arrays. These types of arrays are used to store number of items of a predefined type. All items in a single dimension array are stored contiguously starting from 0 to the size of the array -1.
Example-:
int[] intArray;
intArray = new int[3];

Array declarations in C# are pretty simple. You put array items in curly braces ({}). If an array is not initialized, its items are automatically initialized to the default initial value for the array type if the array is not initialized at the time it is declared.
int[] staticIntArray = new int[3] {1, 3, 5};

The following code declares and initializes an array of 5 string items.
string[] strArray = new string[5] { "Abhinav""vikash""Raj""Sharad""vimal" };

You can even directly assign these values without using the new operator.

string[] strArray = { "Abhinav""vikash""Raj""Sharad""vimal" };

You can initialize a dynamic length array as follows:

string[] strArray = new string[] { Abhinav""vikash""Raj""Sharad""vimal" };

Multi-Dimensional Arrays

A multi-dimensional array, also known as a rectangular array is an array with more than one dimension. The form of a multi-dimensional array is a matrix.

Declaring a multi-dimensional array

A multi dimension array is declared as following:
string[,] mutliDimStringArray;
A multi-dimensional array can be fixed-sized or dynamic sized.

Initializing multi-dimensional arrays

int[,] numbers = new int[3, 2] { { 1, 2 }, { 3, 4 }, { 5, 6 } };
string[,] names = new string[2, 2] { { " Abhinav "" Sharad " }, { " vikash "" Raj " } };

Now let's see examples of multi-dimensional dynamic arrays where you are not sure of the number of items of the array.

int[,] numbers = new int[,] { { 1, 2 }, { 3, 4 }, { 5, 6 } };
string[,] names = new string[,] { { " Abhinav "" Sharad " }, { " vikash "" Raj " } };

You can also omit the new operator as we did in single dimension arrays. You can assign these values directly without using the new operator. For example:
int[,] numbers = { { 1, 2 }, { 3, 4 }, { 5, 6 } };
string[,] names = { { " Abhinav "" Sharad " }, { " vikash "" Raj " } };

We can also initialize the array items one item at a time. The following code snippet is an example of initializing array items one at a time.

int[,] numbers = new int[3, 2];
numbers[0, 0] = 1;
numbers[1, 0] = 2;
numbers[2, 0] = 3;
numbers[0, 1] = 4;
numbers[1, 1] = 5;
numbers[2, 1] = 6;

Accessing multi-dimensional arrays

A multi-dimensional array items are represented in a matrix format and to access its items, we need to specify the matrix dimension. For example, item (1,2) represents an array item in the matrix at second row and third column.
The following code snippet shows how to access numbers array defined in the above code.
Console.WriteLine(numbers[0,0]);
Console.WriteLine(numbers[0, 1]);
Console.WriteLine(numbers[1, 0]);
Console.WriteLine(numbers[1, 1]);
Console.WriteLine(numbers[2, 0]);
Console.WriteLine(numbers[2, 2]);

Jagged Arrays

Jagged arrays are arrays of arrays. The elements of a jagged array are other arrays.

Declaring Jagged Arrays

Declaration of a jagged array involves two brackets. For example, the following code snippet declares a jagged array that has three items of an array.

int[][] intJaggedArray = new int[3][];

The following code snippet declares a jagged array that has two items of an array.

string[][] stringJaggedArray = new string[2][];

Initializing Jagged Arrays

// Initializing jagged arrays
intJaggedArray[0] = new int[2];
intJaggedArray[1] = new int[4];
intJaggedArray[2] = new int[6];

We can also initialize a jagged array's items by providing the values of the array's items. The following code snippet initializes item an array's items directly during the declaration.

// Initializing jagged arrays
intJaggedArray[0] = new int[2]{2, 12};
intJaggedArray[1] = new int[4]{4, 14, 24, 34};
intJaggedArray[2] = new int[6] {6, 16, 26, 36, 46, 56 };


Accessing Jagged Arrays

We can access a jagged array's items individually in the following way:

Console.Write(intJaggedArray3[0][0]);
Console.WriteLine(intJaggedArray3[2][5]);

We can also loop through all of the items of a jagged array. The Length property of an array helps a lot; it gives us the number of items in an array.

// Loop through all itesm of a jagged array
for (int i = 0; i < intJaggedArray3.Length; i++)
{
    System.Console.Write("Element({0}): ", i);
    for (int j = 0; j < intJaggedArray3[i].Length; j++)
    {
        System.Console.Write("{0}{1}", intJaggedArray3[i][j], j == (intJaggedArray3[i].Length - 1) ? "" : " ");
    }
    System.Console.WriteLine();
}

Mixed Arrays

Mixed arrays are a combination of multi-dimension arrays and jagged arrays. The mixed arrays type is removed from .NET 4.0. I have not really seen any use of mixed arrays. You can do anything you want with the help of multi-dimensional and jagged arrays.

A Simple Example
  
Console.WriteLine("Single Dimension Array Sample");
// Single dim array
string[] strArray = new string[] { "Abhinav Bajpai""raju Verma""Viaksh dwevedi""Sharad Mishra""Vimal tripathi" };
// Read array items using foreach loop
foreach (string str in strArray)
{
    Console.WriteLine(str);
}
Console.WriteLine("-----------------------------");

Console.WriteLine("Multi-Dimension Array Sample");
string[,] string2DArray = new string[2, 2] { { "abhi""raj" }, { "Amiya""shreya" } };
foreach (string str in string2DArray)
{
    Console.WriteLine(str);
}
Console.WriteLine("-----------------------------");

Console.WriteLine("Jagged Array Sample");
int[][] intJaggedArray3 =
{
    new int[] {2,12},
    new int[] {14, 14, 24, 34},
    new int[] {6, 16, 26, 36, 46, 56}
};
// Loop through all itesm of a jagged array
for (int i = 0; i < intJaggedArray3.Length; i++)
{
    Console.Write("Element({0}): ", i);
    for (int j = 0; j < intJaggedArray3[i].Length; j++)
    {
        Console.Write("{0}{1}", intJaggedArray3[i][j], j == (intJaggedArray3[i].Length - 1) ?"" : " ");
    }
    Console.WriteLine();
}
Console.WriteLine("-----------------------------");


Thanks Guys ....keep visiting..:)