package com.fh.controller.fhdb.brdb; import java.io.PrintWriter; import java.text.DateFormat; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Date; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.concurrent.ExecutionException; import javax.annotation.Resource; import org.springframework.beans.propertyeditors.CustomDateEditor; import org.springframework.stereotype.Controller; import org.springframework.web.bind.WebDataBinder; import org.springframework.web.bind.annotation.InitBinder; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; import org.springframework.web.servlet.ModelAndView; import com.fh.controller.base.BaseController; import com.fh.entity.Page; import com.fh.util.AppUtil; import com.fh.util.DbFH; import com.fh.util.FileUtil; import com.fh.util.PageData; import com.fh.util.Jurisdiction; import com.fh.util.Tools; import com.fh.service.fhdb.brdb.BRdbManager; /** * 说明:数据库管理(备份和还原) * 创建时间:2016-03-30 */ @Controller @RequestMapping(value="/brdb") public class BRdbController extends BaseController { String menuUrl = "brdb/list.do"; //菜单地址(权限用)数据还原菜单 String menuUrlb = "brdb/listAllTable.do"; //菜单地址(权限用)数据备份菜单 @Resource(name="brdbService") private BRdbManager brdbService; /**列出所有表 * @throws Exception */ @SuppressWarnings("unchecked") @RequestMapping(value="/listAllTable") public ModelAndView listAllTable() throws Exception{ logBefore(logger, Jurisdiction.getUsername()+"列出所有表"); if(!Jurisdiction.buttonJurisdiction(menuUrlb, "cha")){return null;} //校验权限(无权查看时页面会有提示,如果不注释掉这句代码就无法进入列表页面,所以根据情况是否加入本句代码) ModelAndView mv = this.getModelAndView(); Object[] arrOb = DbFH.getTables(); List tblist = (List)arrOb[1]; mv.setViewName("fhdb/brdb/table_list"); mv.addObject("varList", tblist); //所有表 mv.addObject("dbtype", arrOb[2]); //数据库类型 mv.addObject("databaseName", arrOb[0]); //数据库名 mv.addObject("QX",Jurisdiction.getHC()); //按钮权限 return mv; } /**备份全库 * @param * @throws Exception */ @RequestMapping(value="/backupAll") @ResponseBody public Object backupAll(){ String username = Jurisdiction.getUsername(); logBefore(logger, username+"备份全库"); if(!Jurisdiction.buttonJurisdiction(menuUrlb, "add")){return null;} //校验权限 PageData pd = new PageData(); Map map = new HashMap(); pd = this.getPageData(); List pdList = new ArrayList(); String kackupPath; try { kackupPath = DbFH.getDbFH().backup("").toString(); //调用数据库备份 if(Tools.notEmpty(kackupPath) && !"errer".equals(kackupPath)){ pd.put("FHDB_ID", this.get32UUID()); //主键 pd.put("USERNAME", username); //操作用户 pd.put("BACKUP_TIME", Tools.date2Str(new Date())); //备份时间 pd.put("TABLENAME", "整库"); //表名 pd.put("SQLPATH", kackupPath); //存储位置 pd.put("DBSIZE", FileUtil.getFilesize(kackupPath)); //文件大小 pd.put("TYPE", 1); //1: 备份整库,2:备份某表 pd.put("BZ", username+"备份全库操作"); //备注 pd.put("msg", "ok"); try { brdbService.save(pd); } catch (Exception e) { pd.put("msg", "no"); } }else{ pd.put("msg", "no"); } } catch (InterruptedException e) { pd.put("msg", "no"); e.printStackTrace(); } catch (ExecutionException e) { pd.put("msg", "no"); e.printStackTrace(); } pdList.add(pd); map.put("list", pdList); return AppUtil.returnObject(pd, map); } /**备份单表 * @param * @throws Exception */ @RequestMapping(value="/backupTable") @ResponseBody public Object backupTable(){ String username = Jurisdiction.getUsername(); logBefore(logger, username+"备份单表"); if(!Jurisdiction.buttonJurisdiction(menuUrlb, "add")){return null;} //校验权限 PageData pd = new PageData(); Map map = new HashMap(); pd = this.getPageData(); String TABLENAME = pd.getString("fhtable"); //页面ajax传过来的表名 List pdList = new ArrayList(); String kackupPath; try { kackupPath = DbFH.getDbFH().backup(TABLENAME).toString(); //调用数据库备份 if(Tools.notEmpty(kackupPath) && !"errer".equals(kackupPath)){ pd.put("FHDB_ID", this.get32UUID()); //主键 pd.put("USERNAME", username); //操作用户 pd.put("BACKUP_TIME", Tools.date2Str(new Date())); //备份时间 pd.put("TABLENAME", TABLENAME); //表名 pd.put("SQLPATH", kackupPath); //存储位置 pd.put("DBSIZE", FileUtil.getFilesize(kackupPath)); //文件大小 pd.put("TYPE", 2); //1: 备份整库,2:备份某表 pd.put("BZ", username+"备份单表"); //备注 pd.put("msg", "ok"); try { brdbService.save(pd); } catch (Exception e) { pd.put("msg", "no"); } }else{ pd.put("msg", "no"); } } catch (InterruptedException e) { pd.put("msg", "no"); e.printStackTrace(); } catch (ExecutionException e) { pd.put("msg", "no"); e.printStackTrace(); } pdList.add(pd); map.put("list", pdList); return AppUtil.returnObject(pd, map); } /**数据还原操作 * @param * @throws Exception */ @RequestMapping(value="/dbRecover") @ResponseBody public Object dbRecover(){ String username = Jurisdiction.getUsername(); logBefore(logger, username+"数据还原操作"); if(!Jurisdiction.buttonJurisdiction(menuUrl, "edit")){return null;} //校验权限 PageData pd = new PageData(); Map map = new HashMap(); pd = this.getPageData(); List pdList = new ArrayList(); String TABLENAME = pd.getString("TABLENAME"); //页面ajax传过来的表名或数据库名 String SQLPATH = pd.getString("SQLPATH"); //页面ajax传过来的备份文件完整路径 try { String returnStr = DbFH.getDbFH().recover(TABLENAME, SQLPATH).toString(); if("ok".equals(returnStr)){ pd.put("msg", "ok"); }else{ pd.put("msg", "no"); } } catch (InterruptedException e) { pd.put("msg", "no"); e.printStackTrace(); } catch (ExecutionException e) { pd.put("msg", "no"); e.printStackTrace(); } pdList.add(pd); map.put("list", pdList); return AppUtil.returnObject(pd, map); } /**删除 * @param out * @throws Exception */ @RequestMapping(value="/delete") public void delete(PrintWriter out) throws Exception{ logBefore(logger, Jurisdiction.getUsername()+"删除Fhdb"); if(!Jurisdiction.buttonJurisdiction(menuUrl, "del")){return;} //校验权限 PageData pd = new PageData(); pd = this.getPageData(); brdbService.delete(pd); out.write("success"); out.close(); } /**修改 * @param * @throws Exception */ @RequestMapping(value="/edit") public ModelAndView edit() throws Exception{ logBefore(logger, Jurisdiction.getUsername()+"修改Fhdb"); if(!Jurisdiction.buttonJurisdiction(menuUrl, "edit")){return null;} //校验权限 ModelAndView mv = this.getModelAndView(); PageData pd = new PageData(); pd = this.getPageData(); brdbService.edit(pd); mv.addObject("msg","success"); mv.setViewName("save_result"); return mv; } /**列表 * @param page * @throws Exception */ @RequestMapping(value="/list") public ModelAndView list(Page page) throws Exception{ logBefore(logger, Jurisdiction.getUsername()+"列表Fhdb"); //if(!Jurisdiction.buttonJurisdiction(menuUrl, "cha")){return null;} //校验权限(无权查看时页面会有提示,如果不注释掉这句代码就无法进入列表页面,所以根据情况是否加入本句代码) ModelAndView mv = this.getModelAndView(); PageData pd = new PageData(); pd = this.getPageData(); String keywords = pd.getString("keywords"); //关键词检索条件 if(null != keywords && !"".equals(keywords)){ pd.put("keywords", keywords.trim()); } String lastStart = pd.getString("lastStart"); //开始时间 String lastEnd = pd.getString("lastEnd"); //结束时间 if(Tools.notEmpty(lastStart)){ pd.put("lastLoginStart", lastStart+" 00:00:00"); } if(Tools.notEmpty(lastEnd)){ pd.put("lastLoginEnd", lastEnd+" 00:00:00"); } page.setPd(pd); List varList = brdbService.list(page); //列出Fhdb列表 Map DBmap = DbFH.getDBParameter(); mv.setViewName("fhdb/brdb/brdb_list"); mv.addObject("varList", varList); mv.addObject("pd", pd); mv.addObject("dbtype", DBmap.get("dbtype").toString()); //数据库类型 mv.addObject("remoteDB", DBmap.get("remoteDB").toString()); //是否远程备份数据库 yes or no mv.addObject("QX",Jurisdiction.getHC()); //按钮权限 return mv; } /**去修改页面 * @param * @throws Exception */ @RequestMapping(value="/goEdit") public ModelAndView goEdit()throws Exception{ ModelAndView mv = this.getModelAndView(); PageData pd = new PageData(); pd = this.getPageData(); pd = brdbService.findById(pd); //根据ID读取 mv.setViewName("fhdb/brdb/brdb_edit"); mv.addObject("msg", "edit"); mv.addObject("pd", pd); return mv; } /**批量删除 * @param * @throws Exception */ @RequestMapping(value="/deleteAll") @ResponseBody public Object deleteAll() throws Exception{ logBefore(logger, Jurisdiction.getUsername()+"批量删除备份记录"); if(!Jurisdiction.buttonJurisdiction(menuUrl, "del")){return null;} //校验权限 PageData pd = new PageData(); Map map = new HashMap(); pd = this.getPageData(); List pdList = new ArrayList(); String DATA_IDS = pd.getString("DATA_IDS"); if(null != DATA_IDS && !"".equals(DATA_IDS)){ String ArrayDATA_IDS[] = DATA_IDS.split(","); brdbService.deleteAll(ArrayDATA_IDS); pd.put("msg", "ok"); }else{ pd.put("msg", "no"); } pdList.add(pd); map.put("list", pdList); return AppUtil.returnObject(pd, map); } @InitBinder public void initBinder(WebDataBinder binder){ DateFormat format = new SimpleDateFormat("yyyy-MM-dd"); binder.registerCustomEditor(Date.class, new CustomDateEditor(format,true)); } }