服务和WEB隔离

Former-commit-id: 3f07c2e6b59e4949011f4806b9a198e5845d7f41
master
王兵 5 years ago
parent 96bf9cf102
commit 0c7c0b0295

@ -0,0 +1,89 @@
package xyz.wbsite.action.ajax.wsvr;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.multipart.MultipartFile;
import xyz.wbsite.frame.excel.WExcel;
import xyz.wbsite.frame.utils.LogUtil;
import xyz.wbsite.frame.auth.LocalData;
import xyz.wbsite.frame.base.ErrorType;
import xyz.wbsite.frame.utils.MapperUtil;
import xyz.wbsite.frame.base.BaseResponse;
import xyz.wbsite.frame.utils.ResponseUtil;
import xyz.wbsite.frame.utils.ValidationUtil;
import xyz.wbsite.frame.excel.exception.TemplateNotMatchException;
import xyz.wbsite.module.wsvr.ent.Logerr;
import xyz.wbsite.module.wsvr.mgr.LogerrManager;
import xyz.wbsite.module.wsvr.req.LogerrCreateRequest;
import xyz.wbsite.module.wsvr.req.LogerrDeleteRequest;
import xyz.wbsite.module.wsvr.req.LogerrFindRequest;
import xyz.wbsite.module.wsvr.req.LogerrUpdateRequest;
import xyz.wbsite.module.wsvr.rsp.LogerrCreateResponse;
import xyz.wbsite.module.wsvr.rsp.LogerrDeleteResponse;
import xyz.wbsite.module.wsvr.rsp.LogerrFindResponse;
import xyz.wbsite.module.wsvr.rsp.LogerrUpdateResponse;
import java.io.IOException;
import java.util.List;
public class LogerrAjax{
@Autowired
private LogerrManager logerrManager;
public LogerrCreateResponse create(LogerrCreateRequest request) {
return logerrManager.create(request, LocalData.getToken());
}
public LogerrDeleteResponse delete(LogerrDeleteRequest request) {
return logerrManager.delete(request, LocalData.getToken());
}
public LogerrUpdateResponse update(LogerrUpdateRequest request) {
return logerrManager.update(request, LocalData.getToken());
}
public LogerrFindResponse find(LogerrFindRequest request) {
return logerrManager.find(request, LocalData.getToken());
}
public Object template(){
return ResponseUtil.apply(new WExcel<>(Logerr.class));
}
public Object exports(LogerrFindRequest request) {
LogerrFindResponse response = logerrManager.find(request, LocalData.getToken());
if (response.hasError()) {
return response;
} else if (response.getTotalCount() == 0) {
response.addError(ErrorType.BUSINESS_ERROR, "导出数据为空");
return response;
}
return ResponseUtil.apply(new WExcel<>(Logerr.class).addDatas(response.getResult()));
}
public Object imports(MultipartFile file) {
BaseResponse baseResponse = new BaseResponse();
try {
WExcel sheet = new WExcel<>(Logerr.class).read(file.getBytes(), new WExcel.Processor<Logerr>() {
@Override
public List<String> exec(Logerr o, int index) {
LogerrCreateRequest request = MapperUtil.map(o, LogerrCreateRequest.class);
return ValidationUtil.validate(request);
}
});
if (sheet.hasError()) {
return ResponseUtil.apply(sheet.getBytes(), sheet.getName() + "-检查.xlsx");
} else {
return baseResponse;
}
} catch (IOException e) {
e.printStackTrace();
LogUtil.dumpException(e);
baseResponse.addError(ErrorType.BUSINESS_ERROR, "上传文件出错");
} catch (TemplateNotMatchException e) {
baseResponse.addError(ErrorType.BUSINESS_ERROR, e.getMessage());
}
return baseResponse;
}
}

