From af0e0a110e7187bf008655f7510199a0c0b25ec4 Mon Sep 17 00:00:00 2001 From: Nymph2333 <498092988@qq.com> Date: 星期一, 10 四月 2023 14:27:40 +0800 Subject: [PATCH] newInstance() 已弃用,使用clazz.getDeclaredConstructor().newInstance() This method propagates any exception thrown by the nullary constructor, including a checked exception. Use of this method effectively bypasses the compile-time exception checking that would otherwise be performed by the compiler. The Constructor.newInstance method avoids this problem by wrapping any exception thrown by the constructor in a (checked) InvocationTargetException. The call clazz.newInstance() can be replaced by clazz.getDeclaredConstructor().newInstance() The latter sequence of calls is inferred to be able to throw the additional exception types InvocationTargetException and NoSuchMethodException. Both of these exception types are subclasses of ReflectiveOperationException. --- ruoyi-ui/src/views/monitor/operlog/index.vue | 628 ++++++++++++++++++++++++++++---------------------------- 1 files changed, 313 insertions(+), 315 deletions(-) diff --git a/ruoyi-ui/src/views/monitor/operlog/index.vue b/ruoyi-ui/src/views/monitor/operlog/index.vue index ba84d3c..34a3ce3 100644 --- a/ruoyi-ui/src/views/monitor/operlog/index.vue +++ b/ruoyi-ui/src/views/monitor/operlog/index.vue @@ -1,315 +1,313 @@ -<template> - <div class="app-container"> - <el-form :model="queryParams" ref="queryForm" :inline="true" label-width="68px"> - <el-form-item label="系统模块" prop="title"> - <el-input - v-model="queryParams.title" - placeholder="请输入系统模块" - clearable - style="width: 240px;" - size="small" - @keyup.enter.native="handleQuery" - /> - </el-form-item> - <el-form-item label="操作人员" prop="operName"> - <el-input - v-model="queryParams.operName" - placeholder="请输入操作人员" - clearable - style="width: 240px;" - size="small" - @keyup.enter.native="handleQuery" - /> - </el-form-item> - <el-form-item label="类型" prop="businessType"> - <el-select - v-model="queryParams.businessType" - placeholder="操作类型" - clearable - size="small" - style="width: 240px" - > - <el-option - v-for="dict in typeOptions" - :key="dict.dictValue" - :label="dict.dictLabel" - :value="dict.dictValue" - /> - </el-select> - </el-form-item> - <el-form-item label="状态" prop="status"> - <el-select - v-model="queryParams.status" - placeholder="操作状态" - clearable - size="small" - style="width: 240px" - > - <el-option - v-for="dict in statusOptions" - :key="dict.dictValue" - :label="dict.dictLabel" - :value="dict.dictValue" - /> - </el-select> - </el-form-item> - <el-form-item label="操作时间"> - <el-date-picker - v-model="dateRange" - size="small" - style="width: 240px" - value-format="yyyy-MM-dd" - type="daterange" - range-separator="-" - start-placeholder="开始日期" - end-placeholder="结束日期" - ></el-date-picker> - </el-form-item> - <el-form-item> - <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button> - <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button> - </el-form-item> - </el-form> - - <el-row :gutter="10" class="mb8"> - <el-col :span="1.5"> - <el-button - type="danger" - icon="el-icon-delete" - size="mini" - :disabled="multiple" - @click="handleDelete" - v-hasPermi="['monitor:operlog:remove']" - >删除</el-button> - </el-col> - <el-col :span="1.5"> - <el-button - type="danger" - icon="el-icon-delete" - size="mini" - @click="handleClean" - v-hasPermi="['monitor:operlog:remove']" - >清空</el-button> - </el-col> - <el-col :span="1.5"> - <el-button - type="warning" - icon="el-icon-download" - size="mini" - @click="handleExport" - v-hasPermi="['system:config:export']" - >导出</el-button> - </el-col> - </el-row> - - <el-table v-loading="loading" :data="list" @selection-change="handleSelectionChange"> - <el-table-column type="selection" width="55" align="center" /> - <el-table-column label="日志编号" align="center" prop="operId" /> - <el-table-column label="系统模块" align="center" prop="title" /> - <el-table-column label="操作类型" align="center" prop="businessType" :formatter="typeFormat" /> - <el-table-column label="请求方式" align="center" prop="requestMethod" /> - <el-table-column label="操作人员" align="center" prop="operName" /> - <el-table-column label="主机" align="center" prop="operIp" width="130" :show-overflow-tooltip="true" /> - <el-table-column label="操作地点" align="center" prop="operLocation" :show-overflow-tooltip="true" /> - <el-table-column label="操作状态" align="center" prop="status" :formatter="statusFormat" /> - <el-table-column label="操作日期" align="center" prop="operTime" width="180"> - <template slot-scope="scope"> - <span>{{ parseTime(scope.row.operTime) }}</span> - </template> - </el-table-column> - <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> - <template slot-scope="scope"> - <el-button - size="mini" - type="text" - icon="el-icon-view" - @click="handleView(scope.row,scope.index)" - v-hasPermi="['monitor:operlog:query']" - >详细</el-button> - </template> - </el-table-column> - </el-table> - - <pagination - v-show="total>0" - :total="total" - :page.sync="queryParams.pageNum" - :limit.sync="queryParams.pageSize" - @pagination="getList" - /> - - <!-- 操作日志详细 --> - <el-dialog title="操作日志详细" :visible.sync="open" width="700px" append-to-body> - <el-form ref="form" :model="form" label-width="100px" size="mini"> - <el-row> - <el-col :span="12"> - <el-form-item label="操作模块:">{{ form.title }} / {{ typeFormat(form) }}</el-form-item> - <el-form-item - label="登录信息:" - >{{ form.operName }} / {{ form.operIp }} / {{ form.operLocation }}</el-form-item> - </el-col> - <el-col :span="12"> - <el-form-item label="请求地址:">{{ form.operUrl }}</el-form-item> - <el-form-item label="请求方式:">{{ form.requestMethod }}</el-form-item> - </el-col> - <el-col :span="24"> - <el-form-item label="操作方法:">{{ form.method }}</el-form-item> - </el-col> - <el-col :span="24"> - <el-form-item label="请求参数:">{{ form.operParam }}</el-form-item> - </el-col> - <el-col :span="24"> - <el-form-item label="返回参数:">{{ form.jsonResult }}</el-form-item> - </el-col> - <el-col :span="12"> - <el-form-item label="操作状态:"> - <div v-if="form.status === 0">正常</div> - <div v-else-if="form.status === 1">失败</div> - </el-form-item> - </el-col> - <el-col :span="12"> - <el-form-item label="操作时间:">{{ parseTime(form.operTime) }}</el-form-item> - </el-col> - <el-col :span="24"> - <el-form-item label="异常信息:" v-if="form.status === 1">{{ form.errorMsg }}</el-form-item> - </el-col> - </el-row> - </el-form> - <div slot="footer" class="dialog-footer"> - <el-button @click="open = false">关 闭</el-button> - </div> - </el-dialog> - </div> -</template> - -<script> -import { list, delOperlog, cleanOperlog, exportOperlog } from "@/api/monitor/operlog"; - -export default { - name: "Operlog", - data() { - return { - // 遮罩层 - loading: true, - // 选中数组 - ids: [], - // 非多个禁用 - multiple: true, - // 总条数 - total: 0, - // 表格数据 - list: [], - // 是否显示弹出层 - open: false, - // 类型数据字典 - typeOptions: [], - // 类型数据字典 - statusOptions: [], - // 日期范围 - dateRange: [], - // 表单参数 - form: {}, - // 查询参数 - queryParams: { - pageNum: 1, - pageSize: 10, - title: undefined, - operName: undefined, - businessType: undefined, - status: undefined - } - }; - }, - created() { - this.getList(); - this.getDicts("sys_oper_type").then(response => { - this.typeOptions = response.data; - }); - this.getDicts("sys_common_status").then(response => { - this.statusOptions = response.data; - }); - }, - methods: { - /** 查询登录日志 */ - getList() { - this.loading = true; - list(this.addDateRange(this.queryParams, this.dateRange)).then( response => { - this.list = response.rows; - this.total = response.total; - this.loading = false; - } - ); - }, - // 操作日志状态字典翻译 - statusFormat(row, column) { - return this.selectDictLabel(this.statusOptions, row.status); - }, - // 操作日志类型字典翻译 - typeFormat(row, column) { - return this.selectDictLabel(this.typeOptions, row.businessType); - }, - /** 搜索按钮操作 */ - handleQuery() { - this.queryParams.pageNum = 1; - this.getList(); - }, - /** 重置按钮操作 */ - resetQuery() { - this.dateRange = []; - this.resetForm("queryForm"); - this.handleQuery(); - }, - // 多选框选中数据 - handleSelectionChange(selection) { - this.ids = selection.map(item => item.operId) - this.multiple = !selection.length - }, - /** 详细按钮操作 */ - handleView(row) { - this.open = true; - this.form = row; - }, - /** 删除按钮操作 */ - handleDelete(row) { - const operIds = row.operId || this.ids; - this.$confirm('是否确认删除日志编号为"' + operIds + '"的数据项?', "警告", { - confirmButtonText: "确定", - cancelButtonText: "取消", - type: "warning" - }).then(function() { - return delOperlog(operIds); - }).then(() => { - this.getList(); - this.msgSuccess("删除成功"); - }).catch(function() {}); - }, - /** 清空按钮操作 */ - handleClean() { - this.$confirm('是否确认清空所有操作日志数据项?', "警告", { - confirmButtonText: "确定", - cancelButtonText: "取消", - type: "warning" - }).then(function() { - return cleanOperlog(); - }).then(() => { - this.getList(); - this.msgSuccess("清空成功"); - }).catch(function() {}); - }, - /** 导出按钮操作 */ - handleExport() { - const queryParams = this.queryParams; - this.$confirm('是否确认导出所有操作日志数据项?', "警告", { - confirmButtonText: "确定", - cancelButtonText: "取消", - type: "warning" - }).then(function() { - return exportOperlog(queryParams); - }).then(response => { - this.download(response.msg); - }).catch(function() {}); - } - } -}; -</script> - +<template> + <div class="app-container"> + <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> + <el-form-item label="系统模块" prop="title"> + <el-input + v-model="queryParams.title" + placeholder="请输入系统模块" + clearable + style="width: 240px;" + @keyup.enter.native="handleQuery" + /> + </el-form-item> + <el-form-item label="操作人员" prop="operName"> + <el-input + v-model="queryParams.operName" + placeholder="请输入操作人员" + clearable + style="width: 240px;" + @keyup.enter.native="handleQuery" + /> + </el-form-item> + <el-form-item label="类型" prop="businessType"> + <el-select + v-model="queryParams.businessType" + placeholder="操作类型" + clearable + style="width: 240px" + > + <el-option + v-for="dict in dict.type.sys_oper_type" + :key="dict.value" + :label="dict.label" + :value="dict.value" + /> + </el-select> + </el-form-item> + <el-form-item label="状态" prop="status"> + <el-select + v-model="queryParams.status" + placeholder="操作状态" + clearable + style="width: 240px" + > + <el-option + v-for="dict in dict.type.sys_common_status" + :key="dict.value" + :label="dict.label" + :value="dict.value" + /> + </el-select> + </el-form-item> + <el-form-item label="操作时间"> + <el-date-picker + v-model="dateRange" + style="width: 240px" + value-format="yyyy-MM-dd HH:mm:ss" + type="daterange" + range-separator="-" + start-placeholder="开始日期" + end-placeholder="结束日期" + :default-time="['00:00:00', '23:59:59']" + ></el-date-picker> + </el-form-item> + <el-form-item> + <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button> + <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button> + </el-form-item> + </el-form> + + <el-row :gutter="10" class="mb8"> + <el-col :span="1.5"> + <el-button + type="danger" + plain + icon="el-icon-delete" + size="mini" + :disabled="multiple" + @click="handleDelete" + v-hasPermi="['monitor:operlog:remove']" + >删除</el-button> + </el-col> + <el-col :span="1.5"> + <el-button + type="danger" + plain + icon="el-icon-delete" + size="mini" + @click="handleClean" + v-hasPermi="['monitor:operlog:remove']" + >清空</el-button> + </el-col> + <el-col :span="1.5"> + <el-button + type="warning" + plain + icon="el-icon-download" + size="mini" + @click="handleExport" + v-hasPermi="['monitor:operlog:export']" + >导出</el-button> + </el-col> + <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> + </el-row> + + <el-table ref="tables" v-loading="loading" :data="list" @selection-change="handleSelectionChange" :default-sort="defaultSort" @sort-change="handleSortChange"> + <el-table-column type="selection" width="50" align="center" /> + <el-table-column label="日志编号" align="center" prop="operId" /> + <el-table-column label="系统模块" align="center" prop="title" :show-overflow-tooltip="true" /> + <el-table-column label="操作类型" align="center" prop="businessType"> + <template slot-scope="scope"> + <dict-tag :options="dict.type.sys_oper_type" :value="scope.row.businessType"/> + </template> + </el-table-column> + <el-table-column label="操作人员" align="center" prop="operName" width="110" :show-overflow-tooltip="true" sortable="custom" :sort-orders="['descending', 'ascending']" /> + <el-table-column label="操作地址" align="center" prop="operIp" width="130" :show-overflow-tooltip="true" /> + <el-table-column label="操作地点" align="center" prop="operLocation" :show-overflow-tooltip="true" /> + <el-table-column label="操作状态" align="center" prop="status"> + <template slot-scope="scope"> + <dict-tag :options="dict.type.sys_common_status" :value="scope.row.status"/> + </template> + </el-table-column> + <el-table-column label="操作日期" align="center" prop="operTime" width="160" sortable="custom" :sort-orders="['descending', 'ascending']"> + <template slot-scope="scope"> + <span>{{ parseTime(scope.row.operTime) }}</span> + </template> + </el-table-column> + <el-table-column label="消耗时间" align="center" prop="costTime" width="110" :show-overflow-tooltip="true" sortable="custom" :sort-orders="['descending', 'ascending']"> + <template slot-scope="scope"> + <span>{{ scope.row.costTime }}毫秒</span> + </template> + </el-table-column> + <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> + <template slot-scope="scope"> + <el-button + size="mini" + type="text" + icon="el-icon-view" + @click="handleView(scope.row,scope.index)" + v-hasPermi="['monitor:operlog:query']" + >详细</el-button> + </template> + </el-table-column> + </el-table> + + <pagination + v-show="total>0" + :total="total" + :page.sync="queryParams.pageNum" + :limit.sync="queryParams.pageSize" + @pagination="getList" + /> + + <!-- 操作日志详细 --> + <el-dialog title="操作日志详细" :visible.sync="open" width="700px" append-to-body> + <el-form ref="form" :model="form" label-width="100px" size="mini"> + <el-row> + <el-col :span="12"> + <el-form-item label="操作模块:">{{ form.title }} / {{ typeFormat(form) }}</el-form-item> + <el-form-item + label="登录信息:" + >{{ form.operName }} / {{ form.operIp }} / {{ form.operLocation }}</el-form-item> + </el-col> + <el-col :span="12"> + <el-form-item label="请求地址:">{{ form.operUrl }}</el-form-item> + <el-form-item label="请求方式:">{{ form.requestMethod }}</el-form-item> + </el-col> + <el-col :span="24"> + <el-form-item label="操作方法:">{{ form.method }}</el-form-item> + </el-col> + <el-col :span="24"> + <el-form-item label="请求参数:">{{ form.operParam }}</el-form-item> + </el-col> + <el-col :span="24"> + <el-form-item label="返回参数:">{{ form.jsonResult }}</el-form-item> + </el-col> + <el-col :span="6"> + <el-form-item label="操作状态:"> + <div v-if="form.status === 0">正常</div> + <div v-else-if="form.status === 1">失败</div> + </el-form-item> + </el-col> + <el-col :span="8"> + <el-form-item label="消耗时间:">{{ form.costTime }}毫秒</el-form-item> + </el-col> + <el-col :span="10"> + <el-form-item label="操作时间:">{{ parseTime(form.operTime) }}</el-form-item> + </el-col> + <el-col :span="24"> + <el-form-item label="异常信息:" v-if="form.status === 1">{{ form.errorMsg }}</el-form-item> + </el-col> + </el-row> + </el-form> + <div slot="footer" class="dialog-footer"> + <el-button @click="open = false">关 闭</el-button> + </div> + </el-dialog> + </div> +</template> + +<script> +import { list, delOperlog, cleanOperlog } from "@/api/monitor/operlog"; + +export default { + name: "Operlog", + dicts: ['sys_oper_type', 'sys_common_status'], + data() { + return { + // 遮罩层 + loading: true, + // 选中数组 + ids: [], + // 非多个禁用 + multiple: true, + // 显示搜索条件 + showSearch: true, + // 总条数 + total: 0, + // 表格数据 + list: [], + // 是否显示弹出层 + open: false, + // 日期范围 + dateRange: [], + // 默认排序 + defaultSort: {prop: 'operTime', order: 'descending'}, + // 表单参数 + form: {}, + // 查询参数 + queryParams: { + pageNum: 1, + pageSize: 10, + title: undefined, + operName: undefined, + businessType: undefined, + status: undefined + } + }; + }, + created() { + this.getList(); + }, + methods: { + /** 查询登录日志 */ + getList() { + this.loading = true; + list(this.addDateRange(this.queryParams, this.dateRange)).then( response => { + this.list = response.rows; + this.total = response.total; + this.loading = false; + } + ); + }, + // 操作日志类型字典翻译 + typeFormat(row, column) { + return this.selectDictLabel(this.dict.type.sys_oper_type, row.businessType); + }, + /** 搜索按钮操作 */ + handleQuery() { + this.queryParams.pageNum = 1; + this.getList(); + }, + /** 重置按钮操作 */ + resetQuery() { + this.dateRange = []; + this.resetForm("queryForm"); + this.queryParams.pageNum = 1; + this.$refs.tables.sort(this.defaultSort.prop, this.defaultSort.order) + }, + /** 多选框选中数据 */ + handleSelectionChange(selection) { + this.ids = selection.map(item => item.operId) + this.multiple = !selection.length + }, + /** 排序触发事件 */ + handleSortChange(column, prop, order) { + this.queryParams.orderByColumn = column.prop; + this.queryParams.isAsc = column.order; + this.getList(); + }, + /** 详细按钮操作 */ + handleView(row) { + this.open = true; + this.form = row; + }, + /** 删除按钮操作 */ + handleDelete(row) { + const operIds = row.operId || this.ids; + this.$modal.confirm('是否确认删除日志编号为"' + operIds + '"的数据项?').then(function() { + return delOperlog(operIds); + }).then(() => { + this.getList(); + this.$modal.msgSuccess("删除成功"); + }).catch(() => {}); + }, + /** 清空按钮操作 */ + handleClean() { + this.$modal.confirm('是否确认清空所有操作日志数据项?').then(function() { + return cleanOperlog(); + }).then(() => { + this.getList(); + this.$modal.msgSuccess("清空成功"); + }).catch(() => {}); + }, + /** 导出按钮操作 */ + handleExport() { + this.download('monitor/operlog/export', { + ...this.queryParams + }, `operlog_${new Date().getTime()}.xlsx`) + } + } +}; +</script> + -- Gitblit v1.9.2