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/logininfor/index.vue | 35 +++++++++++++++++++++++++++++++---- 1 files changed, 31 insertions(+), 4 deletions(-) diff --git a/ruoyi-ui/src/views/monitor/logininfor/index.vue b/ruoyi-ui/src/views/monitor/logininfor/index.vue index e9490e7..d6af834 100644 --- a/ruoyi-ui/src/views/monitor/logininfor/index.vue +++ b/ruoyi-ui/src/views/monitor/logininfor/index.vue @@ -38,11 +38,12 @@ <el-date-picker v-model="dateRange" style="width: 240px" - value-format="yyyy-MM-dd" + 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> @@ -75,6 +76,17 @@ </el-col> <el-col :span="1.5"> <el-button + type="primary" + plain + icon="el-icon-unlock" + size="mini" + :disabled="single" + @click="handleUnlock" + v-hasPermi="['monitor:logininfor:unlock']" + >解锁</el-button> + </el-col> + <el-col :span="1.5"> + <el-button type="warning" plain icon="el-icon-download" @@ -99,7 +111,7 @@ <dict-tag :options="dict.type.sys_common_status" :value="scope.row.status"/> </template> </el-table-column> - <el-table-column label="操作信息" align="center" prop="msg" /> + <el-table-column label="操作信息" align="center" prop="msg" :show-overflow-tooltip="true" /> <el-table-column label="登录日期" align="center" prop="loginTime" sortable="custom" :sort-orders="['descending', 'ascending']" width="180"> <template slot-scope="scope"> <span>{{ parseTime(scope.row.loginTime) }}</span> @@ -118,7 +130,7 @@ </template> <script> -import { list, delLogininfor, cleanLogininfor } from "@/api/monitor/logininfor"; +import { list, delLogininfor, cleanLogininfor, unlockLogininfor } from "@/api/monitor/logininfor"; export default { name: "Logininfor", @@ -129,8 +141,12 @@ loading: true, // 选中数组 ids: [], + // 非单个禁用 + single: true, // 非多个禁用 multiple: true, + // 选择用户名 + selectName: "", // 显示搜索条件 showSearch: true, // 总条数 @@ -174,13 +190,15 @@ resetQuery() { this.dateRange = []; this.resetForm("queryForm"); + this.queryParams.pageNum = 1; this.$refs.tables.sort(this.defaultSort.prop, this.defaultSort.order) - this.handleQuery(); }, /** 多选框选中数据 */ handleSelectionChange(selection) { this.ids = selection.map(item => item.infoId) + this.single = selection.length!=1 this.multiple = !selection.length + this.selectName = selection.map(item => item.userName); }, /** 排序触发事件 */ handleSortChange(column, prop, order) { @@ -207,6 +225,15 @@ this.$modal.msgSuccess("清空成功"); }).catch(() => {}); }, + /** 解锁按钮操作 */ + handleUnlock() { + const username = this.selectName; + this.$modal.confirm('是否确认解锁用户"' + username + '"数据项?').then(function() { + return unlockLogininfor(username); + }).then(() => { + this.$modal.msgSuccess("用户" + username + "解锁成功"); + }).catch(() => {}); + }, /** 导出按钮操作 */ handleExport() { this.download('monitor/logininfor/export', { -- Gitblit v1.9.2