package com.nq.controller.backend; import cn.afterturn.easypoi.excel.ExcelExportUtil; import cn.afterturn.easypoi.excel.entity.ExportParams; import com.github.pagehelper.PageInfo; import com.nq.common.ServerResponse; import com.nq.pojo.UserWithdraw; import com.nq.service.IUserWithdrawService; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.poi.ss.usermodel.Workbook; import org.slf4j.Logger; import org.slf4j.LoggerFactory; 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.RequestParam; import org.springframework.web.bind.annotation.ResponseBody; import java.io.IOException; import java.util.List; @Controller @RequestMapping({"/admin/withdraw/"}) public class AdminWithDrawController { private static final Logger log = LoggerFactory.getLogger(AdminWithDrawController.class); @Autowired IUserWithdrawService iUserWithdrawService; //分页查询资金管理 提现列表信息及模糊查询 @RequestMapping({"list.do"}) @ResponseBody public ServerResponse list(@RequestParam(value = "agentId", required = false) Integer agentId, @RequestParam(value = "userId", required = false) Integer userId, @RequestParam(value = "realName", required = false) String realName, @RequestParam(value = "state", required = false) Integer state, @RequestParam(value = "beginTime", required = false) String beginTime, @RequestParam(value = "endTime", required = false) String endTime, @RequestParam(value = "pageNum", defaultValue = "1") int pageNum, @RequestParam(value = "pageSize", defaultValue = "10") int pageSize, HttpServletRequest request) { return this.iUserWithdrawService.listByAdmin(agentId, userId, realName, state, beginTime, endTime, request, pageNum, pageSize); } //导出提现记录 @RequestMapping({"export.do"}) @ResponseBody public void export( @RequestParam(value = "agentId", required = false) Integer agentId, @RequestParam(value = "userId", required = false) Integer userId, @RequestParam(value = "realName", required = false) String realName, @RequestParam(value = "state", required = false) Integer state, @RequestParam(value = "beginTime", required = false) String beginTime, @RequestParam(value = "endTime", required = false) String endTime, HttpServletRequest request, HttpServletResponse response) { List userRechargeList = this.iUserWithdrawService.exportByAdmin(agentId, userId, realName, state, beginTime, endTime, request); Workbook workbook = ExcelExportUtil.exportExcel(new ExportParams("提现导出","提现数据"), UserWithdraw.class, userRechargeList); try { ServletOutputStream outputStream = response.getOutputStream(); workbook.write(outputStream); outputStream.flush(); outputStream.close(); } catch (IOException e) { log.error("导出提现数据失败",e); } } //修改资金管理 提现列表 提现状态 @RequestMapping({"updateState.do"}) @ResponseBody public ServerResponse updateState(@RequestParam(value = "withId", required = false) Integer withId, @RequestParam(value = "state", required = false) Integer state, @RequestParam(value = "authMsg", required = false) String authMsg) { ServerResponse serverResponse = null; try { serverResponse = this.iUserWithdrawService.updateState(withId, state, authMsg); } catch (Exception e) { log.error("admin修改充值订单状态出错 ,异常 = {}", e); } return serverResponse; } //删除资金记录 @RequestMapping({"deleteWithdraw.do"}) @ResponseBody public ServerResponse deleteWithdraw(Integer withdrawId) { return this.iUserWithdrawService.deleteWithdraw(withdrawId); } }