setting a cookie based on the http referer

Posted on 2009-07-13
Last Modified: 2012-05-07

I need to set a cookie for every user based on the referer. I figured out how to retrieve a cookie in a JSP here...

Now, I need to figure out how to set a cookie based on the value of that referer (URL). I already have a setCookie() javascript function created btw. I'd really appreciate it if someone could help me out.

Question by:biglarrrr
  • 3
  • 3
LVL 27

Expert Comment

ID: 24848695
To set a cookie from a JSP page, you create a Cookie object and add it to the HttpServletResponse.  Something like this:

Cookie aCookie = new Cookie( "mycookiename", "mycookievalue");
aCookie .setPath("/");
response.addCookie( aCookie );

The response object is the special object in a JSP page that refers to the HttpServletResponse.

See the Cookie api here for more values to set if you want a permanent cookie rather than a session cookie:


Author Comment

ID: 24850850
Thanks for replying mrcoffee365...

I know how to create a cookie, I just can't figure out how to create a cookie which holds the value of the Referer. I read that I'll need to use request.getHeader("Referer") to get the referer, but how do I take the value of that and drop it in a cookie? I only want this to be a session cookie.

I'm sorry, I'm not exactly the greatest when it comes to JavaScript. :)

LVL 27

Expert Comment

ID: 24851115
Okay, are you looking for javascript code or JSP code?  They are not the same thing, and you seem to be using the terms interchangeably.
Free Tool: ZipGrep

ZipGrep is a utility that can list and search zip (.war, .ear, .jar, etc) archives for text patterns, without the need to extract the archive's contents.

One of a set of tools we're offering as a way to say thank you for being a part of the community.

LVL 27

Accepted Solution

mrcoffee365 earned 500 total points
ID: 24851195
In case you mean JSP, how to set the value of the cookie is in the line I posted:

Cookie aCookie = new Cookie( "mycookiename", "mycookievalue");

If you want it to have the url in the referer, then put that in for the string of the value.

Cookie aCookie = new Cookie( "mycookiename", refererVal);


Author Comment

ID: 24851710
THANK YOU!!! That's the part I couldn't figure out. And it was all because I didn't put quotes around "mycookiename". :( Thanks so much for your help on this! I've paste my code below...
String ref_value = null;
boolean refFound = false;
String referrer = request.getHeader("Referer");
System.out.println("referer url = " + referrer);
Cookie[] cookies = request.getCookies();
if (cookies != null) {
  for (int i=0; i< cookies.length;i++) {
    Cookie cookie = cookies[i];
    if (cookie.getName().equals("referrer")) {
      ref_value = cookie.getValue();
      refFound = true;
      session.setAttribute("referrer", ref_value);
  if (!refFound) {
    if (referrer!= null && referrer.length() > 0) {
      Cookie cookie = new Cookie("referrer",referrer);
      session.setAttribute("referrer", referrer);

Open in new window


Author Closing Comment

ID: 31603070
Thanks for your help. I'm sorry I didn't explain my question in better detail but you managed to read my mind. :)

Featured Post

Networking for the Cloud Era

Join Microsoft and Riverbed for a discussion and demonstration of enhancements to SteelConnect:
-One-click orchestration and cloud connectivity in Azure environments
-Tight integration of SD-WAN and WAN optimization capabilities
-Scalability and resiliency equal to a data center

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
AlarmClock Challenge 35 155
fullcallendar did not show 2 65
Java Exception example issues 11 84
tomcat startup error 5 100
The business world is becoming increasingly integrated with tech. It’s not just for a select few anymore — but what about if you have a small business? It may be easier than you think to integrate technology into your small business, and it’s likely…
Giving access to ESXi shell console is always an issue for IT departments to other Teams, or Projects. We need to find a way so that teams can use ESXTOP for their POCs, or tests without giving them the access to ESXi host shell console with a root …
Microsoft Active Directory, the widely used IT infrastructure, is known for its high risk of credential theft. The best way to test your Active Directory’s vulnerabilities to pass-the-ticket, pass-the-hash, privilege escalation, and malware attacks …

792 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