oss上传

//获取oss url
    private String getUrl(File file, String excelName) {
        String url=null;
        try {
            url = OssUploadController.uploadInputSteam(new FileInputStream(file), excelName+".rar");
            System.out.println(url);
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }
        return url;
    }
//上传获取url
public void test(){
File file = ZipUtil.zip(PathKit.getWebRootPath() + "/" + fileUuid + "/workModel");
        String url = getUrl(file, excelName);
        if (StrKit.isBlank(url)){
            re("失败");
            return;
        }
        rsPara("成功",Kv.by("url",url));
    }
/**
 * TODO
 * oss文件上传控制器
 **/
public class OssUploadController extends BaseController{

    /**
     * oss 获取文件上传签名
     */
    @Clear
    @Before(AllowCrossDomainInterceptor.class)
    public void getSign(){

        String endpoint = get("OSS-ENDPOINT");
        String accessId = get("OSS-ACCESSID");
        String accessKey = get("OSS-ACCESSKEY");
        String bucket = get("OSS-BUCKET");
        String dir = get("OSS-DIR");
        String host = "https://" + bucket + "." + endpoint;
        try {
            OSS client = new OSSClientBuilder().build(endpoint, accessId, accessKey);
            long expireTime = 30;
            long expireEndTime = System.currentTimeMillis() + expireTime * 1000;
            Date expiration = new Date(expireEndTime);
            PolicyConditions policyConds = new PolicyConditions();
            policyConds.addConditionItem(PolicyConditions.COND_CONTENT_LENGTH_RANGE, 0, 1048576000);
            policyConds.addConditionItem(MatchMode.StartWith, PolicyConditions.COND_KEY, dir);
            String postPolicy = client.generatePostPolicy(expiration, policyConds);
            byte[] binaryData = postPolicy.getBytes("utf-8");
            String encodedPolicy = BinaryUtil.toBase64String(binaryData);
            String postSignature = client.calculatePostSignature(postPolicy);

            Map<String, String> respMap = new LinkedHashMap<String, String>();
            respMap.put("code", "0");
            respMap.put("accessid", accessId);
            respMap.put("policy", encodedPolicy);
            respMap.put("signature", postSignature);
            // respMap.put("expire", formatISO8601Date(expiration));
            respMap.put("dir", dir);
            respMap.put("host", host);
            respMap.put("expire", String.valueOf(expireEndTime / 1000));
            renderJson(respMap);
        } catch (Exception e) {
            e.printStackTrace();
            rw(e.getMessage());
        }
    }

    // 上传文件流到阿里oss
    public static String uploadInputSteam(InputStream file, String fileName) {
        String endpoint = get("OSS-ENDPOINT");
        String accessId = get("OSS-ACCESSID");
        String accessKey = get("OSS-ACCESSKEY");
        String bucket = get("OSS-BUCKET");

        // 创建OSSClient实例。
        OSS ossClient = new OSSClientBuilder().build(endpoint, accessId, accessKey);

        // 上传文件流。
        ossClient.putObject(bucket, fileName, file);

         // 设置URL过期时间为24小时。
         Date expiration = new Date(System.currentTimeMillis() + 24 * 3600 * 1000);
        ossClient.setBucketAcl(bucket, CannedAccessControlList.PublicRead);
        // 生成以GET方法访问的签名URL,访客可以直接通过浏览器访问相关内容。
         URL url = ossClient.generatePresignedUrl(bucket, fileName, expiration);
        // 关闭OSSClient。
        ossClient.shutdown();
        return url.toString();
    }
/**
 * 跨域请求拦截器
 *
 */
public class AllowCrossDomainInterceptor implements Interceptor {

    @Override
    public void intercept(Invocation inv) {
        inv.getController().getResponse().addHeader("Access-Control-Allow-Origin", "*");
        inv.getController().getResponse().addHeader("Access-Control-Allow-Credentials", "true");
        inv.getController().getResponse().addHeader("Access-Control-Allow-Methods", "OPTIONS,HEAD,GET,PUT,POST,DELETE,PATCH");
        inv.getController().getResponse().addHeader("Access-Control-Allow-Headers", "Content-Type, Access-Control-Allow-Headers, Authorization, X-Requested-With, login_code,x-token,platform_code");
        inv.getController().getResponse().addHeader("Access-Control-Max-Age", "3600");
        if (StrKit.notBlank(inv.getController().getRequest().getMethod()) && inv.getController().getRequest().getMethod().equals("OPTIONS")) {
            inv.getController().renderText("");
            return;
        }
        String json = HttpKit.readData(inv.getController().getRequest());
        if (StrKit.notBlank(json)) {
            if (PropKit.getBoolean("devMode", false)) {
                System.out.println(json);
            }
            JSONObject obj = JSONObject.parseObject(json);
            inv.getController().setAttr("obj", obj);
        }
        inv.invoke();
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值