src/main/java/com/se/simu/controller/SimuController.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/se/simu/domain/po/SimuPo.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/se/simu/domain/vo/CreateFilesSimuVo.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/se/simu/service/SimuFilesService.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/se/simu/service/SimuService.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/se/simu/utils/EntityLibraryUtils.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/se/simu/utils/ProjectionToGeographicUtil.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/se/simu/utils/TiffToRGBUtil.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/resources/config.json | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 |
src/main/java/com/se/simu/controller/SimuController.java
@@ -27,6 +27,7 @@ import java.net.URL; import java.net.URLEncoder; import java.nio.charset.StandardCharsets; import java.text.SimpleDateFormat; import java.util.*; import java.util.stream.Collectors; @@ -344,7 +345,7 @@ dtos.add(new GridDto(vo.getMaxy(), vo.getMinx())); dtos.add(new GridDto(vo.getMaxy(), vo.getMaxx())); dtos.add(new GridDto(vo.getMiny(), vo.getMaxx())); createSem(tableName, dtos, vo.getSemUrl()); createSem(tableName, dtos, vo); // å¼å§æ¨¡æè®¡ç® boolean flag = simuFilesService.createByfiles(vo); return success(flag, flag ? "æå" : "失败"); @@ -353,41 +354,90 @@ } } public R<Boolean> createSem(String tableName, List<GridDto> dtos, String semUrl) throws Exception { boolean ends = semUrl.endsWith("\\"); if (!ends) { semUrl = semUrl + "\\"; @ApiOperation(value = "è·åç¹è·¯å¾") @GetMapping("/getPointUrl") public R<String> getPointUrl(@RequestParam("id") Integer id) throws Exception{ SimuPo po = simuService.getSimuById(id); String token = EntityLibraryUtils.login(); if (po != null) { return success(po.getPointUrl().replace("{token}",token)); } File file = new File(semUrl); return success(null); } @ApiOperation(value = "è·å线路å¾") @GetMapping("/getLineUrl") public R<String> getLineUrl(@RequestParam("id") Integer id) throws Exception{ SimuPo po = simuService.getSimuById(id); String token = EntityLibraryUtils.login(); if (po != null) { return success(po.getLinkUrl().replace("{token}",token)); } return success(null); } public R<Boolean> createSem(String tableName, List<GridDto> dtos, CreateFilesSimuVo vo) throws Exception { String name = vo.getSemUrl(); vo.setSemUrl(inPath + "\\" + vo.getSemUrl()); boolean ends = vo.getSemUrl().endsWith("\\"); if (!ends) { vo.setSemUrl(vo.getSemUrl() + "\\"); } File file = new File(vo.getSemUrl()); if (!file.exists()) { file.mkdirs(); } //éé¨æä»¶çæ saveZarr(tableName,semUrl); String token = EntityLibraryUtils.login(); //éé¨æä»¶çæ saveZarr(tableName, vo.getSemUrl()); //管ç¹çæ pointTosem(dtos, token,semUrl); pointTosem(dtos, token, vo.getSemUrl()); //ç®¡çº¿çæ lineToSem(dtos, token,semUrl); //å°å½¢çæ terrainToSem(dtos,semUrl); lineToSem(dtos, token, vo.getSemUrl()); //èå´çæ gridToCityJson(dtos,semUrl); gridToCityJson(dtos, vo.getSemUrl()); //æ²³æµçæ riverToSem(semUrl); riverToSem(vo.getSemUrl()); //åå°å©ç¨çæ landuseToSem(semUrl); landuseToSem(vo.getSemUrl()); //å°å½¢çæ terrainToSem(dtos, vo.getSemUrl()); String bbox = ""; //çæç¹å线çå®ä½åºæ¨¡åå¹¶ä¿åè·¯å¾ vo.setPointName(name + "-point"); vo.setLinkName(name + "-line"); JSONArray min = ProjectionToGeographicUtil.get4548Point(dtos.get(0).getLon(), dtos.get(0).getLat()); JSONArray max = ProjectionToGeographicUtil.get4548Point(dtos.get(2).getLon(), dtos.get(2).getLat()); bbox = bbox + min.getDouble(0) + "," + min.getDouble(1) + "," + max.getDouble(0) + "," + max.getDouble(1); JSONObject point = getModule("layerQueryPointParams.json"); String pointUrl = assemble(vo.getPointName(), point.getString("layerid"), bbox, token); vo.setPointName(pointUrl); JSONObject link = getModule("layerQueryParams.json"); String linkUrl = assemble(vo.getLinkName(), link.getString("layerid"), bbox, token); vo.setLinkName(linkUrl); return success(true); } @ApiOperation(value = "tarræä»¶ç»è£ ") @GetMapping(value = "/saveZarr", produces = "application/json; charset=UTF-8") public R<String> saveZarr(@RequestParam("name") String tableName,String semUrl) throws Exception { public String assemble(String name, String layerid, String bbox, String token) throws Exception { JSONObject jsonObject = EntityLibraryUtils.createAssemble(name, token); String packageid = jsonObject.getString("packageid"); EntityLibraryUtils.addAssemble(layerid, token, packageid, bbox); JSONObject result = EntityLibraryUtils.submitAssemble(token, packageid); Random random = new Random(); int randomNumber = random.nextInt(90000) + 10000; String url = "http://106.120.22.26:8024/geo-service/package/3d/normal/85257774fdb64e5f99f6778696cad02a/" + packageid + "/" + layerid + "//l0/tileset.json?r=" + randomNumber + "&token={token}"; return url; } public R<String> saveZarr(String tableName, String semUrl) throws Exception { List<String> list = CsvToSQLiteUtils.getNameList(tableName); String path = outPath + "\\"; String rainfall = "rainfall\\"; String basePath = path + tableName + "\\" + rainfall; JSONObject jsonObject = getModule("rainfallmodule.json"); String startTime = null; String endTime = null; for (String src : list ) { File directories = new File(basePath); @@ -398,6 +448,12 @@ System.out.println("Directories already exist."); } List<StationRainVo> stationRainVos = CsvToSQLiteUtils.getList(tableName, src); if (startTime == null) { startTime = stationRainVos.get(0).getDatetime(); } if (endTime == null) { endTime = stationRainVos.get(stationRainVos.size() - 1).getDatetime(); } ZarrUtils.saveZarrRainfall(basePath + src, stationRainVos); ZarrUtils.saveZarrTime(basePath + src, stationRainVos); ZipUtils.toZarr(basePath + src, basePath + src + ".zip"); @@ -440,7 +496,21 @@ fileWriter.write(jsonObject.toJSONString()); fileWriter.close(); SemUtils.cityJsonToSem(path + tableName + "\\éé¨é.json", semUrl + "raingage.sem"); getConfigJson(startTime, endTime, semUrl); return success(semUrl + "raingage.sem"); } public void getConfigJson(String startTime, String endTime, String semUrl) throws Exception { SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm"); Date start = sdf.parse(startTime); Date end = sdf.parse(endTime); SimpleDateFormat simpleDateFormat = new SimpleDateFormat("MM/dd/yyyy HH:mm:ss"); JSONObject jsonObject = getModule("config.json"); jsonObject.put("start_datetime", simpleDateFormat.format(start)); jsonObject.put("end_datetime", simpleDateFormat.format(end)); FileWriter fileWriter = new FileWriter(semUrl + "\\config.json"); fileWriter.write(jsonObject.toJSONString()); fileWriter.close(); } public R<String> pointTosem(List<GridDto> dtos, String token,String semUrl) throws Exception { @@ -512,9 +582,8 @@ return success(semUrl + "node.sem"); } @ApiOperation(value = "管ç¹è½¬cityjson") @GetMapping(value = "/pointToCityJson", produces = "application/json; charset=UTF-8") public R<String> pointToCityJson(@RequestParam("shpPath") String shpPath) throws Exception { public R<String> pointToCityJson(String shpPath) throws Exception { String path = outPath + "\\point\\"; List<Map<String, Object>> list = ShpReadUtils.readPointShp(shpPath); JSONObject jsonObject = getModule("pointmodule.json"); @@ -656,9 +725,7 @@ return success(semUrl + "link.sem"); } @ApiOperation(value = "管线转cityjson") @GetMapping(value = "/lineToCityJson", produces = "application/json; charset=UTF-8") public R<String> lineToCityJson(@RequestParam("shpPath") String shpPath) throws Exception { public R<String> lineToCityJson(String shpPath) throws Exception { String path = outPath + "\\line\\"; List<Map<String, Object>> list = ShpReadUtils.readPointShp(shpPath); JSONObject jsonObject = getModule("linemodule.json"); @@ -709,9 +776,7 @@ return success(filePatn + "link.sem"); } @ApiOperation(value = "å°å½¢è½¬sem") @PostMapping(value = "/terrainToSem", produces = "application/json; charset=UTF-8") public R<String> terrainToSem(@RequestBody List<GridDto> dtos,String semUrl) throws Exception { public R<String> terrainToSem(List<GridDto> dtos, String semUrl) throws Exception { long times = System.currentTimeMillis(); String path = outPath + "\\terrain\\" + times + "\\"; File dirFile = new File(path + "appearance"); @@ -752,9 +817,7 @@ return success(semUrl + "terrain.sem"); } @ApiOperation(value = "å°å½¢è½¬cityjson") @GetMapping(value = "/terrainToCityJson", produces = "application/json; charset=UTF-8") public R<String> terrainToCityJson(@RequestParam("tifPath") String tifPath) throws Exception { public R<String> terrainToCityJson(String tifPath) throws Exception { long times = System.currentTimeMillis(); String path = outPath + "\\terrain\\" + times + "\\"; File dirFile = new File(path + "appearance"); @@ -777,9 +840,7 @@ return success(filePatn + "terrain.sem"); } @ApiOperation(value = "grid转cityjson") @PostMapping(value = "/gridToCityJson", produces = "application/json; charset=UTF-8") public R<String> gridToCityJson(@RequestBody List<GridDto> dtos,String semUrl) throws Exception { public R<String> gridToCityJson(List<GridDto> dtos, String semUrl) throws Exception { long times = System.currentTimeMillis(); String path = outPath + "\\grid\\" + times + "\\"; File dirFile = new File(path); @@ -804,8 +865,6 @@ return success(semUrl + "grid.sem"); } @ApiOperation(value = "river转sem") @GetMapping(value = "/riverToSem", produces = "application/json; charset=UTF-8") public R<String> riverToSem(String semUrl) throws Exception { long times = System.currentTimeMillis(); String path = outPath + "\\river\\" + times + "\\"; @@ -821,8 +880,6 @@ return success(semUrl + "river.sem"); } @ApiOperation(value = "landuse转sem") @GetMapping(value = "/landuseToSem", produces = "application/json; charset=UTF-8") public R<String> landuseToSem(String semUrl) throws Exception { long times = System.currentTimeMillis(); String path = outPath + "\\landuse\\" + times + "\\"; src/main/java/com/se/simu/domain/po/SimuPo.java
@@ -47,6 +47,12 @@ @ApiModelProperty("semè·¯å¾") private String semUrl; @ApiModelProperty("ç¹æ°æ®è·¯å¾") private String pointUrl; @ApiModelProperty("çº¿æ°æ®è·¯å¾") private String linkUrl; public SimuPo() { } @@ -154,4 +160,20 @@ public void setSemUrl(String semUrl) { this.semUrl = semUrl; } public String getPointUrl() { return pointUrl; } public void setPointUrl(String pointUrl) { this.pointUrl = pointUrl; } public String getLinkUrl() { return linkUrl; } public void setLinkUrl(String linkUrl) { this.linkUrl = linkUrl; } } src/main/java/com/se/simu/domain/vo/CreateFilesSimuVo.java
@@ -88,4 +88,10 @@ @ApiModelProperty("semè·¯å¾") private String semUrl; @ApiModelProperty("ç¹çæè·¯å¾") private String pointName; @ApiModelProperty("线çæè·¯å¾") private String linkName; } src/main/java/com/se/simu/service/SimuFilesService.java
@@ -127,6 +127,8 @@ simu.setServiceName(date); simu.setCreateTime(new Timestamp(now.getTime())); simu.setSemUrl(vo.getSemUrl()); simu.setPointUrl(vo.getPointName()); simu.setLinkUrl(vo.getLinkName()); int rows = simuMapper.insert(simu); if (rows > 0) { asyncCall(simu); src/main/java/com/se/simu/service/SimuService.java
@@ -122,6 +122,9 @@ return simuMapper.selectOne(wrapper); } public SimuPo getSimuById(Integer id) { return simuMapper.selectById(id); } public SimuPo getSimuByServiceName(String serviceName) { if (StringHelper.isEmpty(serviceName)) { src/main/java/com/se/simu/utils/EntityLibraryUtils.java
@@ -8,7 +8,6 @@ import org.springframework.http.*; import org.springframework.http.converter.StringHttpMessageConverter; import org.springframework.web.client.RestTemplate; import org.springframework.web.util.UriUtils; import javax.crypto.Cipher; import java.net.URL; @@ -116,16 +115,94 @@ return outstn; } public static void main(String[] args) throws Exception { String publickey = getPublicKey(); System.out.println("å ¬é¥=" + publickey); String en = encrypt("id in ('46235','49876')", publickey); System.out.println("å å¯å符串=" + en); String encode = UriUtils.encode(en, StandardCharsets.UTF_8); System.out.println("encodeå符串=" + encode); String decode = UriUtils.decode(encode, StandardCharsets.UTF_8); System.out.println("decodeå符串=" + decode); System.out.println("è§£å¯å符串=" + decrypt(decode, "MIICeAIBADANBgkqhkiG9w0BAQEFAASCAmIwggJeAgEAAoGBAJiF6WkdgHlimpakWJMvH3Xnjwws7qqoo1rhbg/iLzLGly/EKLvUzD6D7FUFk+GAP/sOKh1cZZEvi1KkGd6OufqMKdDvRvVtGjXExI5MLJDVDaYTsqhzNF8maB2H7dwR+iiDGph2DMPQtuV/k/dalXMxR6O8Q2MPQfaUiOVebKBbAgMBAAECgYARrPs21ldsOdQmfxdQv1ZLCLHYPGDQYEjGIHfr2U+U99TPkVETK38cA5fg5ouTx5QimSqiSnHu2G6x/hiNZUcCJp/1agvsFEI2FLokShYbitOYa07Da1eIKpZA5F+P5j5/QOVpVsWOxvEDA/dkF+vrV4vU/iV7H3QJqBfsLSxEeQJBAO43SVkzJM6dqnRw7sib7SOvguicnr7UKt0Tadc1PwLMWCCFu+4p3iN9Zj/7K5VHjomW+NIv7UAGynDfHBpv1x0CQQCj6ONm+m4FlaTdg+Pc36BBy4Gd6ucm6WfjDTHMaZi3uzINjTPBut6DmrUt68dyHdGpo6OIjCdX3xU27HtmjiPXAkEAwjdhHdCM2cfCCV1p0TUPimC2ImBPLNZefBAv4r4OuYFQ+HMQXYTVD6pViySEzBijJZppEzTwAZuHwa6lgwhcIQJBAI8PBOssSDq3kV2Fb6unwseqR0b9byKXNQUGzyAKSjCSQe1yAGpmHy/eJ6Qc1cbUH9pf6KuVKAGZw3pcjJfGF6ECQQCx9dJ2qJjm2R78/HH0SkOATpMATgewtHH5tRJfCJv7NLveuYNRFH1An4APWYq9IdVfyn+4gyXz3OClteE7jAkt")); /** * å建ç»è£ * * @param name ç»è£ åç§° * @return åå»ºç»æ */ public static JSONObject createAssemble(String name, String token) { JSONObject jsonObject = new JSONObject(); jsonObject.put("token", token); jsonObject.put("description", null); jsonObject.put("name", name); jsonObject.put("dbid", "85257774fdb64e5f99f6778696cad02a"); RestTemplate restTemplate = new RestTemplate(); // åéJSONæ ¼å¼çPOSTè¯·æ± HttpHeaders headers = new HttpHeaders(); headers.setContentType(MediaType.APPLICATION_JSON); String json = jsonObject.toJSONString(); HttpEntity<String> request = new HttpEntity<>(json, headers); ResponseEntity<String> responseEntity = restTemplate.postForEntity("http://106.120.22.26:8024/geo-service/package/self/add", request, String.class); if (responseEntity.getStatusCode().is2xxSuccessful()) { String body = responseEntity.getBody(); JSONObject result = JSONObject.parseObject(body); if (result.getInteger("code") == 200) { return result.getJSONObject("data"); } } return null; } /** * æäº¤ç»è£ * @param token token * @param packageid ç»è£ id * @return æäº¤ç»æ */ public static JSONObject submitAssemble(String token, String packageid) { JSONObject jsonObject = new JSONObject(); jsonObject.put("dbid", "85257774fdb64e5f99f6778696cad02a"); jsonObject.put("packageid", packageid); jsonObject.put("token", token); RestTemplate restTemplate = new RestTemplate(); // åéJSONæ ¼å¼çPOSTè¯·æ± HttpHeaders headers = new HttpHeaders(); headers.setContentType(MediaType.APPLICATION_JSON); String json = jsonObject.toJSONString(); HttpEntity<String> request = new HttpEntity<>(json, headers); ResponseEntity<String> responseEntity = restTemplate.postForEntity("http://106.120.22.26:8024/geo-service/package/status/complete", request, String.class); if (responseEntity.getStatusCode().is2xxSuccessful()) { String body = responseEntity.getBody(); JSONObject result = JSONObject.parseObject(body); if (result.getInteger("code") == 200) { return result.getJSONObject("data"); } } return null; } /** * å å ¥ç»è£ * * @param layerid å¾å±id * @param token token * @param packageid ç»è£ id * @param bbox èå´ * @return æ¯å¦å å ¥æå */ public static Boolean addAssemble(String layerid, String token, String packageid, String bbox) { JSONObject jsonObject = new JSONObject(); jsonObject.put("dbid", "85257774fdb64e5f99f6778696cad02a"); jsonObject.put("layerid", layerid); jsonObject.put("packageid", packageid); jsonObject.put("token", token); jsonObject.put("bbox", bbox); RestTemplate restTemplate = new RestTemplate(); // åéJSONæ ¼å¼çPOSTè¯·æ± HttpHeaders headers = new HttpHeaders(); headers.setContentType(MediaType.APPLICATION_JSON); String json = jsonObject.toJSONString(); HttpEntity<String> request = new HttpEntity<>(json, headers); ResponseEntity<String> responseEntity = restTemplate.postForEntity("http://106.120.22.26:8024/geo-service/package/data/add", request, String.class); if (responseEntity.getStatusCode().is2xxSuccessful()) { String body = responseEntity.getBody(); JSONObject result = JSONObject.parseObject(body); if (result.getInteger("code") == 200) { return result.getBoolean("data"); } } return null; } /** @@ -157,6 +234,7 @@ } return null; } /** * 管线å表 * src/main/java/com/se/simu/utils/ProjectionToGeographicUtil.java
@@ -51,6 +51,6 @@ } public static void main(String[] args) { System.out.println(get4548Point(116.66,39.8962)); System.out.println(getPoint(469257.26224087493,4416938.9521611305)); } } src/main/java/com/se/simu/utils/TiffToRGBUtil.java
@@ -51,7 +51,6 @@ int g = value / 256; int b = value % 256; Color color = new Color(r, g, b); System.out.printf("Pixel (%d, %d): R=%d, G=%d, B=%d%n", x, y, r, g, b); int newRgb = color.getRGB(); // å°å¤çåçåç´ é¢è²å¼è®¾ç½®å°æ°ç PNG å¾åä¸ pngImage.setRGB(x, y, newRgb); src/main/resources/config.json
¶Ô±ÈÐÂÎļþ @@ -0,0 +1,14 @@ { "semfile_node": "node.sem", "semfile_link": "link.sem", "semfile_grid": "grid.sem", "semfile_river": "river.sem", "semfile_terrain": "terrain.sem", "semfile_raingage": "raingage.sem", "semfile_landuse": "landuse.sem", "start_datetime": "07/31/2023 00:00:00", "end_datetime": "07/31/2023 08:00:00", "report_step": "00:01:00", "mesh_size": 10.0, "pixel_size":3.0 }