Upload.java 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. package com.happy.action;
  2. import com.happy.Until.ResponseUtil;
  3. import jxl.Sheet;
  4. import jxl.Workbook;
  5. import net.sf.json.JSONObject;
  6. import org.apache.commons.fileupload.FileItem;
  7. import org.apache.commons.fileupload.FileUploadException;
  8. import org.apache.commons.fileupload.disk.DiskFileItemFactory;
  9. import org.apache.commons.fileupload.servlet.ServletFileUpload;
  10. import org.apache.struts2.ServletActionContext;
  11. import org.springframework.context.ApplicationContext;
  12. import org.springframework.context.support.ClassPathXmlApplicationContext;
  13. import javax.servlet.ServletException;
  14. import javax.servlet.annotation.WebServlet;
  15. import javax.servlet.http.HttpServlet;
  16. import javax.servlet.http.HttpServletRequest;
  17. import javax.servlet.http.HttpServletResponse;
  18. import javax.sql.DataSource;
  19. import java.io.File;
  20. import java.io.IOException;
  21. import java.io.PrintWriter;
  22. import java.sql.Connection;
  23. import java.sql.PreparedStatement;
  24. import java.sql.ResultSet;
  25. import java.sql.SQLException;
  26. import java.util.ArrayList;
  27. import java.util.List;
  28. @WebServlet("/upload")
  29. public class Upload extends HttpServlet {
  30. private static final long serialVersionUID = 1L;
  31. protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  32. request.setCharacterEncoding("utf-8");
  33. response.setContentType("text/html;charset=utf-8");
  34. /*
  35. InputStream in = request.getInputStream();
  36. BufferedReader br = new BufferedReader(new InputStreamReader(in));
  37. String str = "";
  38. while((str=br.readLine())!=null){
  39. System.out.println(str);
  40. }
  41. */
  42. System.out.println("[-------------------------------------------------------]");
  43. String filepath=request.getServletContext().getRealPath("/download/");
  44. File file = new File(filepath);
  45. if(!file.exists()) {
  46. file.mkdir();
  47. }
  48. DiskFileItemFactory factory = new DiskFileItemFactory();
  49. ServletFileUpload upload = new ServletFileUpload(factory);
  50. try {
  51. List<FileItem> items= upload.parseRequest(request);
  52. String ex = "";
  53. for(FileItem item: items) {
  54. ex = filepath+item.getName();
  55. if(!item.isFormField()) {
  56. item.write(new File(filepath+item.getName()));
  57. }
  58. if(item.isFormField()){
  59. System.out.println(item.getString());
  60. System.out.println(item.getFieldName());
  61. }
  62. }
  63. File files = new File(ex);
  64. Workbook workbook = Workbook.getWorkbook(files);
  65. Sheet sheet = workbook.getSheet(0);
  66. ArrayList<ArrayList> aa = new ArrayList<>();
  67. for (int i=1; i<sheet.getRows(); i++){
  68. ArrayList a = new ArrayList();
  69. for (int j=0; j<sheet.getColumns(); j++){
  70. a.add(sheet.getCell(j, i).getContents());
  71. }
  72. aa.add(a);
  73. }
  74. ApplicationContext ac = new ClassPathXmlApplicationContext(
  75. "applicationContext.xml");
  76. DataSource dataSource = (DataSource) ac.getBean("slaveDataSource");
  77. Connection conn = null;
  78. ResultSet rs = null;
  79. try {
  80. conn = dataSource.getConnection();
  81. PreparedStatement ps = conn.prepareStatement("select * from build_water order by id asc");
  82. rs = ps.executeQuery();
  83. System.out.println("成功获取数据");
  84. ArrayList a1 = new ArrayList();
  85. while (rs.next()){
  86. a1.add(rs.getInt("id"));
  87. }
  88. for (int i=0; i<aa.size(); i++){
  89. if(!a1.contains(Integer.parseInt(String.valueOf(aa.get(i).get(0))))) {
  90. String sql = String.format("insert into build_water(id, school, build, floors, dom, user_id) " +
  91. "values('%s', '%s', '%s', '%s', '%s', '%s')", aa.get(i).get(0), aa.get(i).get(1), aa.get(i).get(2), aa.get(i).get(3), aa.get(i).get(4), aa.get(i).get(5));
  92. PreparedStatement pst = conn.prepareStatement(sql);
  93. pst.execute();
  94. pst.close();
  95. }else{
  96. String sql = String.format("update build_water set school='%s', build='%s', floors='%s', dom='%s', user_id='%s' " +
  97. "where id='%s'", aa.get(i).get(1), aa.get(i).get(2), aa.get(i).get(3), aa.get(i).get(4), aa.get(i).get(5), aa.get(i).get(0));
  98. PreparedStatement pst2 = conn.prepareStatement(sql);
  99. pst2.execute();
  100. pst2.close();
  101. }
  102. }
  103. } catch (SQLException e) {
  104. System.out.println("导入失败!");
  105. response.setContentType("text/html;charset=utf-8");
  106. PrintWriter out = response.getWriter();
  107. out.println("有重复id");
  108. out.flush();
  109. out.close();
  110. } finally {
  111. try {
  112. if (conn != null) {
  113. conn.close();
  114. }
  115. } catch (SQLException e) {
  116. // TODO: handle exception
  117. }
  118. }
  119. } catch (FileUploadException e) {
  120. e.printStackTrace();
  121. } catch (Exception e) {
  122. // TODO Auto-generated catch block
  123. e.printStackTrace();
  124. }
  125. System.out.println("导入成功!");
  126. response.setContentType("text/html;charset=utf-8");
  127. PrintWriter out = response.getWriter();
  128. out.println("导入成功");
  129. out.flush();
  130. out.close();
  131. }
  132. }