importjava.io.ByteArrayOutputStream;importjava.nio.charset.Charset;importjava.security.MessageDigest;import java.util.*;importjavax.crypto.Cipher;importjavax.crypto.spec.IvParameterSpec;importjavax.crypto.spec.SecretKeySpec;importorg.apache.commons.codec.binary.Base64;/*** 加解密方法
* 在ORACLE官方网站下载JCE无限制权限策略文件
* JDK6的下载地址:http://www.oracle.com/technetwork/java/javase/downloads/jce-6-download-429243.html* JDK7的下载地址:http://www.oracle.com/technetwork/java/javase/downloads/jce-7-download-432124.html
*/
public classDingTalkEncryptor {private static final Charset CHARSET = Charset.forName("utf-8");private static final Base64 base64 = newBase64();private byte[] aesKey;privateString token;privateString corpId;/**ask getPaddingBytes key固定长度**/
private static final Integer AES_ENCODE_KEY_LENGTH = 43;/**加密随机字符串字节长度**/
private static final Integer RANDOM_LENGTH = 16;/*** 构造函数
*@paramtoken 钉钉开放平台上,开发者设置的token
*@paramencodingAesKey 钉钉开放台上,开发者设置的EncodingAESKey
*@paramcorpId ISV进行配置的时候应该传对应套件的SUITE_KEY(第一次创建时传的是默认的CREATE_SUITE_KEY),普通企业是Corpid
*@throwsDingTalkEncryptException 执行失败,请查看该异常的错误码和具体的错误信息*/
public DingTalkEncryptor(String token, String encodingAesKey, String corpId) throwsDingTalkEncryptException{if (null==encodingAesKey || encodingAesKey.length() !=AES_ENCODE_KEY_LENGTH) {throw newDingTalkEncryptException(DingTalkEncryptEx