?? demopaction.java
字號:
package demo.classic.action;
import java.io.PrintWriter;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.lang.StringUtils;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import org.ecside.common.QueryResult;
import org.ecside.core.TableConstants;
import org.ecside.resource.MimeUtils;
import org.ecside.util.RequestUtils;
import org.springframework.web.context.support.WebApplicationContextUtils;
import demo.classic.dao.TestDAO;
import demo.classic.dao.UserInfoDAO;
import demo.common.CommonDictionary;
public class DemoPAction extends BaseDispatchAction {
//默認每頁顯示的記錄條數
protected static int DEFAULT_PAGE_SIZE = 20;
// 應用服務器端分頁,適合數據量不大的情況
// 此時排序 過濾全部使用ECSide內置的缺省方式.
public ActionForward doQuery2(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
UserInfoDAO UserInfoDAO=(UserInfoDAO)getBean("UserInfoDAO");
List rslist = UserInfoDAO.getAllUserInfo();
int totalRows=rslist!=null?rslist.size():0;
//RequestUtil.setTotalRows: 總行數寫入request.
//如果ec:table的tableId不是ec或者不是默認的,那么請使用下面這個方法:
//RequestUtil.initLimit(request, "ec:table的tableId" ,totalRows,DEFAULT_PAGE_SIZE);
// DEFAULT_PAGE_SIZE ==0 時, 每頁記錄數會使用 properties文件內的默認設置
// DEFAULT_PAGE_SIZE ==-1 時, 每頁記錄數會等于全部記錄數
RequestUtils.initLimit(request, totalRows,DEFAULT_PAGE_SIZE);
request.setAttribute("recordList", rslist);
request.setAttribute("GENDER_MAP", CommonDictionary.GENDER);
request.setAttribute("USERROLE_MAP", CommonDictionary.USERROLE);
return mapping.findForward("listPage");
}
// 直接導出
// public ActionForward doDirectExport(ActionMapping mapping, ActionForm form,
// HttpServletRequest request, HttpServletResponse response)
// throws Exception {
// UserInfoDAO UserInfoDAO=(UserInfoDAO)getBean("UserInfoDAO");
//
// Map parameterMap=new HashMap();
// Map mappingItems=new HashMap();
// mappingItems.put("GENDER", CommonDictionary.GENDER);
// mappingItems.put("USERROLE", CommonDictionary.USERROLE);
//
// RequestUtils.beforeExport(request, response);
//
// UserInfoDAO.exportUserListText(parameterMap, mappingItems, response.getOutputStream());
//
// RequestUtils.afterExport(request, response);
//
// return null;
//
// }
// 直接導出
public ActionForward doDirectExportXLS(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
String exportFileName="text.xls";
try{
int num=Integer.parseInt(request.getParameter("num"));
String mimeType = MimeUtils.getFileMimeType(exportFileName);
if (StringUtils.isNotBlank(mimeType)) {
response.setContentType(mimeType);
}
response.setHeader("Content-Disposition", "attachment;filename=\"" + exportFileName + "\"");
response.setHeader("Content-Transfer-Encoding","binary");
response.setHeader("Cache-Control", "must-revalidate, post-check=0, pre-check=0");
response.setHeader("Pragma", "public");
response.setDateHeader("Expires", (System.currentTimeMillis() + 1000));
TestDAO testDAO=(TestDAO)getBean("testDAO");
String methodName=request.getParameter("mn");
if ("1".equals(methodName) ){
testDAO.getAllUserInfo1(num,response.getOutputStream() );
}else if("2".equals(methodName) ){
testDAO.getAllUserInfo2(num,response.getOutputStream() );
}else if("3".equals(methodName) ){
testDAO.getAllUserInfo2(num,response.getOutputStream() );
}else{
testDAO.getAllUserInfo(num,response.getOutputStream() );
}
response.getOutputStream().flush();
response.getOutputStream().close();
}catch(Throwable e){
}
return null;
}
// 直接輸出ECSideTable,將QueryResult傳入request,交給ecside處理
public ActionForward doDirectTable(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
UserInfoDAO UserInfoDAO=(UserInfoDAO)getBean("UserInfoDAO");
QueryResult queryResult=UserInfoDAO.getUserInfoQueryResult();
int totalRows = RequestUtils.getTotalRowsFromRequest(request);
if (totalRows < 0) {
// TODO : UserInfoDAO.getAllUserInfoNumber()為能夠取得總行數的方法,請替換為實際的實現。
totalRows = UserInfoDAO.getUserInfoNumber(null);
}
//RequestUtil.setTotalRows: 總行數寫入request.
//如果ec:table的tableId不是ec或者不是默認的,那么請使用下面這個方法:
//RequestUtil.initLimit(request, "ec:table的tableId" ,totalRows,DEFAULT_PAGE_SIZE);
RequestUtils.initLimit(request, totalRows,totalRows);
request.setAttribute("recordList", queryResult);
request.setAttribute("GENDER_MAP", CommonDictionary.GENDER);
request.setAttribute("USERROLE_MAP", CommonDictionary.USERROLE);
return mapping.findForward("listPage");
}
//
// public ActionForward doAjaxUpdate(ActionMapping mapping, ActionForm form,
// HttpServletRequest request, HttpServletResponse response)
// throws Exception {
// Map formMap=request.getParameterMap();
// UserInfoDAO UserInfoDAO=(UserInfoDAO)getBean("UserInfoDAO");
// int opresult=UserInfoDAO.doUpdateUserInfo(formMap);
// response.setContentType("text/html");
// PrintWriter out=response.getWriter();
// out.println(opresult);
// out.println(((String[])formMap.get(TableConstants.RECORDKEY_NAME))[0]);
// out.print(((String[])formMap.get("USERNAME"))[0]);
// out.flush();
// out.close();
// return null;
//
// }
public Object getBean(String beanName){
Object bean=null;
bean=WebApplicationContextUtils.getRequiredWebApplicationContext(getServlet().getServletContext()).getBean(beanName);
return bean;
}
public ActionForward defaultMethod(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
return doQuery2(mapping, form, request, response);
// response.setContentType("text/html;charset=GBK");
// PrintWriter out=response.getWriter();
// out.println("沒有指明欲調用的 DispatchAction 方法");
// return null;
}
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -