1.服务容器
- bind() : 是向容器中绑定服务对象.
- make() : 是从容器中取出对象.
//创建一个消息工厂
$text = new Container();
//绑定服务对象
$text->bind('服务对象名字',function (){
return new 服务对象类();
});
$text->bind('STU',function (){
return new Student();
});
//取出对象
$SMS = $message->make('STU');
2.密码加密和加密盐
拼接密码和加密盐 : generateHashPassword( 密码, 加密盐);
(1).生成加密盐:
protected function generateSalt()
{
// 使用随机方式生成一个四位字符
$chars = array_merge(range('A', 'Z'), range('a', 'z'), range('0', '9'));
$str = '';
for ($i = 0; $i < 4; $i++) {
$str .= $chars[mt_rand(0, count($chars) - 1)];
}
return $str;
}
(2).合成密码:
function generateHashPassword($password, $salt)
{
return md5(sha1($password) . $salt);
}
$insert['pass_salt'] = $this->generateSalt();
$insert['user_pass'] = generateHashPassword($insert['user_pass'], $insert['pass_salt']);
3.缓存
(1)缓存路径:
storage/framework/cache/
(2)缓存方法:
Cache::put('key1','val1',10);//键 值 有效时间(分钟)
//Cache::add('key2','val2',20);//若key2不存在,则添加成功 否则,添加失败
//Cache::forever('key3','val3');//永久保存对象到缓存
//Cache::has('key1');//判断是否存在
Cache::forget('key1');//删除缓存
//$data = Cache::get('key1');//取值
$data = Cache::pull('key1');//取值后删除
4.数组
(1)方法:
-
array_column ():用于将数组中相同键的一列值合并到一起组成一个新的数组
-
array_multisort (参数1,参数2,参数3) 函数对多个数组或多维数组进行排序。 参数中的数组被当成一个表的列并以行来进行排序 - 这类似 SQL 的 ORDER BY 子句的功能。
参数1 : 必需 规定数组 参数2 : 可选 规定排列顺序 SORT_ASC - 默认。按升序排列 (A-Z)。SORT_DESC - 按降序排列 (Z-A)。 参数3 : 可选 规定数组
5.默认地址
(1)业务需求:
当我们遇到网上购物业务时,总会出现购物地址选择是否设置默认地址这个业务,我们不论是添加地址,还是修改地址都需要在仓库中设置判断数据库是否有设置过默认地址的数据,有就要将其修改.
>1.添加功能
//添加功能 注册功能
public function store($request)
{
$insert = [];
//判断数据库是否含有默认地址
$this->model->where('default',1)->update(['default' => 2]);
foreach ($this->model->getFillable() as $v){
if (isset($request[$v])){
$insert[$v] = $request[$v];
}
}
return $this->model->insert($insert) ? $this->result(0,'添加成功') : $this->result(-1,'添加失败');
}
>2.修改功能
//修改功能
public function save($request, $id)
{
$update = [];
//判断数据库是否含有默认地址
$this->model->where('default',1)->update(['default' => 2]);
foreach ($this->model->getFillable() as $v){
if (isset($request[$v])){
$update[$v] = $request[$v];
}
}
return $this->model->where('id',$id)->update($update) ? $this->result(0,'修改成功') : $this->result(-1,'修改失败');
}