/* * Copyright (c) 2018-2028, Chill Zhuang All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * Neither the name of the dreamlu.net developer nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * Author: Chill 庄骞 (smallchill@163.com) */ package org.springblade.modules.mechanism.controller; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.google.zxing.WriterException; import io.minio.*; import io.minio.errors.*; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiParam; import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport; import lombok.AllArgsConstructor; import javax.validation.Valid; import org.springblade.common.utils.Base64Util; import org.springblade.common.utils.QRCodeUtil; import org.springblade.core.mp.support.Condition; import org.springblade.core.mp.support.Query; import org.springblade.core.oss.model.BladeFile; import org.springblade.core.tool.api.R; import org.springblade.core.tool.utils.Func; import org.springblade.modules.resource.builder.oss.OssBuilder; import org.springblade.modules.resource.entity.Oss; import org.springblade.modules.resource.service.IOssService; import org.springframework.web.bind.annotation.*; import com.baomidou.mybatisplus.core.metadata.IPage; import org.springblade.modules.mechanism.entity.Mechanism; import org.springblade.modules.mechanism.vo.MechanismVO; import org.springblade.modules.mechanism.service.IMechanismService; import org.springblade.core.boot.ctrl.BladeController; import springfox.documentation.annotations.ApiIgnore; import sun.misc.BASE64Encoder; import java.io.ByteArrayInputStream; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.net.URLEncoder; import java.security.InvalidKeyException; import java.security.NoSuchAlgorithmException; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.UUID; /** * 控制器 * * @author BladeX * @since 2021-11-22 */ @RestController @AllArgsConstructor @RequestMapping("blade-mechanism/mechanism") @Api(value = "", tags = "接口") public class MechanismController extends BladeController { private final IMechanismService mechanismService; private final IOssService ossService; /** * 对象存储构建类 */ private final OssBuilder ossBuilder; /** * 详情 */ @GetMapping("/detail") @ApiOperationSupport(order = 1) @ApiOperation(value = "详情", notes = "传入mechanism") public R detail(Mechanism mechanism) { Mechanism detail = mechanismService.getOne(Condition.getQueryWrapper(mechanism)); return R.data(detail); } /** * 分页 */ @GetMapping("/list") @ApiOperationSupport(order = 2) @ApiOperation(value = "分页", notes = "传入mechanism") public R> list(@ApiIgnore @RequestParam Map mechanism, Query query) { IPage pages = mechanismService.page(Condition.getPage(query), Condition.getQueryWrapper(mechanism, Mechanism.class)); return R.data(pages); } /** * 自定义分页 */ @GetMapping("/page") @ApiOperationSupport(order = 3) @ApiOperation(value = "分页", notes = "传入mechanism") public R> page(MechanismVO mechanism, Query query) { IPage pages = mechanismService.selectMechanismPage(Condition.getPage(query), mechanism); return R.data(pages); } /** * 新增 */ @PostMapping("/save") @ApiOperationSupport(order = 4) @ApiOperation(value = "新增", notes = "传入mechanism") public R save(@Valid @RequestBody Mechanism mechanism) throws IOException, WriterException, ServerException, InsufficientDataException, NoSuchAlgorithmException, InternalException, InvalidResponseException, XmlParserException, InvalidKeyException, ErrorResponseException { mechanism.setPitch("-90"); mechanism.setHeading("0"); mechanism.setRoll("0"); mechanism.setGd("0"); String addressName = URLEncoder.encode(mechanism.getAddressName(), "UTF-8"); //String url = "http://192.168.0.115:8080/#/mobileLayout/default"; String url = "https://dev.jxpskj.com:8023/zhjg/#/mobileLayout/default"; String gotos = URLEncoder.encode("arc", "UTF-8"); String mechanismname = URLEncoder.encode(mechanism.getMechanismname(), "UTF-8"); String address = URLEncoder.encode(mechanism.getAddress(), "UTF-8"); String telephone = URLEncoder.encode(mechanism.getTelephone(), "UTF-8"); String introduce = URLEncoder.encode(mechanism.getIntroduce(), "UTF-8"); String jd = URLEncoder.encode(mechanism.getJd(), "UTF-8"); String x = URLEncoder.encode(mechanism.getX(), "UTF-8"); String wd = URLEncoder.encode(mechanism.getWd(), "UTF-8"); String gd = URLEncoder.encode(mechanism.getGd(), "UTF-8"); String tpurl = URLEncoder.encode(mechanism.getTpurl(), "UTF-8"); String websiteurl = URLEncoder.encode(mechanism.getWebsiteurl(), "UTF-8"); String type = URLEncoder.encode(mechanism.getType(), "UTF-8"); String mtype = URLEncoder.encode(mechanism.getMtype(), "UTF-8"); String loutype = URLEncoder.encode(mechanism.getLoutype(), "UTF-8"); String campus = URLEncoder.encode(mechanism.getCampus(), "UTF-8"); String heading = URLEncoder.encode(mechanism.getHeading(), "UTF-8"); String pitch = URLEncoder.encode(mechanism.getPitch(), "UTF-8"); String roll = URLEncoder.encode(mechanism.getRoll(), "UTF-8"); String videourl = URLEncoder.encode(mechanism.getVideourl(), "UTF-8"); String content = url + "?methods=" + gotos + "&mechanismname=" + mechanismname + "&address=" + address + "&telephone=" + telephone + "&introduce=" + introduce + "&jd=" + jd + "&x=" + x + "&wd=" + wd + "&gd=" + gd + "&tpurl=" + tpurl + "&websiteurl=" + websiteurl + "&type=" + type + "&mtype=" + mtype + "&loutype=" + loutype + "&campus=" + campus + "&heading=" + heading + "&pitch=" + pitch + "&roll=" + roll + "&addressName=" + addressName + "&videourl=" + videourl; //生成标注二维码 byte[] qrCodeImage = QRCodeUtil.getQRCodeImage(content, 350, 350); // String encode = new BASE64Encoder().encode(qrCodeImage); // //设置二维码 // String a = "data:image/png;base64," + encode; ByteArrayInputStream stream = new ByteArrayInputStream(qrCodeImage); String upload = upload(stream);//关闭流 stream.close(); //设置二维码地址 mechanism.setCodeurl(upload); return R.status(mechanismService.save(mechanism)); } /** * 修改 */ @PostMapping("/update") @ApiOperationSupport(order = 5) @ApiOperation(value = "修改", notes = "传入mechanism") public R update(@Valid @RequestBody Mechanism mechanism) { return R.status(mechanismService.updateById(mechanism)); } /** * 新增或修改 */ @PostMapping("/submit") @ApiOperationSupport(order = 6) @ApiOperation(value = "新增或修改", notes = "传入mechanism") public R submit(@Valid @RequestBody Mechanism mechanism) { return R.status(mechanismService.saveOrUpdate(mechanism)); } /** * 删除 */ @PostMapping("/remove") @ApiOperationSupport(order = 8) @ApiOperation(value = "删除", notes = "传入ids") public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) { return R.status(mechanismService.removeByIds(Func.toLongList(ids))); } /** * code url 转换 */ @GetMapping("/url") public void url() throws IOException, ServerException, InsufficientDataException, NoSuchAlgorithmException, InternalException, InvalidResponseException, XmlParserException, InvalidKeyException, ErrorResponseException { List list = mechanismService.selectAllList(); for (Mechanism mechanism : list) { int index = mechanism.getCodeurl().lastIndexOf(",") +1; String substring = mechanism.getCodeurl().substring(index); byte[] qrCodeImage = Base64Util.decode(substring); ByteArrayInputStream inputStream = new ByteArrayInputStream(qrCodeImage); String url = upload(inputStream); mechanism.setCodeurl(url); mechanismService.updateById(mechanism); //关闭流 inputStream.close(); } } private String upload(ByteArrayInputStream in) throws IOException, InvalidKeyException, InvalidResponseException, InsufficientDataException, NoSuchAlgorithmException, ServerException, InternalException, XmlParserException, ErrorResponseException { QueryWrapper wrapper = new QueryWrapper<>(); wrapper.eq("is_deleted",0); Oss one = ossService.getOne(wrapper); //填写你文件上传的地址以及相应信息 // String url = "http://106.225.193.35:2081"; // String access = "zhbaadmin"; // String secret = "zhbapassword"; // String bucket = "zhxy"; String url = one.getEndpoint(); String access = one.getAccessKey(); String secret = one.getSecretKey(); String bucket = one.getBucketName(); 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("-", "") + ".png"; //创建头部信息 Map 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()); //文件推送 // String urls = "https://dev.jxpskj.com:8023/zhxy/"+newName; String urls = url + "/"+ bucket + "/" + newName; //返回 return urls; } }