Explorar o código

1、增加阿里云oss日志分析获取下载次数
2、agent删除app 时同步删除 default_config配置

marxjaw hai 3 meses
pai
achega
021b323735

+ 1 - 0
yt-agent/agent-service/src/main/java/com/ytpm/service/impl/AgentAppServiceImpl.java

@@ -168,6 +168,7 @@ public class AgentAppServiceImpl implements AgentAppService {
         }
 //        advertiseFeign.delApp(appId);
         appMapper.deleteApp(appId);
+        appFeign.delAppConfig(appId);
         return Result.resultOk(RepMessage.DELETE_SUCCESS);
     }
 

+ 3 - 0
yt-app/app-feign/src/main/java/com/ytpm/feign/AppFeign.java

@@ -84,4 +84,7 @@ public interface AppFeign {
 
     @PostMapping("/user/getRevenueByTime")
     BigDecimal getRevenueByTime(@RequestBody YtAppUserListParam param);
+
+    @PostMapping("/wx/delDefaultConfig")
+    void delAppConfig(@RequestParam("appId") String appId);
 }

+ 6 - 0
yt-app/app-service/src/main/java/com/ytpm/controller/dyz/WxController.java

@@ -155,4 +155,10 @@ public class WxController {
     public List<WxDefaultConfig> getConfigs(@RequestParam(name = "appIds")String appIds){
         return appUserMapper.getConfigByIds(appIds);
     }
+
+    @ApiOperation("删除默认配置")
+    @GetMapping("/delDefaultConfig")
+    public void delDefaultConfig(@RequestParam(name = "appId")String appId){
+        appUserMapper.delByAppId(appId);
+    }
 }

+ 5 - 0
yt-app/app-service/src/main/java/com/ytpm/dao/dyz/AppUserMapper.java

@@ -166,4 +166,9 @@ public interface AppUserMapper {
      * 分时统计登录
      */
     List<AppUserHourVO> countLoginHour(@Param("appId")String appId, @Param("type")int type);
+
+    /**
+     * 根据应用ID删除默认配置
+     */
+    void delByAppId(@Param("appId")String appId);
 }

+ 3 - 0
yt-app/app-service/src/main/resources/mapper/dyz/AppUserMapper.xml

@@ -159,6 +159,9 @@
         </set>
         where user_id = #{userId}
     </update>
+    <delete id="delByAppId">
+        delete from yt_app_default_config where app_id = #{appId}
+    </delete>
     <select id="getYtAppUser" resultType="com.ytpm.app.model.YtDyzUser">
         select
            user_id, app_id,phone,device_id, ditch_id, nick_name,head_img, power, registry_time, last_login_time, last_login_ip, login_days, total_video, total_income, red_packet_balance, red_packet_amount, points_balance, points_total, withdraw_total, sign_days, user_status, risk_reason, wx_open_id, platform_id

+ 2 - 0
yt-common/src/main/java/com/ytpm/agent/view/AgentAppView.java

