From 8ec2d2febf56274b7cecb291a4657780e311f8fa Mon Sep 17 00:00:00 2001
From: Administrator <admin>
Date: Tue, 05 Jul 2022 17:14:31 +0800
Subject: [PATCH] 地块新增修改,新增图片上传保存
---
src/main/java/org/springblade/modules/lang/mapper/LandMapper.java | 6 +++
src/main/java/org/springblade/modules/lang/service/impl/LandServiceImpl.java | 5 ++
src/main/java/org/springblade/modules/resource/endpoint/OssEndpoint.java | 57 ++++++++++++++++++++++++++++
src/main/java/org/springblade/modules/lang/controller/LandController.java | 26 +++++++++++++
src/main/java/org/springblade/modules/lang/mapper/LandMapper.xml | 7 ++-
src/main/java/org/springblade/modules/lang/service/ILandService.java | 7 +++
6 files changed, 105 insertions(+), 3 deletions(-)
diff --git a/src/main/java/org/springblade/modules/lang/controller/LandController.java b/src/main/java/org/springblade/modules/lang/controller/LandController.java
index 05e6cc9..a18f71f 100644
--- a/src/main/java/org/springblade/modules/lang/controller/LandController.java
+++ b/src/main/java/org/springblade/modules/lang/controller/LandController.java
@@ -32,6 +32,7 @@
import org.springblade.core.tool.utils.Func;
import org.springblade.modules.farm.entity.Farm;
import org.springblade.modules.farm.vo.FarmVO;
+import org.springblade.modules.resource.endpoint.OssEndpoint;
import org.springblade.modules.system.entity.DictBiz;
import org.springblade.modules.system.service.IDictBizService;
import org.springframework.web.bind.annotation.*;
@@ -63,6 +64,7 @@
private final ILandService landService;
private final IDictBizService dictService;
+ private final OssEndpoint ossEndpoint;
/**
* 详情
@@ -145,6 +147,18 @@
} else {
v1 = (double) Math.round(area * 100) / 100;
}
+
+ //图片转换上传
+ if (null!=land.getUrl() && !land.getUrl().equals("")){
+ try {
+ //上传
+ String url = ossEndpoint.uploadBase64String(land.getUrl());
+ //回填url
+ land.setUrl(url);
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+ }
land.setLandArea(String.valueOf(v1));
land.setType(1);
return R.status(landService.saveLandInfo(land));
@@ -189,6 +203,18 @@
} else {
v1 = (double) Math.round(area * 100) / 100;
}
+
+ //图片转换上传
+ if (null!=land.getUrl() && !land.getUrl().equals("")){
+ try {
+ //上传
+ String url = ossEndpoint.uploadBase64String(land.getUrl());
+ //回填url
+ land.setUrl(url);
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+ }
land.setLandArea(String.valueOf(v1));
land.setType(1);
return R.status(landService.updateLandById(land));
diff --git a/src/main/java/org/springblade/modules/lang/mapper/LandMapper.java b/src/main/java/org/springblade/modules/lang/mapper/LandMapper.java
index 6d1818c..c16f311 100644
--- a/src/main/java/org/springblade/modules/lang/mapper/LandMapper.java
+++ b/src/main/java/org/springblade/modules/lang/mapper/LandMapper.java
@@ -42,6 +42,12 @@
* @return
*/
List<LandVO> selectLandPage(IPage page, LandVO land);
+
+ /**
+ * 地块信息新增
+ * @param land
+ * @return
+ */
boolean saveLandInfo(@Param("land") Land land);
/**
* 详情信息(自定义查询)
diff --git a/src/main/java/org/springblade/modules/lang/mapper/LandMapper.xml b/src/main/java/org/springblade/modules/lang/mapper/LandMapper.xml
index b87642e..85dee85 100644
--- a/src/main/java/org/springblade/modules/lang/mapper/LandMapper.xml
+++ b/src/main/java/org/springblade/modules/lang/mapper/LandMapper.xml
@@ -58,13 +58,13 @@
<insert id="saveLandInfo">
insert into sys_land
- (user_id,land_name,land_type,land_area,land_range,type,land_unit,dept_id)
+ (user_id,land_name,land_type,land_area,land_range,type,land_unit,dept_id,url)
values
(#{land.userId},#{land.landName},#{land.landType},#{land.landArea},
<if test="land.landRange!=null and land.landRange!=''">
ST_GeomFromText(${land.landRange}),
</if>
- #{land.type},#{land.landUnit},#{land.deptId})
+ #{land.type},#{land.landUnit},#{land.deptId},#{land.url})
</insert>
<!--详情信息(自定义查询)-->
@@ -83,7 +83,7 @@
and id = #{land.id}
</select>
- <!--自定义修改电子围栏数据-->
+ <!--自定义地块数据-->
<update id="updateLandById">
update sys_land set user_id = #{land.userId},
land_name = #{land.landName},
@@ -94,6 +94,7 @@
</if>
type = #{land.type},
land_unit = #{land.landUnit},
+ url = #{land.url},
where id = #{land.id}
</update>
diff --git a/src/main/java/org/springblade/modules/lang/service/ILandService.java b/src/main/java/org/springblade/modules/lang/service/ILandService.java
index d87ad52..5e2ab7e 100644
--- a/src/main/java/org/springblade/modules/lang/service/ILandService.java
+++ b/src/main/java/org/springblade/modules/lang/service/ILandService.java
@@ -42,7 +42,14 @@
* @return
*/
IPage<LandVO> selectLandPage(IPage<LandVO> page, LandVO land);
+
+ /**
+ * 地块信息新增
+ * @param land
+ * @return
+ */
boolean saveLandInfo(Land land);
+
/**
* 详情信息(自定义查询)
* @return
diff --git a/src/main/java/org/springblade/modules/lang/service/impl/LandServiceImpl.java b/src/main/java/org/springblade/modules/lang/service/impl/LandServiceImpl.java
index adf3e99..569a74d 100644
--- a/src/main/java/org/springblade/modules/lang/service/impl/LandServiceImpl.java
+++ b/src/main/java/org/springblade/modules/lang/service/impl/LandServiceImpl.java
@@ -41,6 +41,11 @@
return page.setRecords(baseMapper.selectLandPage(page, land));
}
+ /**
+ * 地块信息新增
+ * @param land
+ * @return
+ */
@Override
public boolean saveLandInfo(Land land) {
return baseMapper.saveLandInfo(land);
diff --git a/src/main/java/org/springblade/modules/resource/endpoint/OssEndpoint.java b/src/main/java/org/springblade/modules/resource/endpoint/OssEndpoint.java
index ebc25ca..ab0cbb4 100644
--- a/src/main/java/org/springblade/modules/resource/endpoint/OssEndpoint.java
+++ b/src/main/java/org/springblade/modules/resource/endpoint/OssEndpoint.java
@@ -33,9 +33,12 @@
import org.springblade.modules.resource.builder.oss.OssBuilder;
import org.springblade.modules.resource.entity.Attach;
import org.springblade.modules.resource.service.IAttachService;
+import org.springblade.modules.system.entity.User;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
+import sun.misc.BASE64Decoder;
+import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.security.InvalidKeyException;
@@ -159,6 +162,60 @@
return R.data(bladeFile);
}
+ /**
+ * base64 图片上传
+ * @param base64 字符串
+ * @return
+ * @throws Exception
+ */
+ public String uploadBase64String(String base64) throws Exception {
+ String[] split = base64.split(",");
+ //图片上传
+ BASE64Decoder decoder = new BASE64Decoder();
+ // 解密
+ byte[] b = decoder.decodeBuffer(split[1]);
+ // 处理数据
+// for (int i = 0; i < b.length; ++i) {
+// if (b[i] < 0) {
+// b[i] += 256;
+// }
+// }
+ //填写你文件上传的地址以及相应信息
+ String url = "http://61.131.136.25:2081";
+ String access = "zhbaadmin";
+ String secret = "zhbapassword";
+ String bucket = "zhba";
+ MinioClient minioClient =
+ MinioClient.builder()
+ .endpoint(url)
+ .credentials(access, secret)
+ .build();
+ // 检查存储桶是否已经存在
+ boolean isExist = minioClient.bucketExists(BucketExistsArgs.builder().bucket(bucket).build());
+ if (!isExist) {
+ // 创建一个名为zip的存储桶,用于zip文件。
+ minioClient.makeBucket(MakeBucketArgs.builder().bucket(bucket).build());
+ minioClient.setBucketPolicy(SetBucketPolicyArgs.builder().bucket(bucket).build());
+ }
+ String newName = "upload/picture/" + UUID.randomUUID().toString().replaceAll("-", "") + ".jpg";
+ InputStream in = new ByteArrayInputStream(b);
+ //创建头部信息
+ Map<String, String> headers = new HashMap<>(1 << 2);
+ //添加自定义内容类型
+ headers.put("Content-Type", "application/octet-stream");
+ //上传
+ minioClient.putObject(
+ PutObjectArgs.builder().bucket(bucket).object(newName).stream(
+ in, in.available(), -1)
+ .headers(headers)
+ .build());
+ in.close();
+ //url
+ String urls = "http://61.131.136.25:2081/zhba/" + newName;
+ //返回
+ return urls;
+ }
+
/**
* 文件上传,自定义上传
--
Gitblit v1.9.3