com.aliyuncs.v5.auth.SHA256withRSASigner Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aliyun-java-sdk-core-v5 Show documentation
Show all versions of aliyun-java-sdk-core-v5 Show documentation
Aliyun Open API SDK for Java
Copyright (C) Alibaba Cloud Computing
All rights reserved.
版权所有 (C)阿里云计算有限公司
http://www.aliyun.com
The newest version!
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package com.aliyuncs.v5.auth;
import javax.xml.bind.DatatypeConverter;
import java.io.UnsupportedEncodingException;
import java.security.*;
import java.security.spec.InvalidKeySpecException;
import java.security.spec.PKCS8EncodedKeySpec;
/**
* Created by haowei.yao on 2017/9/28.
*/
public class SHA256withRSASigner extends Signer {
public static final String ENCODING = "UTF-8";
private static final String ALGORITHM_NAME = "SHA256withRSA";
@Override
public String signString(String stringToSign, String accessKeySecret) {
try {
Signature rsaSign = Signature.getInstance("SHA256withRSA");
KeyFactory kf = KeyFactory.getInstance("RSA");
byte[] keySpec = DatatypeConverter.parseBase64Binary(accessKeySecret);
PrivateKey privateKey = kf.generatePrivate(new PKCS8EncodedKeySpec(keySpec));
rsaSign.initSign(privateKey);
rsaSign.update(stringToSign.getBytes(ENCODING));
byte[] sign = rsaSign.sign();
String signature = new String(DatatypeConverter.printBase64Binary(sign));
return signature;
} catch (NoSuchAlgorithmException e) {
throw new IllegalArgumentException(e.toString());
} catch (InvalidKeySpecException e) {
throw new IllegalArgumentException(e.toString());
} catch (InvalidKeyException e) {
throw new IllegalArgumentException(e.toString());
} catch (SignatureException e) {
throw new IllegalArgumentException(e.toString());
} catch (UnsupportedEncodingException e) {
throw new IllegalArgumentException(e.toString());
}
}
@Override
public String signString(String stringToSign, AlibabaCloudCredentials credentials) {
return signString(stringToSign, credentials.getAccessKeySecret());
}
@Override
public String getSignerName() {
return ALGORITHM_NAME;
}
@Override
public String getSignerVersion() {
return "1.0";
}
@Override
public String getSignerType() {
return "PRIVATEKEY";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy