RasterController.java 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312
  1. package com.fd.controller;
  2. import com.fd.constant.Command;
  3. import com.fd.constant.MsgCode;
  4. import com.fd.constant.TypeCode;
  5. import com.fd.dto.PageDto;
  6. import com.fd.entity.FileEntity;
  7. import com.fd.server.CmdServer;
  8. import com.fd.server.FileServer;
  9. import com.fd.util.R;
  10. import io.swagger.annotations.ApiOperation;
  11. import lombok.extern.log4j.Log4j2;
  12. import org.apache.commons.lang3.StringUtils;
  13. import org.springframework.beans.factory.annotation.Autowired;
  14. import org.springframework.beans.factory.annotation.Value;
  15. import org.springframework.web.bind.annotation.*;
  16. import org.springframework.web.multipart.MultipartFile;
  17. import java.io.File;
  18. import java.util.ArrayList;
  19. import java.util.Date;
  20. /**
  21. * Created by Owen on 2019/11/12 0012 9:40
  22. *
  23. * 栅格数据
  24. */
  25. @Log4j2
  26. @RequestMapping("api/raster")
  27. @RestController
  28. public class RasterController {
  29. @Value("${input.file.path}")
  30. private String INPUT_FILE_PATH;
  31. @Autowired
  32. private FileServer fileServer;
  33. @Autowired
  34. private CmdServer cmdServer;
  35. @ApiOperation("上传栅格数据,只能上传tif文件")
  36. @PostMapping(value = "upload", consumes = { "multipart/form-data" })
  37. private R upload(@RequestParam("file") MultipartFile file){
  38. log.info("run upload");
  39. // 文件名全名
  40. String fileName = file.getOriginalFilename();
  41. String s = StringUtils.substringAfterLast(fileName, ".");
  42. if (!"tif".equals(s)) {
  43. return new R(50008,MsgCode.E50008);
  44. }
  45. return fileServer.uploadBigFile(file, TypeCode.FILE_TYPE_RASTER_TIF);
  46. }
  47. @ApiOperation("获取栅格数据列表")
  48. @PostMapping(value = "list")
  49. private R list(@RequestBody PageDto param){
  50. log.info("run list");
  51. return fileServer.findByType(TypeCode.FILE_TYPE_RASTER_TIF, param);
  52. }
  53. /**
  54. * 删除文件
  55. */
  56. @ApiOperation("删除文件")
  57. @GetMapping("delete/{fileId}/")
  58. private R deleteFile(@PathVariable("fileId") Long fileId) {
  59. log.info("run deleteFile: {}", fileId);
  60. return fileServer.deleteById(fileId);
  61. }
  62. @ApiOperation("栅格数据判断坐标")
  63. @GetMapping("command/judge/coord/{fileId}/")
  64. private R cmdJudgeCoord(@PathVariable("fileId") Long fileId) {
  65. log.info("run cmdJudgeCoord: {}", fileId);
  66. FileEntity entity = fileServer.findById(fileId);
  67. String cmd = Command.RASTER_JUDGE_COORD;
  68. cmd = cmd.replace("@inputFile", entity.getFileUrl());
  69. log.info("cmd: {}", cmd);
  70. Integer isJudge = cmdServer.exeCmdRasterJudgeCoord(cmd);
  71. if (1000 == isJudge){
  72. log.info("need to transform");
  73. // 严格坐标转换
  74. entity = cmdTansformGdalwarpStrict(fileId);
  75. } else if (0 == isJudge){
  76. log.info("not to transform");
  77. } else {
  78. log.info("error exeCmd");
  79. return new R(50005, MsgCode.E50005);
  80. }
  81. return new R(200, entity);
  82. }
  83. // @ApiOperation("栅格数据普通坐标转换")
  84. // @GetMapping("command/transform/gdalwarp/{fileId}/")
  85. // private R cmdTansformGdalwarp(@PathVariable("fileId") Long fileId) {
  86. // log.info("run cmdTansformGdalwarp: {}", fileId);
  87. // FileEntity entity = fileServer.findById(fileId);
  88. //
  89. // String fileName = StringUtils.substringBefore(entity.getFileName(), ".");
  90. //
  91. // String cmd = Command.RASTER_TRANSFORM_GDALWARP;
  92. // cmd = cmd.replace("@fileName",fileName);
  93. // log.info("cmd: {}", cmd);
  94. //
  95. // Integer integer = cmdServer.exeCmdInt(cmd);
  96. // if (integer != 0) {
  97. // log.info("error command transform");
  98. // return new R(50005, MsgCode.E50005);
  99. // }
  100. //
  101. // FileEntity fileEntity = new FileEntity();
  102. // fileEntity.setFileName(entity.getFileName());
  103. // // /root/gis/cesium/input/transform/@fileName.tif
  104. // fileEntity.setFileUrl(INPUT_FILE_PATH + "transform" + File.separator + entity.getFileName());
  105. // fileEntity.setCreateTime(new Date());
  106. // fileEntity.setUpdateTime(new Date());
  107. // fileEntity.setType(TypeCode.FILE_TYPE_RASTER_TIF);
  108. // fileEntity = fileServer.save(fileEntity);
  109. //
  110. // return new R(200, fileEntity) ;
  111. // }
  112. // @ApiOperation("栅格数据严格坐标转换")
  113. // @GetMapping("command/transform/strict/gdalwarp/{fileId}/")
  114. // private R cmdTansformGdalwarpStrict(@PathVariable("fileId") Long fileId) {
  115. // log.info("run cmdTansformGdalwarpStrict: {}", fileId);
  116. // FileEntity entity = fileServer.findById(fileId);
  117. //
  118. // String fileName = StringUtils.substringBefore(entity.getFileName(), ".");
  119. //
  120. // String step_1 = Command.RASTER_TRANSFORM_GDALWARP_STRICT_1;
  121. // String step_2 = Command.RASTER_TRANSFORM_GDALWARP_STRICT_2;
  122. // step_1 = step_1.replace("@fileName",fileName);
  123. // step_2 = step_2.replace("@fileName",fileName);
  124. // log.info("cmd1: {}", step_1);
  125. // log.info("cmd2: {}", step_2);
  126. //
  127. // Integer integer = cmdServer.exeCmd(step_1, step_2);
  128. //
  129. // if (integer != 0) {
  130. // log.info("error command transform");
  131. // return new R(50005, MsgCode.E50005);
  132. // }
  133. //
  134. // FileEntity fileEntity = new FileEntity();
  135. // fileEntity.setFileName(entity.getFileName());
  136. // // /root/gis/cesium/input/transform_strict/@fileName.tif
  137. // fileEntity.setFileUrl(INPUT_FILE_PATH + "transform_strict" + File.separator + entity.getFileName());
  138. // fileEntity.setCreateTime(new Date());
  139. // fileEntity.setUpdateTime(new Date());
  140. // fileEntity.setType(TypeCode.FILE_TYPE_RASTER_TIF);
  141. // fileEntity = fileServer.save(fileEntity);
  142. //
  143. // return new R(200, fileEntity) ;
  144. // }
  145. @ApiOperation("栅格数据切片命令")
  146. @GetMapping("command/osgeo/{fileId}/")
  147. private R cmdOsgeo(@PathVariable("fileId") Long fileId) {
  148. log.info("run cmdOsgeo: {}", fileId);
  149. FileEntity entity = fileServer.findById(fileId);
  150. String fileName = StringUtils.substringBefore(entity.getFileName(), ".");
  151. // fileName_tiles
  152. fileName = fileName + "_tiles";
  153. String cmd = Command.RASTER_SLICE_OSGEO;
  154. cmd = cmd.replace("@filePath", entity.getFileUrl());
  155. cmd = cmd.replace("@fileName",fileName);
  156. log.info("cmd: {}", cmd);
  157. // Integer integer = cmdServer.exeCmdRasterSlice(cmd);
  158. // if (integer != 0) {
  159. // log.info("error command exeCmdRasterSlice");
  160. // return new R(50005, MsgCode.E50005);
  161. // }
  162. FileEntity fileEntity = new FileEntity();
  163. fileEntity.setFileName(fileName);
  164. fileEntity.setFileUrl(INPUT_FILE_PATH + fileName);
  165. fileEntity.setCreateTime(new Date());
  166. fileEntity.setUpdateTime(new Date());
  167. fileEntity.setType(TypeCode.FILE_TYPE_RASTER_TIF);
  168. fileEntity = fileServer.save(fileEntity);
  169. // 多线程运行切片
  170. new Thread(new RasterSliceThread(cmd, fileEntity)).start();
  171. return new R(200, fileEntity) ;
  172. }
  173. public class RasterSliceThread implements Runnable{
  174. private String cmd;
  175. private FileEntity entity;
  176. private RasterSliceThread(String cmd, FileEntity entity){
  177. this.cmd = cmd;
  178. this.entity = entity;
  179. }
  180. @Override
  181. public void run() {
  182. log.warn("run RasterSliceThread");
  183. Integer integer = cmdServer.exeCmdRasterSlice(cmd, entity);
  184. if (integer != 0) {
  185. log.info("error command exeCmdRasterSlice");
  186. // return new R(50005, MsgCode.E50005);
  187. // 如果命令运行失败,删除刚才创建的实体类
  188. fileServer.deleteById(entity.getId());
  189. return;
  190. }
  191. // // 需要告诉前端,当状态为1是,才是可以的
  192. // entity.setStatus(1);
  193. // fileServer.save(entity);
  194. log.warn("end RasterSliceThread");
  195. }
  196. }
  197. // 严格坐标转换
  198. private FileEntity cmdTansformGdalwarpStrict(Long fileId){
  199. log.info("run cmdTansformGdalwarpStrict: {}", fileId);
  200. FileEntity entity = fileServer.findById(fileId);
  201. String fileName = StringUtils.substringBefore(entity.getFileName(), ".");
  202. String step_1 = Command.RASTER_TRANSFORM_GDALWARP_STRICT_1;
  203. String step_2 = Command.RASTER_TRANSFORM_GDALWARP_STRICT_2;
  204. step_1 = step_1.replace("@fileName",fileName);
  205. step_2 = step_2.replace("@fileName",fileName);
  206. log.info("cmd1: {}", step_1);
  207. log.info("cmd2: {}", step_2);
  208. Integer integer = cmdServer.exeCmd(step_1, step_2);
  209. if (integer != 0) {
  210. log.info("error command transform");
  211. return null;
  212. // return new R(50005, MsgCode.E50005);
  213. }
  214. FileEntity fileEntity = new FileEntity();
  215. fileEntity.setFileName(entity.getFileName());
  216. // /root/gis/cesium/input/transform_strict/@fileName.tif
  217. fileEntity.setFileUrl(INPUT_FILE_PATH + "transform_strict" + File.separator + entity.getFileName());
  218. fileEntity.setCreateTime(new Date());
  219. fileEntity.setUpdateTime(new Date());
  220. fileEntity.setType(TypeCode.FILE_TYPE_RASTER_TIF);
  221. fileEntity = fileServer.save(fileEntity);
  222. return fileEntity;
  223. }
  224. // String a = "112222.zip";
  225. // String b = "11/2222/aa";
  226. // String c = "11/2222/aa.zip";
  227. // String e = "/root/gis/cesium/input/test/clip.shp";
  228. // System.out.println(StringUtils.stripStart(a, "."));
  229. // System.out.println("After: " + StringUtils.substringAfter(a, "."));
  230. // System.out.println("before: " + StringUtils.substringBefore(a, "."));
  231. // System.out.println("c: " + StringUtils.substringBefore(c, "/"));
  232. // System.out.println("c: " + StringUtils.substringBeforeLast(c, "/"));
  233. // System.out.println(StringUtils.substringBefore(b, "/"));
  234. // System.out.println(StringUtils.substringBeforeLast(b, "/"));
  235. // System.out.println(StringUtils.substring(b, b.lastIndexOf("/") + 1, b.length()));
  236. // System.out.println("e: " + StringUtils.substringBeforeLast(e, "/"));
  237. // System.out.println("e1: " + StringUtils.substring(e, e.indexOf("input/") + 6, e.lastIndexOf("/")));
  238. // System.out.println("===========================================");
  239. // System.out.println();
  240. //
  241. // System.out.println("a: " + StringUtils.substringAfterLast(a, "."));
  242. public static void main(String[] args) {
  243. String a = "0...10...20...30...40...50...60...70...80...90...100.....10..11";
  244. String b = "...10";
  245. String c = "...10...20";
  246. String d = "...10...100";
  247. String re = "\\.\\.\\.";
  248. String r1 = "...";
  249. // String s = a.replaceAll(re, "@");
  250. String rr = "\\.\\.\\.[0-9]{2,3}";
  251. System.out.println("b: " + b.matches(rr));
  252. System.out.println("c: " + c.matches(rr));
  253. System.out.println("c: " + StringUtils.substring(c, -2));
  254. System.out.println("d: " + StringUtils.substring(d, -2));
  255. System.out.println("a: " + StringUtils.contains(a, "..."));
  256. System.out.println("d: " + StringUtils.substring(d, -6));
  257. System.out.println("c: " + StringUtils.substring(c, -6));
  258. System.out.println("a: " + a.matches(r1));
  259. }
  260. }