java 웹 개발 중 대량의 데이터 내보내기 Excel 시간 초과(504) 문제 해결
import java.io.IOException;
import java.io.OutputStream;
import java.lang.reflect.Field;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.lang3.StringUtils;
import org.joda.time.DateTime;
import com.travelzen.framework.net.http.TZHttpClient;
import com.travelzen.tops.front.ota.member.item.CustomerItem;
public class CSV {
/**
*
*/
private OutputStream stream;
/**
*
*/
private Map<String,String> fields;
/**
* model map
*/
private static Map<String, Field> fieldMap = new HashMap<>();
public CSV(HttpServletResponse response,Map<String,String> fields,String fileName,Class<?> clz) throws IOException{
if(response == null || fields == null || fileName == null || clz == null)
throw new IllegalArgumentException();
getFieldMap(clz,fieldMap);
this.stream = response.getOutputStream();
this.fields = fields;
response.setContentType("application/octet-stream;charset=GBK");
response.setHeader("Content-Disposition", "attachment;fileName="+ fileName);
// , ,
StringBuilder hb = new StringBuilder();
for(Entry<String, String> e : fields.entrySet())
hb.append(e.getValue()+",");
stream.write(hb.substring(0, hb.length() - 1).getBytes("GBK"));
stream.flush();
}
/**
*
*/
public void write(List<Object> data) throws IllegalArgumentException, IllegalAccessException, IOException{
for(Object o : data){
StringBuilder sb = new StringBuilder();
sb.append("
");
for(String field : fields.keySet()){
Field f = fieldMap.get(field);
f.setAccessible(true);
Object value = f.get(o);
if(value == null || StringUtils.isBlank(value.toString())){
sb.append(" ,");
} else if (f.getType() == Date.class) {
sb.append(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(value) + ",");
} else if (f.getType() == DateTime.class) {
sb.append(((DateTime)value).toString("yyyy-MM-dd HH:mm:ss") + ",");
} else {
String tmp = value.toString();
if(tmp.contains(","))
tmp = tmp.replace(",", "\",\"");
sb.append(value.toString() + ",");
}
}
stream.write(sb.substring(0, sb.length() - 1).getBytes("GBK"));
stream.flush();
}
}
public void close() throws IOException{
stream.close();
}
private static <T extends Object> void getFieldMap(Class<T> clz, Map<String, Field> result) {
for (Field field : clz.getDeclaredFields()) {
result.put(field.getName(), field);
}
if (clz.getSuperclass() != null) {
getFieldMap(clz.getSuperclass(), result);
}
}
}
웹 개발에서 흔히 볼 수 있는 Excel 데이터 준비는 데이터베이스에서 데이터를 조회하거나 크로스 시스템에서 인터페이스를 호출하여 데이터를 조회하는 데 많은 시간을 소모하기 때문에 브라우저에 데이터를 제때에 되돌려 주지 않아 504가 시간을 초과하게 된다.이 도구는 ServletOutputStream으로 세그먼트화된 브라우저flush 데이터를 사용합니다.호출 방식: 먼저 new CSV (), 지정한 매개 변수를 전송하고, wirte () 방법을 끊임없이 호출하여 브라우저에 데이터를 쓰고, 마지막으로close 방법을 호출하여 흐름을 닫습니다.
이 도구에서 내보낸 파일 형식은 입니다.csv 파일, 윈도우즈 오피스 도구의 기본 인코딩은 ASCI입니다. wps는 각종 인코딩과 일치합니다. libre Office calc는 인코딩을 지정할 수 있습니다. 따라서 이 설정은 GBK로 인코딩되고 세 가지 Excel 소프트웨어를 호환하며 자신의 수요에 따라 인코딩을 설정할 수 있습니다.
"이 도구는 CSV에서""의 코드만 처리하고 큰따옴표는 처리하지 않습니다.
이 문제에 부딪힌 친구에게 본고가 도움이 되었으면 좋겠습니다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
38. Java의 Leetcode 솔루션텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.