小区管理

master
周宇恒 2024-01-30 19:59:28 +08:00
parent 4bf2faaa34
commit 72fa4fcff4
10 changed files with 466 additions and 0 deletions

View File

@ -0,0 +1,14 @@
package com.zyh.common.domain;
import lombok.Data;
@Data
public class Area {
private Integer id;
private String name;
private Integer areaId;
private Integer parentId;
}

View File

@ -0,0 +1,17 @@
package com.zyh.common.domain;
import lombok.Data;
@Data
public class House {
private Integer id;
private String name;
private Integer jurisdiction;
private Double lng;
private Double lat;
private String pic;
private String plotId;
private String areaname;
}

View File

@ -61,7 +61,18 @@
<scope>test</scope>
</dependency>
<dependency>
<groupId>com.github.tobato</groupId>
<artifactId>fastdfs-client</artifactId>
<version>1.26.5</version>
</dependency>
<!-- 阿里云oss -->
<dependency>
<groupId>com.aliyun.oss</groupId>
<artifactId>aliyun-sdk-oss</artifactId>
<version>3.10.2</version>
</dependency>
</dependencies>

View File

@ -0,0 +1,49 @@
package com.zyh.system.controller;
import com.zyh.common.domain.Area;
import com.zyh.common.domain.House;
import com.zyh.common.result.Result;
import com.zyh.system.service.HouseService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
import java.util.List;
@RestController
public class HouseController {
@Autowired
private HouseService houseService;
//新增小区
@PostMapping("addHouse")
public Result addHouse(@RequestBody House house) {
return houseService.addHouse(house);
}
//查询小区
@PostMapping("getHouse")
public Result<List<House>> getHouse() {
return houseService.getHouse();
}
//查询行政区树
@PostMapping("getJurisdictionTree")
public Result<List<Area>> getJurisdictionTree(@RequestParam Integer parentId) {
return houseService.getJurisdictionTree(parentId);
}
//上传图片
@PostMapping("sendPic")
public Result sendPic(@RequestParam("file") MultipartFile multipartFile) {
Result result = houseService.sendPic(multipartFile);
return result;
}
}

View File

@ -0,0 +1,18 @@
package com.zyh.system.mapper;
import com.zyh.common.domain.Area;
import com.zyh.common.domain.House;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import java.util.List;
@Mapper
public interface HouseMapper {
Integer addHouse(House house);
List<Area> getJurisdictionTree(@Param("parentId") Integer parentId);
List<House> getHouse();
}

View File

@ -0,0 +1,18 @@
package com.zyh.system.service;
import com.zyh.common.domain.Area;
import com.zyh.common.domain.House;
import com.zyh.common.result.Result;
import org.springframework.web.multipart.MultipartFile;
import java.util.List;
public interface HouseService {
Result addHouse(House house);
Result<List<Area>> getJurisdictionTree(Integer parentId);
Result<List<House>> getHouse();
Result sendPic(MultipartFile pic) ;
}

View File

@ -0,0 +1,76 @@
package com.zyh.system.service.impl;
import com.zyh.common.domain.Area;
import com.zyh.common.domain.House;
import com.zyh.common.result.Result;
import com.zyh.common.utils.StringUtils;
import com.zyh.system.mapper.HouseMapper;
import com.zyh.system.service.HouseService;
import com.zyh.system.util.FastUtil;
import com.zyh.system.util.OssUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.web.multipart.MultipartFile;
import java.util.List;
@Service
public class HouseServicempl implements HouseService {
@Autowired
FastUtil fastUtil;
@Autowired
private HouseMapper houseMapper;
@Override
public Result addHouse(House house) {
//校验参数
checkHouse(house);
Integer add = houseMapper.addHouse(house);
if (add > 0) {
return Result.success("添加成功");
} else {
return Result.error("添加失败");
}
}
private void checkHouse(House house) {
if (StringUtils.isEmpty(house.getName())) {
throw new RuntimeException("名称不能为空");
}
if (StringUtils.isEmpty(house.getPlotId())) {
throw new RuntimeException("所属小区编号不能为空");
}
if (house.getJurisdiction() == null) {
throw new RuntimeException("所属辖区不能为空");
}
}
@Override
public Result<List<Area>> getJurisdictionTree(Integer parentId) {
List<Area> list=houseMapper.getJurisdictionTree(parentId);
return Result.success(list);
}
@Override
public Result<List<House>> getHouse() {
List<House> list=houseMapper.getHouse();
return Result.success(list);
}
@Override
public Result sendPic(MultipartFile pic) {
String sendPic = "";
sendPic= OssUtil.uploadMultipartFile(pic);
return Result.success(sendPic);
}
}

View File

@ -0,0 +1,55 @@
package com.zyh.system.util;
import com.github.tobato.fastdfs.domain.fdfs.StorePath;
import com.github.tobato.fastdfs.service.FastFileStorageClient;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;
import org.springframework.web.multipart.MultipartFile;
import javax.annotation.Resource;
/**
* @BelongsProject: 0107day02
* @BelongsPackage: com.bw.config
* @Author: zhupengfei
* @CreateTime: 2023-02-01 08:52
*/
@Component
public class FastUtil {
private static final Logger log = LoggerFactory.getLogger(FastUtil.class);
@Resource
private FastFileStorageClient storageClient ;
/**
*
*/
public String upload(MultipartFile multipartFile) throws Exception{
String originalFilename = multipartFile.getOriginalFilename().
substring(multipartFile.getOriginalFilename().
lastIndexOf(".") + 1);
StorePath storePath = this.storageClient.uploadImageAndCrtThumbImage(
multipartFile.getInputStream(),
multipartFile.getSize(),originalFilename , null);
return storePath.getFullPath() ;
}
/**
*
*/
public String deleteFile(String fileUrl) {
if (StringUtils.isEmpty(fileUrl)) {
log.info("fileUrl == >>文件路径为空...");
return "文件路径不能为空";
}
try {
StorePath storePath = StorePath.parseFromUrl(fileUrl);
storageClient.deleteFile(storePath.getGroup(), storePath.getPath());
} catch (Exception e) {
log.error(e.getMessage());
}
return "删除成功";
}
}

View File