@@ -19,6 +19,8 @@ public class AgentAppView {
     private Integer appType;
     @ApiModelProperty("apk安装包地址")
     private String apkUrl;
+    @ApiModelProperty("下载次数")
+    private Integer downloadCount;
     @ApiModelProperty("二维码链接")
     private String qrCode;
     @ApiModelProperty("版本号")

+ 2 - 2
yt-common/src/main/java/com/ytpm/app/param/AppUserParam.java

@@ -7,6 +7,6 @@ import java.util.Date;
 @Data
 public class AppUserParam {
     private String userIds;
-    private Date loginTimeBegin;
-    private Date loginTimeEnd;
+    private String loginTimeBegin;
+    private String loginTimeEnd;
 }

+ 0 - 3
yt-common/src/main/java/com/ytpm/app/view/YtAppUserListView.java

@@ -1,6 +1,5 @@
 package com.ytpm.app.view;
 
-import com.fasterxml.jackson.annotation.JsonFormat;
 import com.ytpm.app.model.YtDyzLoginRecord;
 import com.ytpm.custom.CustomField;
 import com.ytpm.general.PageMeta;
@@ -44,10 +43,8 @@ public class YtAppUserListView extends PageMeta {
     @ApiModelProperty("用户昵称")
     private String nickName ;
     @ApiModelProperty("注册时间")
-    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
     private Date registryTime;
     @ApiModelProperty("最新登录时间")
-    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
     private Date lastLoginTime;
     @ApiModelProperty("最新登录IP")
     private String lastLoginIp;

+ 2 - 2
yt-common/src/main/java/com/ytpm/risk/param/RiskDeblockingListParam.java

@@ -17,9 +17,9 @@ import java.util.Date;
 @ApiModel("用户解封记录表筛选表单")
 public class RiskDeblockingListParam extends PageMeta {
     @ApiModelProperty("登录时间开始")
-    private Date loginTimeBegin;
+    private String loginTimeBegin;
     @ApiModelProperty("登录时间截止")
-    private Date loginTimeEnd;
+    private String loginTimeEnd;
     @ApiModelProperty("解封时间开始")
     private String deblockingTimeBegin;
     @ApiModelProperty("解封时间结束")

+ 0 - 4
yt-common/src/main/java/com/ytpm/risk/view/RiskBannedListView.java

@@ -1,6 +1,5 @@
 package com.ytpm.risk.view;
 
-import com.fasterxml.jackson.annotation.JsonFormat;
 import com.ytpm.general.PageMeta;
 import io.swagger.annotations.ApiModel;
 import io.swagger.annotations.ApiModelProperty;
@@ -28,17 +27,14 @@ public class RiskBannedListView extends PageMeta {
     @ApiModelProperty("用户昵称")
     private String nickName;
     @ApiModelProperty("注册时间")
-    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
     private Date registryTime;
     @ApiModelProperty("最新登录时间")
-    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
     private Date lastLoginTime;
     @ApiModelProperty("最新登录IP")
     private String lastLoginIp;
     @ApiModelProperty("用户状态")
     private Integer userStatus;
     @ApiModelProperty("封禁时间")
-    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
     private Date bannedTime;
     @ApiModelProperty("封禁原因")
     private String bannedReason;

+ 0 - 4
yt-common/src/main/java/com/ytpm/risk/view/RiskDeblockingListView.java

@@ -1,6 +1,5 @@
 package com.ytpm.risk.view;
 
-import com.fasterxml.jackson.annotation.JsonFormat;
 import com.ytpm.general.PageMeta;
 import io.swagger.annotations.ApiModel;
 import io.swagger.annotations.ApiModelProperty;
@@ -29,10 +28,8 @@ public class RiskDeblockingListView extends PageMeta {
     @ApiModelProperty("用户昵称")
     private String nickName;
     @ApiModelProperty("注册时间")
-    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
     private Date registryTime;
     @ApiModelProperty("最新登录时间")
-    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
     private Date lastLoginTime;
     @ApiModelProperty("用户状态")
     private Integer userStatus;
@@ -43,7 +40,6 @@ public class RiskDeblockingListView extends PageMeta {
     @ApiModelProperty("操作人")
     private String operatorName;
     @ApiModelProperty("解禁时间")
-    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
     private Date deblockingTime;
     @ApiModelProperty("解禁原因")
     private String deblockingReason;

+ 5 - 0
yt-middle/middle-platform/pom.xml

@@ -33,6 +33,11 @@
             <artifactId>aliyun-sdk-oss</artifactId>
             <version>3.17.4</version>
         </dependency>
+        <dependency>
+            <groupId>com.aliyun</groupId>
+            <artifactId>sls20201230</artifactId>
+            <version>5.9.0</version>
+        </dependency>
         <dependency>
             <groupId>com.ytpm</groupId>
             <artifactId>app-feign</artifactId>

+ 14 - 2
yt-middle/middle-platform/src/main/java/com/ytpm/middle/service/impl/ApkServiceImpl.java

@@ -22,11 +22,13 @@ import com.ytpm.middle.dao.ApkMapper;
 import com.ytpm.middle.dao.AppMapper;
 import com.ytpm.middle.dao.RiskMapper;
 import com.ytpm.middle.service.ApkService;
+import com.ytpm.middle.util.AliOSSUtil;
 import com.ytpm.middle.view.AppListVO;
 import com.ytpm.middle.view.MiddleUserInfo;
 import com.ytpm.risk.model.YtRiskConfig;
 import com.ytpm.risk.model.YtRiskTemplate;
 import com.ytpm.risk.model.YtRiskTemplateConfig;
+import com.ytpm.util.DateUtil;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.cloud.context.config.annotation.RefreshScope;
 import org.springframework.stereotype.Service;
@@ -37,6 +39,7 @@ import java.util.ArrayList;
 import java.util.Comparator;
 import java.util.Date;
 import java.util.List;
+import java.util.Locale;
 import java.util.Map;
 import java.util.Objects;
 import java.util.stream.Collectors;
@@ -66,9 +69,18 @@ public class ApkServiceImpl implements ApkService {
         String appIds = views.stream().map(AgentAppView::getAppId).collect(Collectors.joining(","));
         List<WxDefaultConfig> configs = appFeign.getConfigs(appIds);
         Map<String, Integer> appTypeMap = configs.stream().collect(Collectors.toMap(WxDefaultConfig::getAppId, WxDefaultConfig::getAppType));
+        //分析OSS实时日志统计下载次数
+        Map<String, Integer> countDownloadMap = AliOSSUtil.getCountDownload(
+                Math.toIntExact(DateUtil.getTodayStart().getTime() / 1000), (int) (System.currentTimeMillis() / 1000));
         for (AgentAppView view : views) {
-            if(!appTypeMap.containsKey(view.getAppId()))continue;
-            view.setAppCode(appTypeMap.get(view.getAppId()));
+            if(appTypeMap.containsKey(view.getAppId())) {
+                view.setAppCode(appTypeMap.get(view.getAppId()));
+            }
+            if(CharSequenceUtil.isBlank(view.getApkUrl()))continue;
+            String substring = view.getApkUrl().substring(view.getApkUrl().lastIndexOf("/")+1).toLowerCase(Locale.ENGLISH);
+            if(countDownloadMap.containsKey(substring)){
+                view.setDownloadCount(countDownloadMap.get(substring));
+            }
         }
         return ResultTable.resultTableOk(new PageInfo<>(views));
     }

+ 97 - 279
yt-middle/middle-platform/src/main/java/com/ytpm/middle/util/AliOSSUtil.java

@@ -1,5 +1,6 @@
 package com.ytpm.middle.util;
 
+import com.alibaba.fastjson.JSON;
 import com.aliyun.oss.ClientBuilderConfiguration;
 import com.aliyun.oss.OSS;
 import com.aliyun.oss.OSSClientBuilder;
@@ -8,36 +9,20 @@ import com.aliyun.oss.common.auth.DefaultCredentialProvider;
 import com.aliyun.oss.common.auth.DefaultCredentials;
 import com.aliyun.oss.common.comm.Protocol;
 import com.aliyun.oss.common.comm.SignVersion;
-import com.aliyun.oss.model.Bucket;
-import com.aliyun.oss.model.DeleteObjectsRequest;
-import com.aliyun.oss.model.DeleteObjectsResult;
-import com.aliyun.oss.model.GetObjectRequest;
-import com.aliyun.oss.model.ListObjectsRequest;
-import com.aliyun.oss.model.OSSObject;
-import com.aliyun.oss.model.OSSObjectSummary;
-import com.aliyun.oss.model.ObjectListing;
-import com.aliyun.oss.model.ObjectMetadata;
 import com.aliyun.oss.model.PutObjectRequest;
-import com.aliyun.oss.model.PutObjectResult;
-import com.aliyun.oss.model.UploadFileRequest;
+import com.aliyun.sls20201230.models.GetLogsResponse;
+import com.aliyun.tea.TeaException;
+import com.ytpm.util.DateUtil;
+import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.cloud.context.config.annotation.RefreshScope;
 import org.springframework.stereotype.Component;
-import org.springframework.web.multipart.MultipartFile;
-
-import javax.imageio.ImageIO;
-import java.awt.image.BufferedImage;
-import java.io.ByteArrayInputStream;
-import java.io.ByteArrayOutputStream;
-import java.io.File;
-import java.io.IOException;
 import java.io.InputStream;
-import java.net.URL;
-import java.util.ArrayList;
-import java.util.Base64;
-import java.util.Date;
-import java.util.List;
+import java.util.HashMap;
+import java.util.Locale;
+import java.util.Map;
 
+@Slf4j(topic = "AliOSS")
 @Component
 @RefreshScope
 public class AliOSSUtil {
@@ -70,18 +55,30 @@ public class AliOSSUtil {
         bucketName = bucketNameCon;
     }
 
+    private static String projectName;
+    @Value("${oss.aliyun.bucketName}")
+    public static void setProjectName(String projectName) {
+        AliOSSUtil.projectName = projectName;
+    }
 
-    /**
-     * 针对MultipartFile类型
-     *
-     * @param multipartFile 前端传回的MultipartFile类型的数据
-     * @return java.lang.String 返回该文件的访问链接
-     */
-    public static String upload(MultipartFile multipartFile, String fileName) throws IOException {
-        // 获取上传的文件的输入流
-        InputStream inputStream = multipartFile.getInputStream();
-        return upload(inputStream, fileName);
+    private static String logstoreName;
+    @Value("${oss.aliyun.logstoreName}")
+    public static void setLogstoreName(String logstoreName) {
+        AliOSSUtil.logstoreName = logstoreName;
     }
+
+    private static String logUrl;
+    @Value("${oss.aliyun.logUrl}")
+    public static void setLogUrl(String logUrl) {
+        AliOSSUtil.logUrl = logUrl;
+    }
+
+    private static String querySql;
+    @Value("${oss.aliyun.querySql}")
+    public static void setQuerySql(String querySql) {
+        AliOSSUtil.querySql = querySql;
+    }
+
     /**
      * 上传广告平台文件
      */
@@ -116,260 +113,81 @@ public class AliOSSUtil {
     }
 
     /**
-     * 针对Base64类型
-     *
-     * @param base64 Base64字符串,标准的Base64字符串,例如...
-     * @return java.lang.String 返回该文件的访问链接
-     */
-    public static String upload(String base64) {
-        // 获取上传的文件的输入流
-        byte[] bytes = Base64.getDecoder().decode(base64.split(",")[1]);
-        InputStream inputStream = new ByteArrayInputStream(bytes);
-        // 获取文件名称
-        String fileName = base64.substring(base64.indexOf(":") + 1, base64.indexOf(";")).replace("/", ".");
-
-        return upload(inputStream, fileName);
-    }
-
-    /**
-     * 查询所有文件名称
-     *
-     * @param path 相对于阿里云bucket存储空间的文件路径
-     * @return java.util.List<java.lang.String> 该路径下所有文件的名称
-     * <p>
-     * 注:首先会获取根文件的名称
-     */
-    public static List<String> listFileName(String path) {
-        List<String> res = new ArrayList<>();
-        // 构造ListObjectsRequest请求。
-        ListObjectsRequest listObjectsRequest = new ListObjectsRequest(bucketName);
-
-        // 设置prefix参数来获取fun目录下的所有文件。
-        listObjectsRequest.setPrefix(path);
-
-        OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
-
-        // 列出文件。
-        ObjectListing listing = ossClient.listObjects(listObjectsRequest);
-        // 遍历所有文件
-        for (OSSObjectSummary objectSummary : listing.getObjectSummaries()) {
-            System.out.println(objectSummary.getKey());
-        }
-        // 关闭OSSClient。
-        ossClient.shutdown();
-        return res;
-    }
-
-    /**
-     * 查询所有文件的url
-     *
-     * @param path 相对于阿里云bucket存储空间的文件路径
-     * @return java.util.List<java.lang.String> 返回路径下所有文件的url
-     * <p>
-     * 注:首先会获取根文件夹的url,且根文件夹的url无法访问
-     */
-    public static List<String> listFileUrl(String path) {
-        List<String> res = new ArrayList<>();
-
-        // 构造ListObjectsRequest请求
-        ListObjectsRequest listObjectsRequest = new ListObjectsRequest(bucketName);
-
-        // 设置prefix参数来获取fun目录下的所有文件。
-        listObjectsRequest.setPrefix(path);
-
-        OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
-
-        // 列出文件。
-        ObjectListing listing = ossClient.listObjects(listObjectsRequest);
-        // 遍历所有文件。
-
-        for (OSSObjectSummary objectSummary : listing.getObjectSummaries()) {
-            //文件访问路径
-            Date expiration = new Date(System.currentTimeMillis() + 3600L * 1000 * 24 * 365 * 100);
-            URL url = ossClient.generatePresignedUrl(bucketName, objectSummary.getKey(), expiration);
-            res.add(url.toString());
-        }
-        // 关闭OSSClient。
-        ossClient.shutdown();
-        return res;
-    }
-
-    /**
-     * 判断文件是否存在
-     *
-     * @param objectName 相对于阿里云bucket存储空间的文件路径和文件名称
-     * @return boolean 存在返回true,存在返回false
-     */
-    public static boolean isFileExist(String objectName) {
-        OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
-
-        boolean res = ossClient.doesObjectExist(bucketName, objectName);
-        return res;
-    }
-
-    /**
-     * 通过文件名称(包括路径)下载文件
-     *
-     * @param objectName    相对于阿里云bucket存储空间的文件路径和文件名称
-     * @param localFileName 下载的路径和文件名称
-     */
-    public static void downloadFile(String objectName, String localFileName) {
-        OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
-
-        // 下载OSS文件到本地文件。如果指定的本地文件存在会覆盖,不存在则新建。
-        ossClient.getObject(new GetObjectRequest(bucketName, objectName), new File(localFileName));
-        // 关闭OSSClient。
-        ossClient.shutdown();
-    }
-
-    /**
-     * 删除文件或目录
-     *
-     * @param objectName 相对于阿里云bucket存储空间的文件路径和文件名称
+     * 初始化客户端
      */
-    public static void deleteFile(String objectName) {
-        OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
-        ossClient.deleteObject(bucketName, objectName);
-        ossClient.shutdown();
+    public static com.aliyun.sls20201230.Client createClient() throws Exception {
+        com.aliyun.teaopenapi.models.Config config = new com.aliyun.teaopenapi.models.Config()
+                .setAccessKeyId("LTAI5tQQ57pTXeFHacavoJMq")
+                .setAccessKeySecret("TZX8QPD81w1magxBxVpnRJ3NFHEAoS");
+        config.endpoint = "cn-nanjing.log.aliyuncs.com";
+        return new com.aliyun.sls20201230.Client(config);
     }
 
     /**
-     * 批量删除文件或目录
-     *
-     * @param keys 相对于阿里云bucket存储空间的文件路径和文件名称
+     * 根据传入时间分析查询日志
      */
-    public static void deleteFiles(List<String> keys) {
-        OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
-
-        // 删除文件。
-        DeleteObjectsResult deleteObjectsResult = ossClient.deleteObjects(new DeleteObjectsRequest(bucketName).withKeys(keys));
-        List<String> deletedObjects = deleteObjectsResult.getDeletedObjects();
-
-        ossClient.shutdown();
-    }
-
-    /**
-     * 创建文件夹
-     *
-     * @param folder 文件夹名称。注:文件夹名称后面需要添加“/”,否则创建的是文件,并非文件夹。
-     * @return java.lang.String 相对于阿里云bucket存储空间的文件夹路径
-     */
-    public static String createFolder(String folder) {
-        // 文件夹名
-        final String keySuffixWithSlash = folder;
-        OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
-
-        // 判断文件夹是否存在,不存在则创建
-        if (!ossClient.doesObjectExist(bucketName, keySuffixWithSlash)) {
-            // 创建文件夹
-            ossClient.putObject(bucketName, keySuffixWithSlash, new ByteArrayInputStream(new byte[0]));
-            // 得到文件夹名
-            OSSObject object = ossClient.getObject(bucketName, keySuffixWithSlash);
-            String fileDir = object.getKey();
-            ossClient.shutdown();
-            return fileDir;
-        }
-
-        return keySuffixWithSlash;
-    }
-
-    /**
-     * 文件上传,文件上传后会将文件放置在当前日期的目录中,如:2022-07-08/1_1657251247153.png
-     *
-     * @param inputStream 上传文件的流
-     * @param fileName    文件名称,命名规则是:文件名+当前时间戳+后缀
-     * @return java.lang.String 返回该文件的访问链接
-     */
-    private static String upload(InputStream inputStream, String fileName) {
-        // 避免文件被覆盖,为上传文件名称添加时间戳
-        int i = fileName.lastIndexOf(".");
-        String suffix = fileName.substring(i);
-        fileName = fileName.substring(0, i) + "-" + System.currentTimeMillis() + suffix;
-
-        // 如果需要上传时设置存储类型与访问权限
-        ObjectMetadata metadata = new ObjectMetadata();
-        metadata.setContentType(getContentType(fileName.substring(fileName.lastIndexOf("."))));
-
-        // 上传文件到OSS时需要指定包含文件后缀在内的完整路径,例如abc/efg/123.jpg。
-        PutObjectRequest putObjectRequest = new PutObjectRequest(bucketName, fileName, inputStream);
-        putObjectRequest.setMetadata(metadata);
-
-        OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
-
-        ossClient.putObject(putObjectRequest);
-
-        // 关闭ossClient
-        ossClient.shutdown();
-        // 把上传到oss的路径返回
-        return fileName;
-    }
-
-    public static String upload1(InputStream inputStream, String fileName) {
-        // 避免文件被覆盖,为上传文件名称添加时间戳
-        fileName = fileName + "-" + System.currentTimeMillis();
-
-        // 2. 设置文件的 Content-Type
-        ObjectMetadata metadata = new ObjectMetadata();
-        metadata.setContentType(getContentType("png"));
-
-        // 3. 上传文件到OSS,指定文件路径(bucketName 是 OSS 存储桶名称)
-        PutObjectRequest putObjectRequest = new PutObjectRequest(bucketName, fileName, inputStream);
-        putObjectRequest.setMetadata(metadata);
-
-        // 4. 创建 OSS 客户端
-        OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
-
-        // 5. 上传文件
-        ossClient.putObject(putObjectRequest);
-
-        // 6. 关闭 OSS 客户端
-        ossClient.shutdown();
-        // 把上传到oss的路径返回
-        return fileName;
-    }
-
-    private static String getContentType(String FileNameExtension) {
-        if (FileNameExtension.equalsIgnoreCase(".bmp")) {
-            return "image/bmp";
-        }
-        if (FileNameExtension.equalsIgnoreCase(".gif")) {
-            return "image/gif";
-        }
-        if (FileNameExtension.equalsIgnoreCase(".jpeg") ||
-                FileNameExtension.equalsIgnoreCase(".jpg") ||
-                FileNameExtension.equalsIgnoreCase(".png")
-        ) {
-            return "image/jpg";
+    public static Map<String, Integer> getCountDownload(int from , int to){
+        if(from > to)return new HashMap<>();
+        try {
+            com.aliyun.sls20201230.Client client = AliOSSUtil.createClient();
+            com.aliyun.sls20201230.models.GetLogsRequest getLogsRequest = new com.aliyun.sls20201230.models.GetLogsRequest()
+                    .setFrom(from)
+                    .setTo(to)
+                    .setQuery("* and __topic__: oss_access_log and bucket: yt-advise|SELECT object, count(1) pv from log where object like '%.apk' group by object order by pv Desc");
+            com.aliyun.teautil.models.RuntimeOptions runtime = new com.aliyun.teautil.models.RuntimeOptions();
+            java.util.Map<String, String> headers = new java.util.HashMap<>();
+            // 复制代码运行请自行打印 API 的返回值
+            GetLogsResponse logsWithOptions = client.getLogsWithOptions("oss-log-1694777633719600-cn-nanjing", "oss-log-store", getLogsRequest, headers, runtime);
+            Map<String, Integer> map = new HashMap<>();
+            for (Map<String, ?> stringMap : logsWithOptions.getBody()) {
+                String key = stringMap.get("object").toString();
+                map.put(key.substring(key.lastIndexOf("/")+1).toLowerCase(Locale.ROOT), Integer.parseInt(stringMap.get("pv").toString()));
+            }
+            return map;
+        } catch (TeaException error) {
+            // 此处仅做打印展示,请谨慎对待异常处理,在工程项目中切勿直接忽略异常。
+            // 错误 message
+            log.error(error.getMessage());
+            // 诊断地址
+            log.error(error.getData().get("Recommend").toString());
+            com.aliyun.teautil.Common.assertAsString(error.message);
+        } catch (Exception _error) {
+            TeaException error = new TeaException(_error.getMessage(), _error);
+            // 此处仅做打印展示,请谨慎对待异常处理,在工程项目中切勿直接忽略异常。
+            // 错误 message
+            log.error(error.getMessage());
+            // 诊断地址
+            log.error(error.getData().get("Recommend").toString());
+            com.aliyun.teautil.Common.assertAsString(error.message);
         }
-        return "image/jpg";
+        return new HashMap<>();
     }
 
-    public static String uploadToOSS(BufferedImage qrImage, String fileName) {
+    public static void main(String[] args) throws Exception {
+//        getCountDownload(Math.toIntExact(DateUtil.getTodayStart().getTime() / 1000), (int) (System.currentTimeMillis()/1000));
+        com.aliyun.sls20201230.Client client = AliOSSUtil.createClient();
+        com.aliyun.sls20201230.models.GetLogsRequest getLogsRequest = new com.aliyun.sls20201230.models.GetLogsRequest();
+        com.aliyun.teautil.models.RuntimeOptions runtime = new com.aliyun.teautil.models.RuntimeOptions();
+        java.util.Map<String, String> headers = new java.util.HashMap<>();
         try {
-            // 设置文件的 MIME 类型
-            String fileExtension = fileName.substring(fileName.lastIndexOf("."));
-            ObjectMetadata metadata = new ObjectMetadata();
-            metadata.setContentType(getContentType(fileExtension));  // 设置上传文件的 MIME 类型
-
-            ByteArrayOutputStream baos = new ByteArrayOutputStream();
-            ImageIO.write(qrImage, "PNG", baos);
-
-            ByteArrayInputStream inputStream = new ByteArrayInputStream(baos.toByteArray());
-
-            // 使用 OSSClient 上传文件
-            OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
-            PutObjectRequest putObjectRequest = new PutObjectRequest(bucketName, fileName, inputStream);
-            putObjectRequest.setMetadata(metadata);  // 设置文件的元数据
-            ossClient.putObject(putObjectRequest);
-
-            inputStream.close();
-            ossClient.shutdown();
-        } catch (IOException e) {
-            e.printStackTrace();
+            // 复制代码运行请自行打印 API 的返回值
+            client.getLogsWithOptions("", "", getLogsRequest, headers, runtime);
+        } catch (TeaException error) {
+            // 此处仅做打印展示,请谨慎对待异常处理,在工程项目中切勿直接忽略异常。
+            // 错误 message
+            System.out.println(error.getMessage());
+            // 诊断地址
+            System.out.println(error.getData().get("Recommend"));
+            com.aliyun.teautil.Common.assertAsString(error.message);
+        } catch (Exception _error) {
+            TeaException error = new TeaException(_error.getMessage(), _error);
+            // 此处仅做打印展示,请谨慎对待异常处理,在工程项目中切勿直接忽略异常。
+            // 错误 message
+            System.out.println(error.getMessage());
+            // 诊断地址
+            System.out.println(error.getData().get("Recommend"));
+            com.aliyun.teautil.Common.assertAsString(error.message);
         }
-
-        // 返回上传到OSS的路径
-        return "https://" + bucketName + "." + endpoint + "/" + fileName;
     }
-
 }
+

+ 1 - 1
yt-middle/middle-platform/src/main/resources/mapper/WorkorderMapper.xml

@@ -55,7 +55,7 @@
         left join yt_platform_user pu on wo.create_user_id = pu.user_id
         left join yt_platform_user pu1 on wo.processor = pu1.user_id
         where wo.available = 1
-        <if test=" creatorName!=null and != creatorName''">
+        <if test=" creatorName!=null and creatorName!= ''">
             and pu.nick_name like concat('%',#{creatorName},'%')
         </if>
         <if test=" processorName!=null and processorName!= ''">