Home >Backend Development >PHP Tutorial >Tracking cookies: where are they hidden?

Tracking cookies: where are they hidden?

PHPz
PHPzOriginal
2024-01-19 08:37:051338browse

Tracking cookies: where are they hidden?

Tracking Cookies: Where Are They Hidden?

With the continuous development of the Internet, the use of cookies to provide personalized services or conduct advertising tracking has become the norm. However, this also creates opportunities for hackers or other potential threats. So, how can we track the footprints of cookies and ensure the security of user information?

First of all, we need to understand the concept of cookies. Cookies are small files stored on a website's server that contain some user information. When a user visits the website, the server stores this information on the user's computer and identifies the user on subsequent visits. Generally speaking, cookies are divided into session cookies and persistent cookies. Session cookies only exist when the user visits the website and will be automatically cleared when the user closes the browser; while persistent cookies will be stored on the user's computer for a long time and will remain even if the browser is closed.

Next, we will show how to track and manage cookies through code examples.

1. Setting and getting cookies

For the convenience of demonstration, we will use JavaScript to set and get cookies.

First, let's set a persistent cookie.

function setCookie(cname, cvalue, exdays) {
  var d = new Date();
  d.setTime(d.getTime() + (exdays*24*60*60*1000));
  var expires = "expires="+ d.toUTCString();
  document.cookie = cname + "=" + cvalue + ";" + expires + ";path=/";
}

setCookie("username", "John Doe", 365);

The above code will set a cookie named "username" with a value of "John Doe" and a validity period of 365 days.

Next, let’s get the cookie.

function getCookie(cname) {
  var name = cname + "=";
  var decodedCookie = decodeURIComponent(document.cookie);
  var ca = decodedCookie.split(';');
  for(var i = 0; i <ca.length; i++) {
    var c = ca[i];
    while (c.charAt(0) == ' ') {
      c = c.substring(1);
    }
    if (c.indexOf(name) == 0) {
      return c.substring(name.length, c.length);
    }
  }
  return "";
}

var username = getCookie("username");
console.log(username); // 输出 John Doe

The above code will get the cookie named "username" and output its value to the console.

2. Clear cookies

Clearing cookies is very simple. You only need to set the validity period of the cookie to a time in the past.

function clearCookie(cname) {
  document.cookie = cname + "=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;";
}

clearCookie("username");

The above code will clear the cookie named "username".

3. Tracking cookies

In actual scenarios, we need to track cookies to ensure user information security. For example, when a user logs in, we need to store the user's identity information through cookies and verify it in subsequent operations.

The following is a simple example.

function login(username, password) {
  // 验证用户名和密码
  if (username === "admin" && password === "123456") {
    setCookie("loginToken", "token", 7);
    console.log("登录成功!");
  } else {
    console.log("用户名或密码错误!");
  }
}

function isLogin() {
  var token = getCookie("loginToken");
  if (token === "") {
    console.log("未登录!");
  } else {
    console.log("已登录!");
  }
}

login("admin", "123456"); // 登录成功!
isLogin(); // 输出已登录!

In the above code, when the user enters the correct username and password, we will set a cookie named "loginToken" and set its validity period to 7 days. In subsequent operations, we can determine whether the user is logged in by obtaining this cookie. When the cookie does not exist, the output is not logged; when the cookie exists, the output is logged.

To sum up, we can ensure the security of user information by setting, obtaining, clearing and tracking cookies. Of course, this is just a simple example. In actual applications, other technologies need to be combined to maintain user information security.

The above is the detailed content of Tracking cookies: where are they hidden?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn