Package org.jeecgframework.web.demo.controller.test

Source Code of org.jeecgframework.web.demo.controller.test.JpPersonController

package org.jeecgframework.web.demo.controller.test;
import java.io.IOException;
import java.io.OutputStream;
import java.io.UnsupportedEncodingException;
import java.util.List;
import java.util.Map;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import org.jeecgframework.web.demo.entity.test.JpPersonEntity;
import org.jeecgframework.web.demo.service.test.JpPersonServiceI;
import org.jeecgframework.web.system.service.SystemService;

import org.apache.log4j.Logger;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.jeecgframework.core.common.controller.BaseController;
import org.jeecgframework.core.common.hibernate.qbc.CriteriaQuery;
import org.jeecgframework.core.common.model.json.AjaxJson;
import org.jeecgframework.core.common.model.json.DataGrid;
import org.jeecgframework.core.constant.Globals;
import org.jeecgframework.core.util.BrowserUtils;
import org.jeecgframework.core.util.ExceptionUtil;
import org.jeecgframework.core.util.StringUtil;
import org.jeecgframework.core.util.UUIDGenerator;
import org.jeecgframework.poi.excel.ExcelExportUtil;
import org.jeecgframework.poi.excel.ExcelUtil;
import org.jeecgframework.poi.excel.entity.ExcelTitle;
import org.jeecgframework.tag.core.easyui.TagUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.multipart.MultipartHttpServletRequest;
import org.springframework.web.servlet.ModelAndView;

/**  
* @Title: Controller
* @Description: Excel导出
* @author 张代浩
* @date 2013-03-23 21:45:28
* @version V1.0  
*
*/
@Controller
@RequestMapping("/jpPersonController")
public class JpPersonController extends BaseController {
  /**
   * Logger for this class
   */
  private static final Logger logger = Logger.getLogger(JpPersonController.class);

  @Autowired
  private JpPersonServiceI jpPersonService;
  @Autowired
  private SystemService systemService;
  private String message;
 
  public String getMessage() {
    return message;
  }

  public void setMessage(String message) {
    this.message = message;
  }


  /**
   * Excel导出列表 页面跳转
   *
   * @return
   */
  @RequestMapping(params = "jpPerson")
  public ModelAndView jpPerson(HttpServletRequest request) {
    return new ModelAndView("jeecg/demo/test/jpPersonList");
  }
 
  /**
   * 导出excel
   * @param request
   * @param response
   */
  @RequestMapping(params = "exportXls")
  public void exportXls(HttpServletRequest request, HttpServletResponse response) {
     HttpSession session = request.getSession();
          // 生成提示信息,
          response.setContentType("application/vnd.ms-excel");
          String codedFileName = null;
          OutputStream fOut = null;
          try
          {
            codedFileName =  "用户信息" ;
            // 根据浏览器进行转码,使其支持中文文件名
        String browse = BrowserUtils.checkBrowse(request);
        if ("MSIE".equalsIgnoreCase(browse.substring(0, 4))) {
          response.setHeader(
              "content-disposition",
              "attachment;filename="
                  + java.net.URLEncoder.encode(codedFileName, "UTF-8")
                  + ".xls");
        } else {
          String newtitle = new String(codedFileName.getBytes("UTF-8"), "ISO8859-1");
          response.setHeader("content-disposition",
              "attachment;filename=" + newtitle + ".xls");
        }
              // 进行转码,使其支持中文文件名
              // 产生工作簿对象
              HSSFWorkbook workbook = null ;
              List<JpPersonEntity> jpPersons = this.jpPersonService.loadAll(JpPersonEntity.class);
              workbook =  ExcelExportUtil.exportExcel(new ExcelTitle(null,null,"导出信息"), JpPersonEntity.class, jpPersons);
              fOut = response.getOutputStream();
              workbook.write(fOut);
          }
          catch (UnsupportedEncodingException e1)
          {
             
          }
          catch (Exception e)
          {
             
          }
          finally
          {
              try
              {
                  fOut.flush();
                  fOut.close();
              }
              catch (IOException e)
              {
                 
              }
          }
      }
  @RequestMapping(params = "goImplXls")
    public ModelAndView goImplXls(HttpServletRequest request) {
      return  new ModelAndView("jeecg/demo/test/upload");
    }
  // 老的EasyUI上传方式(2013/05/28废弃)
  @RequestMapping(params = "implXls")
  @ResponseBody
    public AjaxJson implXls(HttpServletRequest request, HttpServletResponse response) {
        AjaxJson j = new AjaxJson();
        MultipartHttpServletRequest mulRequest = (MultipartHttpServletRequest) request;
        MultipartFile file = mulRequest.getFile("filedata");
        List<JpPersonEntity> listPersons;
    try {
      boolean isSuccess = true;
      listPersons = (List<JpPersonEntity>) ExcelUtil.importExcelByIs(file.getInputStream(), JpPersonEntity.class);
      for (JpPersonEntity person : listPersons) {
        person.setId(UUIDGenerator.generate());
        if (person.getAge() == null || person.getCreatedt() == null || person.getSalary() == null) {
          isSuccess = false;
          break;
        } else {
          jpPersonService.save(person);
        }
      }
      if (isSuccess)
        j.setMsg("文件导入成功!");
      else
        j.setMsg("文件格式不正确,导入失败!");
    } catch (IOException e) {
            j.setMsg("文件导入失败!");           
            logger.error(ExceptionUtil.getExceptionMessage(e));    
    } catch (Exception e) {
      j.setMsg("文件格式不正确,导入失败!");
    }
        return j;
    }
 
