package se.wgcloud.controller; import cn.hutool.json.JSONUtil; import com.github.pagehelper.PageInfo; import se.wgcloud.dto.MessageDto; import se.wgcloud.entity.DbInfo; import se.wgcloud.service.DbInfoService; import se.wgcloud.service.DbTableService; import se.wgcloud.service.LogInfoService; import se.wgcloud.util.PageUtil; import se.wgcloud.util.jdbc.ConnectionUtil; import se.wgcloud.util.staticvar.StaticKeys; import org.apache.commons.lang3.StringUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; import org.springframework.web.servlet.mvc.support.RedirectAttributes; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import java.util.HashMap; import java.util.Map; /** * @version v2.3 * @ClassName: DbInfoController.java * @author: * @date: 2019年11月16日 * @Description: DbInfoController.java * @Copyright: */ @Controller @RequestMapping("/dbInfo") public class DbInfoController { private static final Logger logger = LoggerFactory.getLogger(DbInfoController.class); @Resource private DbInfoService dbInfoService; @Resource private DbTableService dbTableService; @Resource private LogInfoService logInfoService; @Resource private ConnectionUtil connectionUtil; /** * 测试数据库连接 * * @param model * @param request * @return */ @ResponseBody @RequestMapping(value = "validate") public String valdateDbInfo(DbInfo DbInfo, Model model, HttpServletRequest request) { MessageDto messageDto = new MessageDto(); try { JdbcTemplate JdbcTemplate = connectionUtil.getJdbcTemplate(DbInfo); if (JdbcTemplate == null) { messageDto.setCode("1"); messageDto.setMsg("连接数据库错误,请检查参数是否正确。请在系统信息里查看日志"); } else { messageDto.setCode("0"); messageDto.setMsg("连接数据库成功"); } } catch (Exception e) { logger.error("测试数据源信息错误", e); logInfoService.save("测试数据源信息错误", e.toString(), StaticKeys.LOG_ERROR); } return JSONUtil.toJsonStr(messageDto); } /** * 根据条件查询列表 * * @param model * @param request * @return */ @RequestMapping(value = "list") public String DbInfoList(DbInfo DbInfo, Model model, HttpServletRequest request) { Map params = new HashMap(); try { PageInfo pageInfo = dbInfoService.selectByParams(params, DbInfo.getPage(), DbInfo.getPageSize()); PageUtil.initPageNumber(pageInfo, model); model.addAttribute("pageUrl", "/dbInfo/list?1=1"); model.addAttribute("page", pageInfo); } catch (Exception e) { logger.error("查询数据源信息错误", e); logInfoService.save("查询数据源信息错误", e.toString(), StaticKeys.LOG_ERROR); } return "mysql/dblist"; } /** * 添加 * * @param model * @param request * @return */ @RequestMapping(value = "edit") public String edit(Model model, HttpServletRequest request) { String errorMsg = "添加数据源:"; String id = request.getParameter("id"); DbInfo dbInfo = new DbInfo(); try { if (StringUtils.isEmpty(id)) { model.addAttribute("dbInfo", dbInfo); return "mysql/init"; } dbInfo = dbInfoService.selectById(id); model.addAttribute("dbInfo", dbInfo); } catch (Exception e) { logger.error(errorMsg, e); logInfoService.save(dbInfo.getDbName(), errorMsg + e.toString(), StaticKeys.LOG_ERROR); } return "mysql/init"; } /** * 保存数据源信息 * * @param DbInfo * @param model * @param request * @return */ @RequestMapping(value = "save") public String saveDbInfo(DbInfo DbInfo, Model model, HttpServletRequest request) { try { if (StringUtils.isEmpty(DbInfo.getId())) { dbInfoService.save(DbInfo); } else { dbInfoService.updateById(DbInfo); } } catch (Exception e) { logger.error("保存数据源错误:", e); logInfoService.save("保存数据源错误", e.toString(), StaticKeys.LOG_ERROR); } return "redirect:/dbInfo/list?msg=save"; } /** * 删除数据源 * * @param id * @param model * @param request * @param redirectAttributes * @return */ @RequestMapping(value = "del") public String delete(Model model, HttpServletRequest request, RedirectAttributes redirectAttributes) { String errorMsg = "删除数据源信息错误:"; DbInfo DbInfo = new DbInfo(); try { if (!StringUtils.isEmpty(request.getParameter("id"))) { DbInfo = dbInfoService.selectById(request.getParameter("id")); logInfoService.save("删除数据源:" + DbInfo.getAliasName(), "删除数据源:" + DbInfo.getIp() + ":" + DbInfo.getPort() + ",数据库别名" + DbInfo.getAliasName(), StaticKeys.LOG_ERROR); dbInfoService.deleteById(request.getParameter("id").split(",")); dbTableService.deleteByDbInfoId(DbInfo.getId()); } } catch (Exception e) { logger.error(errorMsg, e); logInfoService.save(errorMsg, e.toString(), StaticKeys.LOG_ERROR); } return "redirect:/dbInfo/list?msg=del"; } }