feat(file): 添加文件浏览次数统计功能

- 在文件列表表格中新增浏览次数列显示
- 在文件详情描述中添加浏览次数信息展示
- 实现文件浏览次数自增接口 incrementView
- 前端点击文件预览时自动调用浏览次数增加功能
- 后端添加 SysFile 实体类 viewCount 字段
- 实现数据库表字段映射和更新逻辑
- 添加控制器接口 /incrementView/{fileId} 处理请求
This commit is contained in:
jhd
2026-07-04 09:40:48 +08:00
parent fa30ac37e9
commit 5029d09f09
9 changed files with 55 additions and 1 deletions

View File

@@ -98,6 +98,15 @@ public class SysFileController extends BaseController {
return toAjax(iSysFileService.deleteWithValidByIds(Arrays.asList(fileIds), true));
}
/**
* 文件浏览次数 +1
*/
@PutMapping("/incrementView/{fileId}")
public R<Void> incrementView(@NotNull(message = "主键不能为空") @PathVariable Long fileId) {
iSysFileService.incrementViewCount(fileId);
return R.ok();
}
/**
* 查询与我相关的文件(私有文件且当前用户在可见用户列表中)
*/

View File

@@ -60,6 +60,10 @@ public class SysFile extends BaseEntity {
* 备注
*/
private String remark;
/**
* 浏览次数
*/
private Long viewCount;
/**
* 删除标识 0正常 2删除
*/

View File

@@ -67,5 +67,9 @@ public class SysFileBo extends BaseEntity {
*/
private String remark;
/**
* 浏览次数
*/
private Long viewCount;
}

View File

@@ -80,5 +80,10 @@ public class SysFileVo extends BaseEntity {
@ExcelProperty(value = "备注")
private String remark;
/**
* 浏览次数
*/
@ExcelProperty(value = "浏览次数")
private Long viewCount;
}

View File

@@ -51,4 +51,9 @@ public interface ISysFileService {
* 查询与我相关的文件(私有文件且当前用户在可见用户列表中)
*/
TableDataInfo<SysFileVo> queryPageListRelatedToMe(SysFileBo bo, PageQuery pageQuery);
/**
* 文件浏览次数 +1
*/
void incrementViewCount(Long fileId);
}

View File

@@ -5,6 +5,7 @@ import com.klp.common.core.page.TableDataInfo;
import com.klp.common.core.domain.PageQuery;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.klp.common.helper.LoginHelper;
import com.klp.common.utils.StringUtils;
@@ -124,6 +125,16 @@ public class SysFileServiceImpl implements ISysFileService {
return TableDataInfo.build(result);
}
/**
* 文件浏览次数 +1
*/
@Override
public void incrementViewCount(Long fileId) {
baseMapper.update(null, Wrappers.<SysFile>lambdaUpdate()
.setSql("view_count = view_count + 1")
.eq(SysFile::getFileId, fileId));
}
/**
* 保存前的数据校验
*/

View File

@@ -15,6 +15,7 @@
<result property="fileType" column="file_type"/>
<result property="scopeType" column="scope_type"/>
<result property="remark" column="remark"/>
<result property="viewCount" column="view_count"/>
<result property="createBy" column="create_by"/>
<result property="createTime" column="create_time"/>
<result property="updateBy" column="update_by"/>

View File

@@ -52,6 +52,14 @@ export function exportFile(query) {
})
}
// 文件浏览次数 +1
export function incrementView(fileId) {
return request({
url: '/system/file/incrementView/' + fileId,
method: 'put'
})
}
// 查询与我相关的文件
export function listRelatedToMe(query) {
return request({

View File

@@ -152,6 +152,11 @@
<span>{{ parseTime(scope.row.createTime) }}</span>
</template>
</el-table-column>
<el-table-column label="浏览次数" align="center" width="90">
<template slot-scope="scope">
<span>{{ scope.row.viewCount != null ? scope.row.viewCount : 0 }}</span>
</template>
</el-table-column>
</KLPTable>
<pagination
@@ -274,6 +279,7 @@
</el-descriptions-item>
<el-descriptions-item label="文件大小">{{ formatFileSize(infoFile.fileSize) }}</el-descriptions-item>
<el-descriptions-item label="文件后缀">{{ infoFile.suffix || '-' }}</el-descriptions-item>
<el-descriptions-item label="浏览次数">{{ infoFile.viewCount != null ? infoFile.viewCount : 0 }} </el-descriptions-item>
<el-descriptions-item label="订单编号">{{ infoFile.orderNo || '-' }}</el-descriptions-item>
<el-descriptions-item label="所属部门">{{ infoFile.dept || '-' }}</el-descriptions-item>
<el-descriptions-item label="可见范围">
@@ -291,7 +297,7 @@
</template>
<script>
import { listFile, getFile, addFile, updateFile, delFile, exportFile, listVisibleUser, addVisibleUser, delVisibleUser, listVisibleUserByFileId, listRelatedToMe } from '@/api/system/file'
import { listFile, getFile, addFile, updateFile, delFile, exportFile, listVisibleUser, addVisibleUser, delVisibleUser, listVisibleUserByFileId, listRelatedToMe, incrementView } from '@/api/system/file'
import { getToken } from '@/utils/auth'
import UserSelect from '@/components/KLPService/UserSelect/index'
import ImagePreview from '@/components/FilePreview/preview/image/index.vue'
@@ -698,6 +704,7 @@ export default {
/** 点击文件名查看预览 */
handlePreview(row) {
this.selectedFile = row
incrementView(row.fileId)
},
/** 点击查看按钮弹出详情 */
handleShowInfo(row) {