  // 统一的Excel上传导入方式
  @RequestMapping(params = "importExcel", method = RequestMethod.POST)
  @ResponseBody
  public AjaxJson importExcel(HttpServletRequest request, HttpServletResponse response) {
    AjaxJson j = new AjaxJson();
   
    MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
    Map<String, MultipartFile> fileMap = multipartRequest.getFileMap();
    for (Map.Entry<String, MultipartFile> entity : fileMap.entrySet()) {
      MultipartFile file = entity.getValue();// 获取上传文件对象
      List<JpPersonEntity> listPersons;
      try {
        listPersons = (List<JpPersonEntity>) ExcelUtil.importExcelByIs(file.getInputStream(), JpPersonEntity.class);
        for (JpPersonEntity person : listPersons) {
          if(person.getAge()!=null){
            person.setId(UUIDGenerator.generate());
            jpPersonService.save(person);
          }
        }
        j.setMsg("文件导入成功!");
      } catch (IOException e) {
        j.setMsg("文件导入失败!");
        logger.error(ExceptionUtil.getExceptionMessage(e));
      }
      //break; // 不支持多个文件导入?
    }

    return j;
  }
    @RequestMapping("check")
    public void check(HttpServletRequest request, HttpServletResponse response)
    {
        try
        {
            if ("open".equals(request.getSession().getAttribute("state")))
            {
                request.getSession().setAttribute("state", null);
                response.getWriter().write("true");
                response.getWriter().flush();
            }
            else
            {
                response.getWriter().write("false");
                response.getWriter().flush();
            }
        }
        catch (IOException e)
        {}
  }

  /**
   * easyui AJAX请求数据
   *
   * @param request
   * @param response
   * @param dataGrid
   * @param user
   */

  @RequestMapping(params = "datagrid")
  public void datagrid(HttpServletRequest request, HttpServletResponse response, DataGrid dataGrid) {
    CriteriaQuery cq = new CriteriaQuery(JpPersonEntity.class, dataGrid);
    this.jpPersonService.getDataGridReturn(cq, true);
    TagUtil.datagrid(response, dataGrid);
  }

  /**
   * 删除Excel导出
   *
   * @return
   */
  @RequestMapping(params = "del")
  @ResponseBody
  public AjaxJson del(JpPersonEntity jpPerson, HttpServletRequest request) {
    AjaxJson j = new AjaxJson();
    jpPerson = systemService.getEntity(JpPersonEntity.class, jpPerson.getId());
    message = "删除成功";
    jpPersonService.delete(jpPerson);
    systemService.addLog(message, Globals.Log_Type_DEL, Globals.Log_Leavel_INFO);
   
    j.setMsg(message);
    return j;
  }


  /**
   * 添加Excel导出
   *
   * @param ids
   * @return
   */
  @RequestMapping(params = "save")
  @ResponseBody
  public AjaxJson save(JpPersonEntity jpPerson, HttpServletRequest request) {
    AjaxJson j = new AjaxJson();
    if (StringUtil.isNotEmpty(jpPerson.getId())) {
      message = "更新成功";
      jpPersonService.saveOrUpdate(jpPerson);
      systemService.addLog(message, Globals.Log_Type_UPDATE, Globals.Log_Leavel_INFO);
    } else {
      message = "添加成功";
      jpPersonService.save(jpPerson);
      systemService.addLog(message, Globals.Log_Type_INSERT, Globals.Log_Leavel_INFO);
    }
   
    return j;
  }

  /**
   * Excel导出列表页面跳转
   *
   * @return
   */
  @RequestMapping(params = "addorupdate")
  public ModelAndView addorupdate(JpPersonEntity jpPerson, HttpServletRequest req) {
    if (StringUtil.isNotEmpty(jpPerson.getId())) {
      jpPerson = jpPersonService.getEntity(JpPersonEntity.class, jpPerson.getId());
      req.setAttribute("jpPersonPage", jpPerson);
    }
    return new ModelAndView("jeecg/demo/test/jpPerson");
  }
}
TOP

Related Classes of org.jeecgframework.web.demo.controller.test.JpPersonController

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.