@ -0,0 +1,261 @@
<div id="app" v-cloak>
<el-card class="box-card">
<el-form class="search" :inline="true" :model="vm" ref="vm" label-position="right" label-width="90px">
<el-form-item label="日志类型" prop="logType">
<el-select v-model="vm.logType" clearable size="mini" filterable placeholder="请输入日志类型">
<el-option key="系统错误" label="系统错误" value="系统错误"></el-option>
<el-option key="任务错误" label="任务错误" value="任务错误"></el-option>
<el-option key="业务错误" label="业务错误" value="业务错误"></el-option>
</el-select>
</el-form-item>
<el-form-item label="任务标题" prop="logTitle">
<el-input v-model="vm.logTitle" clearable size="mini" placeholder="请输入任务标题"></el-input>
</el-form-item>
<el-form-item label="日志状态" prop="logState">
<el-select v-model="vm.logState" clearable size="mini" filterable placeholder="请输入日志状态">
<el-option key="0" label="待处理" value="0"></el-option>
<el-option key="1" label="处理中" value="1"></el-option>
<el-option key="2" label="已处理" value="2"></el-option>
</el-select>
</el-form-item>
<el-form-item label="开始日期" prop="startDate">
<el-date-picker v-model="vm.startDate" clearable size="mini" placeholder="请输入开始日期" type="datetime" value-format="yyyy-MM-dd HH:mm:ss"></el-date-picker>
</el-form-item>
<el-form-item label="结束日期" prop="endDate">
<el-date-picker v-model="vm.endDate" clearable size="mini" placeholder="请输入结束日期" type="datetime" value-format="yyyy-MM-dd HH:mm:ss"></el-date-picker>
</el-form-item>
<el-form-item>
<el-button type="primary" size="mini" icon="el-icon-search" @click="onSearch">搜索</el-button>
<el-button type="warning" size="mini" icon="el-icon-refresh-left" @click="onReset('vm')">重置</el-button>
</el-form-item>
</el-form>
</el-card>
<el-card class="box-card">
<el-row>
<el-col :span="12">
<el-button type="success" size="mini" icon="el-icon-plus" @click="onCreate">新增</el-button>
<el-button type="warning" size="mini" icon="el-icon-download" @click="onExport">导出</el-button>
</el-col>
<el-col :span="12">
<el-button-group style="float: right;">
<el-tooltip effect="dark" content="Excel模板下载" placement="bottom">
<el-button size="mini" icon="el-icon-date" @click="onTemplate"></el-button>
</el-tooltip>
<el-tooltip effect="dark" content="Excel导入" placement="bottom">
<el-button size="mini" icon="el-icon-upload2" @click="onImport"></el-button>
</el-tooltip>
<el-tooltip effect="dark" content="批量删除" placement="bottom">
<el-button size="mini" icon="el-icon-delete" @click="onBitchDelete"></el-button>
</el-tooltip>
<el-tooltip effect="dark" content="刷新" placement="bottom">
<el-button size="mini" icon="el-icon-refresh" @click="onFind"></el-button>
</el-tooltip>
</el-button-group>
</el-col>
</el-row>
<el-table
class="data"
@selection-change="onSelectionChange"
empty-text="无数据"
:stripe="true"
:data="result"
size="mini">
<el-table-column
align="center"
width="45"
type="selection">
</el-table-column>
<el-table-column
align="center"
width="140"
prop="id"
label="主键">
</el-table-column>
<el-table-column
align="center"
width="100"
prop="logType"
label="日志类型">
</el-table-column>
<el-table-column
align="center"
width="180"
prop="logTitle"
label="任务标题">
</el-table-column>
<el-table-column
align="center"
width="180"
prop="logNote"
label="日志描述">
</el-table-column>
<el-table-column
align="center"
width="100"
prop="logState"
label="日志状态">
</el-table-column>
<el-table-column
align="center"
width="140"
prop="createTime"
label="创建时间">
</el-table-column>
<el-table-column
align="center"
width="120"
fixed="right"
label="操作">
<template slot-scope="scope">
<wb-dropdown :arg="scope.row">
<wb-dropdown-item value="编辑" icon="el-icon-edit" @click="onEdit"></wb-dropdown-item>
<wb-dropdown-item value="删除" icon="el-icon-delete" @click="onDelete"></wb-dropdown-item>
</wb-dropdown>
</template>
</el-table-column>
</el-table>
<el-pagination
background
v-if="vm.totalCount > vm.pageSize"
style="margin-top: 10px"
@current-change="onPageChange"
@size-change="onPageSizeChange"
:current-page="vm.pageNumber"
:page-size="vm.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="vm.totalCount">
</el-pagination>
</el-card>
<el-dialog
:custom-class="'dialog'"
:title="form.formTitle"
:close-on-click-modal="false"
:visible.sync="form.formShow">
<el-form class="form" :model="form" :inline="true" :rules="formRules" ref="form" label-position="right" label-width="90px">
<el-select v-model="vm.logType" clearable size="mini" filterable placeholder="请输入日志类型">
<el-option key="系统错误" label="系统错误" value="系统错误"></el-option>
<el-option key="任务错误" label="任务错误" value="任务错误"></el-option>
<el-option key="业务错误" label="业务错误" value="业务错误"></el-option>
</el-select>
<el-form-item label="任务标题" prop="logTitle">
<el-input v-model="form.logTitle" clearable size="mini" placeholder="请输入任务标题" maxlength="50"></el-input>
</el-form-item>
<el-form-item label="日志描述" prop="logNote">
<el-input v-model="form.logNote"
clearable
size="mini"
placeholder="请输入日志描述"
type="textarea"
maxlength="500"
show-word-limit></el-input>
</el-form-item>
<el-select v-model="vm.logState" clearable size="mini" filterable placeholder="请输入日志状态">
<el-option key="0" label="待处理" value="0"></el-option>
<el-option key="1" label="处理中" value="1"></el-option>
<el-option key="2" label="已处理" value="2"></el-option>
</el-select>
</el-form>
<span slot="footer" class="dialog-footer">
<el-button size="mini" @click="form.formShow = false">取 消</el-button>
<el-button size="mini" type="primary" @click="onSave">保存</el-button>
</span>
</el-dialog>
</div>
<script>
var app = new Vue({
mixins: [mixin],
el: "#app",
data: {
module: 'wsvr',
target: 'logerr',
vm: {//条件及分页参数
logType: null,
logTitle: null,
logState: null,
startDate: null,
endDate: null,
pageNumber: 1,
pageSize: 10,
totalCount: 0,
sortKey:'CREATE_TIME',
sortType:'DESC'
},
form: {//待提交表单
formTitle: "",
formShow: false,
id: null,
logType: null,
logTitle: null,
logNote: null,
logState: null,
rowVersion: null
},
formRules: {
logType: [
{required: true, message: '日志类型不能为空', trigger: 'blur'},
],
logTitle: [
{required: true, message: '任务标题不能为空', trigger: 'blur'},
{min: 1, max: 50, message: '任务标题长度在 1 到 50 个字符', trigger: 'blur'}
],
logNote: [
{min: 1, max: 500, message: '日志描述长度在 1 到 500 个字符', trigger: 'blur'}
],
logState: [
{required: true, message: '日志状态不能为空', trigger: 'blur'},
],
}
},
methods: {
onCreate: function () {
this.form.formTitle = "错误日志新增";
this.form.formShow = true;
this.form.id = "";
this.form.logType = "";
this.form.logTitle = "";
this.form.logNote = "";
this.form.logState = "";
},
onEdit: function (item) {
this.form.formTitle = "错误日志编辑";
this.form.formShow = true;
this.form.id = item.id;
this.form.logType = item.logType;
this.form.logTitle = item.logTitle;
this.form.logNote = item.logNote;
this.form.logState = item.logState;
this.form.rowVersion = item.rowVersion;
},
onDelete: function (item) {
this.$confirm('将删除该项, 是否继续?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(function () {
new Ajax("E:\wangbing\source\dbtool\target\project\wadmin\src\main\resources\templates\screen\wsvr", "logerr").delete({id: item.id}, function (response) {
if (response.errors.length > 0) {
nav.e(response.errors[0].message);
} else {
nav.s("删除成功.");
this.onFind();
}
}.bind(this))
}.bind(this)).catch(function (action) {
});
}
},
mounted: function () {
this.onFind();
},
})
</script>
Loading…
Cancel
Save

Powered by TurnKey Linux.