


Now my website uses sessions, but once the browser is closed, the login status is gone, which is very inconvenient
How to use the [Stay logged in] function, and how to do cookie security in detail. It is best to explain it online. There is no specific plan, I hope someone with development experience can provide guidance
Reply content:
Now my website uses sessions, but once the browser is closed, the login status is gone, which is very inconvenient
How to use the [Stay logged in] function, and how to do cookie security in detail. It is best to explain it online. There is no specific plan, I hope someone with development experience can provide guidance
It should be noted that PHP sessions are also implemented using cookies. The cookie name saved in the browser defaults to PHPSESSID.
The cookie of this session can also set the expiration time. For example, the expiration time is set to 3600 seconds: session_set_cookie_params( 3600);
This cookie will still be valid after closing the browser and reopening it within an hour.
PHP session is that each PHPSESSID corresponds to a file that saves session data by default.
That is to say, the session data of different PHPSESSIDs are not shared.
For example, if you use PHP session to implement a shopping cart or video viewing record function,
you Save the shopping cart data in the session file, then you will not be able to see your shopping cart data after logging in from other devices or browsers.
At this time, you should save the shopping cart data in the database.
Let’s talk about how to implement a customized cookie session mechanism based on the database:
The user ID (plain text) and user's salt value (hash) are stored in the cookie.
If high security is required, you can also use MCRYPT_BLOWFISH to encrypt the entire cookie content.
This cookie must be able to authenticate the user, And it must not be forged.
The user's salt value is randomly generated and determined to protect the password when the user registers, and is stored in a field data corresponding to the user in the user table.
<code>//保护用户密码的盐 $salt = sha1( uniqid(getmypid().'_'.mt_rand().'_', true) ); //用户的密码($pwd_user是用户输入的密码明文) $pwd_db = sha1($salt.sha1($pwd_user)); //cookie里的盐 //其中$global_salt是配置里定义的全局盐,用来保护用户的盐,一旦修改,所有用户的cookie都将失效. $cookie_salt = sha1($global_salt.sha1($salt)); //最终生成的cookie内容 $cookie = base64_encode($user_id.'|'.$cookie_salt); //如果你需要高安全性,还可以使用MCRYPT_BLOWFISH对整个cookie的内容做一次加密. $cookie = mcrypt_blowfish($cookie, $key); //设置cookie,这里把过期时间设为3600秒(1小时) setcookie($cookie_name, $cookie, time()+3600);</code>
The user's salt, the application global salt, and the MCRYPT_BLOWFISH encrypted key $key are all randomly generated and determined.
Algorithms such as: sha1( uniqid(getmypid().'_'.mt_rand() .'_', true) )
generates a process ID + random number + a hash value based on the current time microseconds + entropy.
When verifying a user, first use the private key to decrypt $_COOKIE['cookie_name'],
Then base64_decode to get the user ID,
Then query the user's salt based on the user ID,
Then pass the salt through the same hash algorithm followed by the cookie Compare the salt $cookie_salt in
If they are consistent, the user’s cookie is determined to be valid.
<code>//解密cookie $cookie = mdecrypt_blowfish($_COOKIE['cookie_name'], $key); //分割后拿到里面的$user_id和$cookie_salt $cookie = explode('|', base64_decode($_COOKIE['cookie_name']));</code>
Set the cookie validity period, for example, add one week to the current time, so that it will expire in one month even if you close the browser
The cookie content can be symmetrically encrypted for the userId. The backend first gets the ciphertext, then decrypts it, and finally logs in
Only operating cookies cannot solve the problem of session expiration. It is recommended to use a cache
(it is indeed an addictive drug) and put the session in. You can set the expiration time as you like. When checking whether it is online, go directly to the cache to check;
It seems that php.ini
can set the session storage medium.

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

Dreamweaver CS6
Visual web development tools

WebStorm Mac version
Useful JavaScript development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software
