Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17

x
?
Solved

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

Posted on 2008-06-13
5
Medium Priority
?
7,283 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
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 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 750 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

How to Use the Help Bell

Need to boost the visibility of your question for solutions? Use the Experts Exchange Help Bell to confirm priority levels and contact subject-matter experts for question attention.  Check out this how-to article for more information.

Question has a verified solution.

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

Today I had a very interesting conundrum that had to get solved quickly. Needless to say, it wasn't resolved quickly because when we needed it we were very rushed, but as soon as the conference call was over and I took a step back I saw the correct …
Real-time is more about the business, not the technology. In day-to-day life, to make real-time decisions like buying or investing, business needs the latest information(e.g. Gold Rate/Stock Rate). Unlike traditional days, you need not wait for a fe…
In this brief tutorial Pawel from AdRem Software explains how you can quickly find out which services are running on your network, or what are the IP addresses of servers responsible for each service. Software used is freeware NetCrunch Tools (https…
Do you want to know how to make a graph with Microsoft Access? First, create a query with the data for the chart. Then make a blank form and add a chart control. This video also shows how to change what data is displayed on the graph as well as form…

705 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