JAVA-OSS内网外网转换工具类

oss路径是一个比较敏感的url路径,有的时候需要用内网、有的时候需要外网,有的时候需要/有的时候不需要/,这个工具类就是帮忙干这事儿的。

public class OSSUrlUtil {

    public static final String[] OSS_DOMAINS = new String[]{
        "https://biz.s3.url.com/",
        "http://biz.s3.url.com/",
        "https://biz.s3-internal.url.com/",
        "http://biz.s3-internal.url.com/",
        "http://s3.url.com/biz/",
        "https://s3.url.com/biz/",
        "http://s3-internal.url.com/biz/",
        "https://s3-internal.url.com/biz/"
    };

    /**
     * 去除掉oss的域名前缀
     * @param url
     * @return
     */
    public static String delOssDomainAndSign(String url) {
        if (StringUtils.isBlank(url)) {
            return null;
        }
        for (String domain: SystemConstant.OSS_DOMAINS) {
            url = url.replace(domain, "");
        }
        return StringUtils.substringBefore(url, SymbolConstant.QUESTION);
    }


    /**
     * 获取完整的oss的url访问路径 外网
     * @param url
     * @return
     */
    public static String getOuterOssDomainUrl(String url) {
        if (StringUtils.isBlank(url)) {
            return null;
        }
        for (String domain: SystemConstant.OSS_DOMAINS) {
            url = url.replace(domain, "");
        }
        return SystemConstant.OSS_OUTER_PATH_HTTPS + url;
    }

    /**
     * 获取完整的oss的url访问路径 内网
     * @param url
     * @return
     */
    public static String getInternalOssDomainUrl(String url) {
        if (StringUtils.isBlank(url)) {
            return null;
        }
        for (String domain: SystemConstant.OSS_DOMAINS) {
            url = url.replace(domain, "");
        }
        return SystemConstant.OSS_INTERNAL_PATH_HTTPS + url;
    }

    /**
     * 判断是否是OSS路径
     * @param url
     * @return
     */
    public static boolean isOssDomain(String url) {
        if (StringUtils.isBlank(url)) {
            return false;
        }
        for (String domain: SystemConstant.OSS_DOMAINS) {
            if (url.contains(domain)) {
                return true;
            }
        }
        return false;
    }
}

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
图片隐写是指将一张图片隐藏在另外一张图片里面,而 PNG 文件是一种常见的图片格式,因此可以将一张图片隐藏在 PNG 文件中。以下是一个简单的例子: 1. 首先,将要隐藏的图片命名为 image.jpg,将要隐藏图片的 PNG 文件命名为 cover.png。 2. 将 image.jpg 转换为二进制文件,并将其插入 cover.png 中。 ```bash $ xxd -p -c 99999 image.jpg > image.hex $ cat image.hex | tr -d '\n' | xxd -r -p | dd of=cover.png bs=1 seek=100000 conv=notrunc ``` 这里的 `xxd -p -c 99999 image.jpg` 将 `image.jpg` 转换为十六进制,然后 `cat image.hex | tr -d '\n' | xxd -r -p` 将十六进制转回二进制,最后使用 `dd` 命令将二进制插入到 `cover.png` 的第 100000 个字节处。注意,这个位置可以根据具体情况进行调整。 3. 查看生成的 PNG 文件,可以看到图片已经被成功隐藏。 ```bash $ file cover.png cover.png: PNG image data, 800 x 600, 8-bit/color RGB, non-interlaced $ eog cover.png ``` 可以使用 `file` 命令检查文件类型,并使用图片查看器查看图片内容。 4. 提取隐藏的图片。 ```bash $ dd if=cover.png of=image2.jpg bs=1 skip=100000 ``` 这里的 `dd` 命令将 `cover.png` 中的隐藏图片提取到 `image2.jpg` 中。同样地,提取位置可以根据具体情况进行调整。 以上是一个简单的示例,实际情况可能更加复杂。在实际的 CTF 中,可能需要使用更加高级的隐写技巧来隐藏图片,例如使用 Least Significant Bit (LSB) 算法或者 F5 算法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值