All Downloads are FREE. Search and download functionalities are using the official Maven repository.

cn.hutool.crypto.asymmetric.AsymmetricEncryptor Maven / Gradle / Ivy

package cn.hutool.crypto.asymmetric;

import cn.hutool.core.codec.BCD;
import cn.hutool.core.codec.Base64;
import cn.hutool.core.io.IORuntimeException;
import cn.hutool.core.io.IoUtil;
import cn.hutool.core.util.CharsetUtil;
import cn.hutool.core.util.HexUtil;
import cn.hutool.core.util.StrUtil;

import java.io.InputStream;
import java.nio.charset.Charset;

/**
 * 非对称加密器接口,提供:
 * 
    *
  • 加密为bytes
  • *
  • 加密为Hex(16进制)
  • *
  • 加密为Base64
  • *
  • 加密为BCD
  • *
* * @author looly * @since 5.7.12 */ public interface AsymmetricEncryptor { /** * 加密 * * @param data 被加密的bytes * @param keyType 私钥或公钥 {@link KeyType} * @return 加密后的bytes */ byte[] encrypt(byte[] data, KeyType keyType); /** * 编码为Hex字符串 * * @param data 被加密的bytes * @param keyType 私钥或公钥 {@link KeyType} * @return Hex字符串 */ default String encryptHex(byte[] data, KeyType keyType) { return HexUtil.encodeHexStr(encrypt(data, keyType)); } /** * 编码为Base64字符串 * * @param data 被加密的bytes * @param keyType 私钥或公钥 {@link KeyType} * @return Base64字符串 * @since 4.0.1 */ default String encryptBase64(byte[] data, KeyType keyType) { return Base64.encode(encrypt(data, keyType)); } /** * 加密 * * @param data 被加密的字符串 * @param charset 编码 * @param keyType 私钥或公钥 {@link KeyType} * @return 加密后的bytes */ default byte[] encrypt(String data, String charset, KeyType keyType) { return encrypt(StrUtil.bytes(data, charset), keyType); } /** * 加密 * * @param data 被加密的字符串 * @param charset 编码 * @param keyType 私钥或公钥 {@link KeyType} * @return 加密后的bytes */ default byte[] encrypt(String data, Charset charset, KeyType keyType) { return encrypt(StrUtil.bytes(data, charset), keyType); } /** * 加密,使用UTF-8编码 * * @param data 被加密的字符串 * @param keyType 私钥或公钥 {@link KeyType} * @return 加密后的bytes */ default byte[] encrypt(String data, KeyType keyType) { return encrypt(StrUtil.utf8Bytes(data), keyType); } /** * 编码为Hex字符串 * * @param data 被加密的字符串 * @param keyType 私钥或公钥 {@link KeyType} * @return Hex字符串 * @since 4.0.1 */ default String encryptHex(String data, KeyType keyType) { return HexUtil.encodeHexStr(encrypt(data, keyType)); } /** * 编码为Hex字符串 * * @param data 被加密的bytes * @param charset 编码 * @param keyType 私钥或公钥 {@link KeyType} * @return Hex字符串 * @since 4.0.1 */ default String encryptHex(String data, Charset charset, KeyType keyType) { return HexUtil.encodeHexStr(encrypt(data, charset, keyType)); } /** * 编码为Base64字符串,使用UTF-8编码 * * @param data 被加密的字符串 * @param keyType 私钥或公钥 {@link KeyType} * @return Base64字符串 * @since 4.0.1 */ default String encryptBase64(String data, KeyType keyType) { return Base64.encode(encrypt(data, keyType)); } /** * 编码为Base64字符串 * * @param data 被加密的字符串 * @param charset 编码 * @param keyType 私钥或公钥 {@link KeyType} * @return Base64字符串 * @since 4.0.1 */ default String encryptBase64(String data, Charset charset, KeyType keyType) { return Base64.encode(encrypt(data, charset, keyType)); } /** * 加密 * * @param data 被加密的数据流 * @param keyType 私钥或公钥 {@link KeyType} * @return 加密后的bytes * @throws IORuntimeException IO异常 */ default byte[] encrypt(InputStream data, KeyType keyType) throws IORuntimeException { return encrypt(IoUtil.readBytes(data), keyType); } /** * 编码为Hex字符串 * * @param data 被加密的数据流 * @param keyType 私钥或公钥 {@link KeyType} * @return Hex字符串 * @since 4.0.1 */ default String encryptHex(InputStream data, KeyType keyType) { return HexUtil.encodeHexStr(encrypt(data, keyType)); } /** * 编码为Base64字符串 * * @param data 被加密的数据流 * @param keyType 私钥或公钥 {@link KeyType} * @return Base64字符串 * @since 4.0.1 */ default String encryptBase64(InputStream data, KeyType keyType) { return Base64.encode(encrypt(data, keyType)); } /** * 分组加密 * * @param data 数据 * @param keyType 密钥类型 * @return 加密后的密文 * @since 4.1.0 * @deprecated 由于对于ASCII的编码解码有缺陷,且这种BCD实现并不规范,因此会在6.0.0中移除 */ @Deprecated default String encryptBcd(String data, KeyType keyType) { return encryptBcd(data, keyType, CharsetUtil.CHARSET_UTF_8); } /** * 分组加密 * * @param data 数据 * @param keyType 密钥类型 * @param charset 加密前编码 * @return 加密后的密文 * @since 4.1.0 * @deprecated 由于对于ASCII的编码解码有缺陷,且这种BCD实现并不规范,因此会在6.0.0中移除 */ @Deprecated default String encryptBcd(String data, KeyType keyType, Charset charset) { return BCD.bcdToStr(encrypt(data, charset, keyType)); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy