Solved

Setting a cookie in ASP.net based on a drop down list

Posted on 2008-10-07
5
359 Views
Last Modified: 2010-04-21
I'm taking my first attempt at setting a cookie in ASP.net.  I have a drop down list that lists all users of the application.  Once the user has made their selection from the drop down list, they have the option of clicking a checkbox.  When they click the checkbox, I would like for the value of the dropdownlist to be saved as a cookie.  I would like to use that value to set the default value of the drop down list.  I'm not sure what kind of event to put my code in or even if the code is correct.  I've pasted it below.  Thank you for your help.
Dim currentofficer As DropDownList = DirectCast(FindControl("DropDownOfficer"), DropDownList)

        If currentofficer.SelectedValue <> "All Officers" Then

            Response.Cookies("PipelineCookie")("DefaultOfficer") = currentofficer.Text

        Else

        End If

Open in new window

0
Comment
Question by:ryanvb83
  • 3
  • 2
5 Comments
 
LVL 13

Expert Comment

by:crazyman
ID: 22659692

Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load

        If Not Page.IsPostBack Then

            Dim s As String = Response.Cookies("PipelineCookie")("DefaultOfficer")

            If Not String.IsNullOrEmpty(s) Then

                DropDownList1.SelectedValue = s

            End If
 

        End If

    End Sub
 

    Private Sub DropDownList1_SelectedIndexChanged(ByVal sender As Object, ByVal e As System.EventArgs) Handles DropDownList1.SelectedIndexChanged
 

        Response.Cookies("PipelineCookie")("DefaultOfficer") = DropDownList1.SelectedValue

    End Sub

Open in new window

0
 
LVL 13

Accepted Solution

by:
crazyman earned 500 total points
ID: 22659740
sorry my vb sucks, try this.
you could set autopostback = true on your dropdown
you may also want to control the cookie expiration a little better...
    Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load

        If Not Page.IsPostBack Then

            Dim cook As HttpCookie = Request.Cookies("PipelineCookie")

            If Not cook Is Nothing Then

                Dim s As String = cook("DefaultOfficer")

                If Not String.IsNullOrEmpty(s) Then

                    DropDownList1.SelectedValue = s

                End If

            End If

            
 

        End If

    End Sub
 

    Private Sub DropDownList1_SelectedIndexChanged(ByVal sender As Object, ByVal e As System.EventArgs) Handles DropDownList1.SelectedIndexChanged
 

        Response.Cookies("PipelineCookie")("DefaultOfficer") = DropDownList1.SelectedValue

    End Sub

Open in new window

0
 

Author Comment

by:ryanvb83
ID: 22659933
Awesome.  That worked great after I turned on AutoPostBack for the checkbox control.  How do I set the cookie to never expire?
0
 
LVL 13

Assisted Solution

by:crazyman
crazyman earned 500 total points
ID: 22659965
something like...

Response.Cookies("PipelineCookie")("DefaultOfficer").Expires = DateTime.Now.AddYears(50)
0
 

Author Closing Comment

by:ryanvb83
ID: 31503825
Perfect.  Thanks!
0

Featured Post

What Security Threats Are You Missing?

Enhance your security with threat intelligence from the web. Get trending threat insights on hackers, exploits, and suspicious IP addresses delivered to your inbox with our free Cyber Daily.

Join & Write a Comment

A quick way to get a menu to work on our website, is using the Menu control and assign it to a web.sitemap using SiteMapDataSource. Example of web.sitemap file: (CODE) Sample code to add to the page menu: (CODE) Running the application, we wi…
Introduction This article shows how to use the open source plupload control to upload multiple images. The images are resized on the client side before uploading and the upload is done in chunks. Background I had to provide a way for user…
Excel styles will make formatting consistent and let you apply and change formatting faster. In this tutorial, you'll learn how to use Excel's built-in styles, how to modify styles, and how to create your own. You'll also learn how to use your custo…
Access reports are powerful and flexible. Learn how to create a query and then a grouped report using the wizard. Modify the report design after the wizard is done to make it look better. There will be another video to explain how to put the final p…

707 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

Need Help in Real-Time?

Connect with top rated Experts

19 Experts available now in Live!

Get 1:1 Help Now