@ -0,0 +1,188 @@
package com.zyh.system.util;
import com.aliyun.oss.OSS;
import com.aliyun.oss.OSSClientBuilder;
import com.aliyun.oss.model.GetObjectRequest;
import com.aliyun.oss.model.ObjectMetadata;
import com.aliyun.oss.model.PutObjectRequest;
import lombok.extern.log4j.Log4j2;
import org.springframework.web.multipart.MultipartFile;
import java.io.*;
import java.time.LocalDateTime;
import java.util.UUID;
/**
* Oss
*/
@Log4j2
public class OssUtil {
/**
* Endpoint AccessKeyaccessKeySecretAPI访 访
*/
private static String endPoint = "oss-cn-shanghai.aliyuncs.com";
private static String accessKeyId = "LTAI5tN8mAfrDAwgKQwyAapY";
private static String accessKeySecret = "AliAqC58cSClsFp5esdKfk48K1bXeD";
private static String accessPre = "https://sirzpengbucket.oss-cn-shanghai.aliyuncs.com/";
/**
* bucket
* @return
*/
private static String bucketName = "sirzpengbucket";
private static OSS ossClient ;
static {
ossClient = new OSSClientBuilder().build(
endPoint,
accessKeyId,
accessKeySecret);
log.info("oss服务连接成功");
}
/**
* OSS
* @param filePath
* @return OSS 访 null
**/
public static String uploadFileFilePath(String filePath) {
// 创建OSSClient实例
OSS ossClient = new OSSClientBuilder().build(endPoint, accessKeyId, accessKeySecret);
try {
// 生成唯一的文件名,可以根据需要进行调整
String key = System.currentTimeMillis() + "_" + new File(filePath).getName();
// 设置上传文件的元信息
ObjectMetadata metadata = new ObjectMetadata();
// 可以根据需要设置其他元信息例如Content-Type
// 执行文件上传
ossClient.putObject(bucketName, key, new File(filePath), metadata);
// 返回访问路径
return accessPre+key;
} catch (Exception e) {
e.printStackTrace();
} finally {
// 关闭OSSClient
ossClient.shutdown();
}
return "上传失败";
}
/**
*
* @param filePath
*/
public static String uploadFile(String filePath){
return uploadFileForBucket(bucketName,getOssFilePath(filePath) ,filePath);
}
/**
* multipartFile
* @param multipartFile
*/
public static String uploadMultipartFile(MultipartFile multipartFile) {
return uploadMultipartFile(bucketName,getOssFilePath(multipartFile.getOriginalFilename()),multipartFile);
}
/**
* multipartFile
* @param bucketName
* @param ossPath
* @param multipartFile
*/
public static String uploadMultipartFile(String bucketName , String ossPath , MultipartFile multipartFile){
InputStream inputStream = null;
try {
inputStream = multipartFile.getInputStream();
} catch (IOException e) {
e.printStackTrace();
}
uploadFileInputStreamForBucket(bucketName, ossPath, inputStream);
return accessPre+ossPath;
}
/**
* 使FilePutObject ** 使
* @param bucketName
* @param ossPath oss
* @param filePath
*/
public static String uploadFileForBucket(String bucketName , String ossPath , String filePath) {
// 创建PutObjectRequest对象。
PutObjectRequest putObjectRequest = new PutObjectRequest(bucketName, ossPath, new File(filePath));
// 上传
ossClient.putObject(putObjectRequest);
return accessPre+ossPath;
}
/**
* 使bucket
* @param bucketName
* @param ossPath oss
* @param filePath
*/
public static String uploadFileInputStreamForBucket(String bucketName , String ossPath , String filePath){
// 填写本地文件的完整路径。如果未指定本地路径,则默认从示例程序所属项目对应本地路径中上传文件流。
InputStream inputStream = null;
try {
inputStream = new FileInputStream(filePath);
} catch (FileNotFoundException e) {
e.printStackTrace();
}
// 填写Bucket名称和Object完整路径。Object完整路径中不能包含Bucket名称。
uploadFileInputStreamForBucket(bucketName, ossPath, inputStream);
return accessPre+ossPath;
}
public static void uploadFileInputStreamForBucket(String bucketName , String ossPath , InputStream inputStream ){
ossClient.putObject(bucketName, ossPath, inputStream);
}
/**
*
* @param ossFilePath
* @param filePath
*/
public static void downloadFile(String ossFilePath , String filePath ){
downloadFileForBucket(bucketName , ossFilePath , filePath);
}
/**
*
* @param bucketName
* @param ossFilePath oss
* @param filePath
*/
public static void downloadFileForBucket(String bucketName , String ossFilePath , String filePath ){
ossClient.getObject(new GetObjectRequest(bucketName, ossFilePath), new File(filePath));
}
/**
*
* @return
*/
public static String getOssDefaultPath(){
LocalDateTime now = LocalDateTime.now();
String url =
now.getYear()+"/"+
now.getMonth()+"/"+
now.getDayOfMonth()+"/"+
now.getHour()+"/"+
now.getMinute()+"/";
return url;
}
public static String getOssFilePath(String filePath){
String fileSuf = filePath.substring(filePath.indexOf(".") + 1);
return getOssDefaultPath() + UUID.randomUUID().toString() + "." + fileSuf;
}
}

View File

@ -0,0 +1,20 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.zyh.system.mapper.HouseMapper">
<insert id="addHouse">
insert into house values(0,#{plotId},#{name},#{jurisdiction},#{lng},#{lat},#{pic})
</insert>
<select id="getJurisdictionTree" resultType="com.zyh.common.domain.Area">
select * from area
<where>
<if test="parentId != null">
and parent_id = #{parentId}
</if>
</where>
</select>
<select id="getHouse" resultType="com.zyh.common.domain.House">
select house.*,area.name areaname from house left join area on house.jurisdiction=area.id
</select>
</mapper>