awssat/laravel-visits
他的功能主要用于 区分 IP 访问次数就是我最需要的了!!!tag 也是用于区别存储信息很重要的东西
考虑到扩展包升级之类的问题就把 github 地址放在上面了,升级后观看相关文档就可以了 ->github 地址
一个模型中支持多个统计字段(使用 tag 来区分);
支持所有数据模型(不像有些扩展包只是 User 专用);
支持区分 IP 访问次数,页面多刷几次查看数也不会增加(可配置);
读取最多和最少访问量排序的模型列表;
获取访问量最高的国家;
获取月份、年份、全部统计访问量模型排序列表。
1. 首先是使用 composer 安装扩展包
$ composer require awssat/laravel-visits
2. 接下来发布配置文件
php artisan vendor:publish --provider="Awssat\Visits\VisitsServiceProvider"
3. 因为是用 redis 存储访问量所以要确保 redis 正常运行
4. 在 config/database.php 中新建一个 redis 配置专门用于存储访问
.
.
.
'redis' => [
'client' => 'predis',
'default' => [
.
.
.
],
'laravel-visits' => [
'host' => env('REDIS_HOST', '127.0.0.1'),
'password' => env('REDIS_PASSWORD', null),
'port' => env('REDIS_PORT', 6379),
'database' => 3, // anything from 1 to 15, except 0 (or what is set in default)
],
],
.
.
.
5. 由于我做的是接口部分,所以这里基本上就大功告成了接下来就是使用 visit()存储和读取了
接口存储部分 $id 为百科中每本书的 ID increment()内可以填写累加的数量,默认为 1 visit 的第一个参数为每个模型的实例化
//根据百科id获取百科详细信息
public function getEncyclopedia($id)
{
$list=new Encyclopedium();
//阅读量+1
visits($list,$id)->increment();//这里$id为百科书籍ID,这样设置tag就能定位到每本书籍了
return $list->where('id',$id)->first(['id','title','quarry','created_at','textarea'])->toarray();
}
接口读取部分 循环中的 $list [$k][‘id’] 为每本书的 id 因为是展示列表所以在循环中读取并添加到数组当中
//根据一级分类以及二级分类查找百科列表
public function getEncyclopediaList($stage_id,$cate_id)
{
$list=new Encyclopedium();
//访问量不再使用数据库字段改用redis缓存
$list=$list->where(['encyclopedia_stage_id'=>$stage_id,'encyclopedia_cate_id'=>$cate_id])->get(['id','title','text'])->toarray();
foreach ($list as $k=>$v) {
$list[$k]['count_read']=visits(new Encyclopedium(),$list[$k]['id'])->count();
}
return $list;
}
这样访问数量就搬到了 redis 中,下面进行数据隔离的操作
6. 修改 visit 配置在 config/visits.php 实现 ip 隔离,默认情况下 ip 隔离也是开启的,只不过默认时间应该是 15 分钟,这样配置完成的话每天每个 ip 只记录一次的话会数据更精准一些,如果还有其他要求可以再新增一些 redis 配置然后在配置文件中添加相应配置,修改 connection 和 remeber_ip 就可以了,由于本人较懒,整张配置文件就直接放到上面了
<?php
return [
/*
|--------------------------------------------------------------------------
| Database Engine & Connection Name
|--------------------------------------------------------------------------
|
| Supported Engines: "redis", "eloquent"
| Connection Name: see config/database.php
|
*/
'engine' => 'redis',
'connection' => 'laravel-visits',
/*
|--------------------------------------------------------------------------
| Counters periods
|--------------------------------------------------------------------------
|
| Record visits (total) of each one of these periods in this set (can be empty)
|
*/
'periods' => [
'day',
'week',
'month',
'year',
],
/*
|--------------------------------------------------------------------------
| Redis prefix
|--------------------------------------------------------------------------
*/
'keys_prefix' => 'visits',
/*
|--------------------------------------------------------------------------
| Remember ip for x seconds of time
|--------------------------------------------------------------------------
|
| Will count only one visit of an IP during this specified time.
|
*/
'remember_ip' => 24 * 60 * 60,
/*
|--------------------------------------------------------------------------
| Always return uncached fresh top/low lists
|--------------------------------------------------------------------------
*/
'always_fresh' => false,
/*
|--------------------------------------------------------------------------
| Ignore Crawlers
|--------------------------------------------------------------------------
|
| Ignore counting crawlers visits or not
|
*/
'ignore_crawlers' => true,
/*
|--------------------------------------------------------------------------
| Global Ignore Recording
|--------------------------------------------------------------------------
|
| stop recording specific items (can be any of these: 'country', 'refer', 'periods', 'operatingSystem', 'language')
|
*/
'global_ignore' => ['country'],
];