Solved

Gridview Hyperlink value. Need to pass to another page but not using QueryString.

Posted on 2008-06-13
5
7,226 Views
Last Modified: 2013-11-26
On btnSearch_Click event I bind the gridview. First column "Name" is the hyperlink and the second column "UserID" value I need to pass to another page but NOT using Request.QueryString.
Here is the visual of bind datagrid:
Full Name........................User ID....................Header title.................
Joe, Doe ........................123456...................other cell values ..........
Jane, Doe........................78910.....................other cell values..........

The grid might contain a single row or hundreds of rows.
Based on the code below I'm getting hyperlink href="nextpage.aspx?id=y&userid=12345" and so on. However, I need the following:
a. Hide the userid value so the user just sees "nextpage.aspx?id=y"
b. Pass userid value to the next page when user clicks on the link.

Should I use session variable,  hidden fields or what? But how? Example please.
<asp:gridview ID="gvGetUser" AutoGenerateColumns="false"..../>
 <columns>
<asp:hyperlinkfield DataTextField="Name" HeaderText="Full Name" ItemStyle-HorizontalAlign="left" ControlStyle-CssClass="lnk" 
 DataNavigateUrlFields="UserID" DataNavigateUrlFormatString="nextpage.aspx?id=y&userid={0}"  />
<asp:boundfield DataField="UserID" HeaderText="User ID" />
....
</columns>
</asp:gridview>

Open in new window

0
Comment
Question by:vbnetdev
  • 3
  • 2
5 Comments
 
LVL 14

Expert Comment

by:ajitha75
ID: 21783794
When you say you want to hide the user id, do you mean the user should never be able to find out the user id value in second page.  if that is the case, you should not use hidden variable. you can go for session values.
or you should encrypt the url and decrypt it in the next page.
0
 
LVL 1

Author Comment

by:vbnetdev
ID: 21784548
Yes, the user should NOT see the user id when mouse over the link (1st page) along with when the next page loads. And if using session variable, how would I set an individual user id into session or encrypt the value if datagrid might contrain more then 1 row. The user would click only one (user id) at the time and I need an example how to set the value into session since I don't know which link the user clicks. This userid value I need to pass to the next page and run another stored procedure as a passed parameter.

Hope it's clear.
0
 
LVL 1

Author Comment

by:vbnetdev
ID: 21787225
Maybe i should set a button with CommandName="Select" first. That way I will know which row the user selected. Then when the row is selected, grab "UserID" value, set into session variable and redirect to the next page.

Anybody else? Surprised just 1 person responded.
0
 
LVL 14

Accepted Solution

by:
ajitha75 earned 250 total points
ID: 21787318
This is what you can do.

THe following will be html code

<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" AllowSorting="true">
<Columns>  
<asp:TemplateField HeaderText="Navigate">
<ItemTemplate>
<asp:LinkButton id="lnkButton" OnCommand="lnkButton_Click" CommandArgument='<%# DataBinder.Eval(Container.DataItem,"userid") %>' runat="server" Text="Select"></asp:LinkButton>
</ItemTemplate>
</asp:TemplateField>
            </Columns>
        </asp:GridView>


and on the server side

    protected void lnkButton_Click(object sender, CommandEventArgs e)
    {
        Session["userid"] = e.CommandArgument;
        Server.Transfer("default2.aspx");

    }

Of course you will first have to do DataBind in the initial load to bind the datatable to gridview
0
 
LVL 1

Author Comment

by:vbnetdev
ID: 21796997
Thanks but it complained about (Containter.DataItem, "userid") under CommandArgument.

I decided to give a different approach.
User clicks search button to get the grid fill with hyperlink as one of the columns.

a. On button_Click event I create a hashtable, bind the grid and add hastable into Session variable.
b. Under _RowDataBound grid event I create a NewGuid, add NewGuid  as a key with "userid" value.
c. Then  programmatically create a hyperlink with .NavigateUrl set to "nextpage.aspx?guid=" + guid.toString
d. I keep UI hyperlink column just with DataTextField, HeaderText and  ControlStyle-CssClass
e. Nextpage.aspx page will read Session varialble and grabs assigned UserID value based on matched guid received through QueryString.
0

Featured Post

Free Tool: Postgres Monitoring System

A PHP and Perl based system to collect and display usage statistics from PostgreSQL databases.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

This document covers how to connect to SQL Server and browse its contents.  It is meant for those new to Visual Studio and/or working with Microsoft SQL Server.  It is not a guide to building SQL Server database connections in your code.  This is mo…
ASP.Net to Oracle Connectivity Recently I had to develop an ASP.NET application connecting to an Oracle database.As I am doing it first time ,I had to solve several problems. This article will help to such developers  to develop an ASP.NET client…
I've attached the XLSM Excel spreadsheet I used in the video and also text files containing the macros used below. https://filedb.experts-exchange.com/incoming/2017/03_w12/1151775/Permutations.txt https://filedb.experts-exchange.com/incoming/201…
Exchange organizations may use the Journaling Agent of the Transport Service to archive messages going through Exchange. However, if the Transport Service is integrated with some email content management application (such as an antispam), the admini…

680 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question