时间:2021-05-26
前言
用户状态保存是一个很常见的需求,一般用来保存用户状态的方式是在数据库表中创建多个字段来存储相应的用户状态,比如要保存用户是否绑定了手机号和QQ,则需要2个字段(mobile,qq)来保存。
如果使用二进制来保存用户的状态的话则只需要1个字段(status)就能保存多个用户状态。
当然使用二进制来保存也有一些坏处,比如不能存储详细的信息,只能用来判断状态,而且在数据库中可读性也比较差。下面是一个比较简单的Demo。
代码
<?php/** * 使用二进制来保存用户状态 *///首先定义4个用户状态define('MOBILE', 1); //手机号绑定define('EMAIL', 2); //邮箱绑定define('WECHAT', 4); //微信绑定define('QQ', 8); //QQ绑定//模拟用户类class User { public $user_name = ""; public $status = 0; //用来保存用户状态 function __construct($user_name, $status) { $this->user_name = $user_name; $this->status = $status; }}//new一个测试用户$test_user = new User("test_user", 0);//先判断用户是否绑定了手机号if (($test_user->status & MOBILE) == MOBILE) echo "first:该用户已经绑定手机号,用户状态是:" . $test_user->status . "</br>";else echo "first:该用户没有绑定手机号,用户状态是:" . $test_user->status . "</br>";//接着该用户去绑定了手机号 微信 和 QQ$test_user->status = MOBILE | WECHAT | QQ;//再判断一下用户是否绑定了手机号if (($test_user->status & MOBILE) == MOBILE) echo "second:该用户已经绑定手机号,用户状态是:" . $test_user->status . "</br>";else echo "second:该用户没有绑定手机号,用户状态是:" . $test_user->status . "</br>";//再判断一下用户有没有绑定邮箱if (($test_user->status & EMAIL) == EMAIL) echo "third:该用户已经绑定邮箱,用户状态是:" . $test_user->status . "</br>";else echo "third:该用户没有绑定邮箱,用户状态是:" . $test_user->status . "</br>";//然后这个用户解除了手机号绑定$test_user->status = ($test_user->status & (~MOBILE));//再次判断用户是否绑定了手机号if (($test_user->status & MOBILE) == MOBILE) echo "fourth:该用户已经绑定手机号,用户状态是:" . $test_user->status . "</br>";else echo "fourth:该用户没有绑定手机号,用户状态是:" . $test_user->status . "</br>";以上这篇PHP 使用二进制保存用户状态的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了PHP实现十进制、二进制、八进制和十六进制转换相关函数用法。分享给大家供大家参考,具体如下:1.二进制:1.1.二进制转十进制:函数:bindec
本文实例讲述了PHP实现接收二进制流转换成图片的方法。分享给大家供大家参考,具体如下:这里实现php接收二进制流转换成图片,所使用的图片类imageUpload
本文实例讲述了php图片的二进制转换实现方法。分享给大家供大家参考。具体实现方法如下:这里我们是在上传文件时把上传的文件转换成二进制然后保存到数据的字段中去,下
四位二进制可表示16种种状态,用一个值代表一个状态,那么4个二进制位可以代表,2乘4=16种状态。 二进制(英文:Binarysystem)是计算技术中广泛采
1、将文件以二进制流的格式写入数据库首先获得文件路径,然后将文件以二进制读出保存在一个二进制数组中,与数据库建立连接,在SQL语句中将二进制数组赋值给相应的参数