SHA1withRSA简介

因工作中对接金融机构,对数据的安全性较高故仅作为日志,部分涉及私密的信息就不贴出来。

SHA1withRSA:浅显的理解,用SHA算法进行签名,用RSA算法进行加密。

注:SHA1安全哈希算法(Secure Hash Algorithm)主要适用于数字签名标准 (Digital Signature Standard DSS)里面定义的数字签名算法(Digital Signature Algorithm DSA)

附网络上的图示:(图中所示加了一层RSA加密,此次接口不涉及。)

注:RSA对明文有长度限制,详情移步https://blog.csdn.net/lvxiangan/article/details/45487943 。

  • 生成密钥、公钥证书

** 使用OpenSSL工具,或者直接在unix、Linux系统上执行。**

① openssl genrsa -out rsa_private_key.pem 1024
② pkcs8 -topk8 -inform PEM -in rsa_private_key.pem -outform PEM -nocrypt(java需使用pkcs8 )
③ openssl rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem

注:顺序执行,步骤②需注意,转换的pkcs8证书将在控制台输出,注意复制保存下来。(方便测试可以暂时使用网上快速生成的密钥对)

  • Java代码实现

主要有以下步骤:(前提:已生成一对公钥、私钥。)

  1. 所需签名的内容使用私钥进行SHA1WithRSA签名。(SignatureUtil.sign方法)
  2. 获取报文,通过签名信息、报文原文及公钥进行验签。(SignatureUtil.virefy方法)
  3. 拼装接口信息(json),对PLAIN内所有内容签名,存放于SIGNATURE处。

报文示例:

{"IASPDB": {"PLAIN": {"BODY": {"param1": "value1","param2": "value2","param3": "value3"},"HEAD": {"orgId": "1","timeStamp": 1527818279919,"subOrgId": "subOrgId","transId": "1","channel": "1","openId": ""}},"SIGNATURE": "Hg6Rc1y4i+2Ms/EWgasRwUW2TNpPZv6KxpeoqoQgSbYyxn0UezhI4CVGCcp4zwhTFV98x7+r0h8kfuPALloYFK1vn1EOGHxRUgvX1xt40jTRXEtZXrX5J0ii0AWihknxdTkQE+Ks/x3QiixnsKieLb0BnqInPbt4eQuudQo2YsE="}
}
package com.test.sample;import java.io.ByteArrayInputStream;
import java.io.InputStreamReader;
import java.io.StringWriter;
import java.security.KeyFactory;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.Signature;
import java.security.spec.PKCS8EncodedKeySpec;
import java.security.spec.X509EncodedKeySpec;
import java.util.Map;
import java.util.TreeMap;import org.apache.commons.codec.binary.Base64;
import org.junit.Test;import com.test.sample.util.StreamUtil;public class SignatureUtil {private final static String SIGN_TYPE_RSA = "RSA";private final static String SIGN_ALGORITHMS = "SHA1WithRSA";private final static String CHARSETTING = "UTF-8";/*** 获取私钥PKCS8格式(需base64)* @param algorithm* @param priKey* @return PrivateKey* @throws Exception*/public static PrivateKey getPrivateKeyFromPKCS8(String algorithm, String priKey) throws Exception {if (algorithm == null || "".equals(algorithm) || priKey == null || "".equals(priKey))return null;KeyFactory keyFactory = KeyFactory.getInstance(algorithm);byte[] encodedKey = StreamUtil.readText(new ByteArrayInputStream(priKey.getBytes())).getBytes();encodedKey = Base64.decodeBase64(priKey.getBytes());return keyFactory.generatePrivate(new PKCS8EncodedKeySpec(encodedKey));}/*** 通过证书获取公钥(需BASE64,X509为通用证书标准)* @param algorithm* @param pubKey* @return PublicKey* @throws Exception*/public static PublicKey getPublicKeyFromX509(String algorithm, String pubKey) throws Exception {if (algorithm == null || "".equals(algorithm) || pubKey == null || "".equals(pubKey))return null;KeyFactory keyFactory = KeyFactory.getInstance(algorithm);StringWriter writer = new StringWriter();StreamUtil.io(new InputStreamReader(new ByteArrayInputStream(pubKey.getBytes())), writer);byte[] encodeByte = writer.toString().getBytes();encodeByte = Base64.decodeBase64(pubKey.getBytes());return keyFactory.generatePublic(new X509EncodedKeySpec(encodeByte));}/*** 使用私钥对字符进行签名* @param plain  内容体* @param prikey  私钥* @return String* @throws Exception*/public static String sign(String plain, String prikey) throws Exception {if (plain == null || "".equals(plain) || prikey == null || "".equals(prikey))return null;PrivateKey privatekey = getPrivateKeyFromPKCS8(SIGN_TYPE_RSA, prikey);Signature signature = Signature.getInstance(SIGN_ALGORITHMS);signature.initSign(privatekey);signature.update(plain.getBytes(CHARSETTING));byte[] signed = signature.sign();return new String(Base64.encodeBase64(signed));}/*** 将内容体、签名信息、及对方公钥进行验签* @param plain  内容体* @param sign   签名信息* @param pubkey  对方公钥* @return boolean* @throws Exception*/public static boolean virefy(String plain, String sign, String pubkey) throws Exception {if (plain == null || "".equals(plain) || sign == null || "".equals(sign) || pubkey == null || "".equals(pubkey))return false;PublicKey publicKey = getPublicKeyFromX509(SIGN_TYPE_RSA, pubkey);Signature signature = Signature.getInstance(SIGN_ALGORITHMS);signature.initVerify(publicKey);signature.update(plain.getBytes(CHARSETTING));return signature.verify(Base64.decodeBase64(sign.getBytes()));}/*** 测试* @param args* @throws Exception*/@Testpublic static void main(String[] args) throws Exception {//**  私钥密钥此处简单演示,应做成可配置    **/String privateKey = "MIICdgIBADANBgkqhkiG9w0BAQEFAASCAmAwggJcAgEAAoGBAMwJf6SDuNirQKl6/pgC3WQDV10mP2Mwwivqzcb0BH4jE8wIeaOGQ5eBw8ncuz1xAFLA6RE0U7I/RxBehIGCKSMYFYfv1Mzd0y3UIXqkJUCyNgrJTu3vlEvydG3PVOeVn0jb6F55TJj1cO/Es14nwVhskjPk/Ft7ftrqoEBmgoidAgMBAAECgYAg1taIb/rsRIPfwz/+z1c6pZ8GCwXgvRRDZUNBZjzi4FprWGHbg9yVIfmVH8WzGeDncM0SS828vpp9c/j3ry9XgRDh70e2LKovEy9rXNenLyNjdQGCaH9WEcNaMrAwW/p2+a1DOZjtRc01yuLW/jNIlI4Sy8LmZ5bRqcp3bcjDsQJBAOgkUqBc+/rFoSxPs9+HoOU0NDpuKAQyUgTJEvlyYpzQ/ZixOy9gOygm0iCAddKgnzJMi4W9o0YlT5o3lX7aKUsCQQDhAbxxHWYv1aM98RJKOMHnvSO6Jvnn2HLdCL8qrMKdGADMexJsrJy9mXCkeYlEFWUQLAtZYQiHvbNL18trroy3AkBZC83SC7jweayYZb5WqRzzrrG2FBkveunxQfwQSWtAQf50+s78Hkqy3SlPJFeNwuUuEySV2aduudMuEdI7hY2/AkArE80DDvDYaZtWKYgp45HkDwb/BaVEqODcxmbrAaZEsyq7+zf8zFM5zV2Ob6JDAaGWpggKNZSPgFcKRycv13wjAkEAxO1AqU/hwfyZ8hSaROhqtnRrM05zQpDSPhSvHB1nv+qMw5pvJEK/YGDxm3zeEzef/vQhti8IFSo86cF9WMxWxw==";String publicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDMCX+kg7jYq0Cpev6YAt1kA1ddJj9jMMIr6s3G9AR+IxPMCHmjhkOXgcPJ3Ls9cQBSwOkRNFOyP0cQXoSBgikjGBWH79TM3dMt1CF6pCVAsjYKyU7t75RL8nRtz1TnlZ9I2+heeUyY9XDvxLNeJ8FYbJIz5Pxbe37a6qBAZoKInQIDAQAB";String plain = "plain:\"PLAIN\":{\"BODY\":{\"returnCode\":\"AAAAAAA\",\"status\":\"00\",\"returnMsg\":\"交易成功\",\"mobileNo\":\"15555524587\"},\"HEAD\":{\"spdbJnlNo\":\"997907074816\",\"timeStamp\":\"1435152316796\",\"transId\":\"MiguRepay\",\"jnlNo\":\"Y000Y021120140605\",\"version\":\"1.0\"}}";System.out.println(plain);String sign = sign(plain, privateKey);//签名信息System.out.println(sign);//签名信息//String sign = "BYyaHBgXhAZcjW0VUW1Cx7IpACMCkdmLkF5WkkgVEJboNtDzbQ0hRJ6v6xYDCrHKwTTigq9VpVKnyWAdvYkXlQyTs5vK0wx9aPlLaPFj6e8PZfd3+GM+Azwt15vgoaLs6GxcAZJ7FQMVkRqZWRv1MNorMh0rPLNwbdZgVF3m1+g=";//验签结果(接收方使用对方公钥验签)System.out.println(virefy(plain, sign, publicKey));//组装报文BODY内的内容Map<String, String> dataMap = new TreeMap();dataMap.put("param1", "value1");dataMap.put("param2", "value2");dataMap.put("param3", "value3");//生成最终报文(Json)String body = JsonHelper.preparePostData("1", "1", "subOrgId", dataMap);System.out.println(body);}}

备注:有人需要故补充 StreamUtil类

package com.test.sample.util;import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.Reader;
import java.io.StringWriter;
import java.io.Writer;public class StreamUtil {private static final int DEFAULT_BUFFER_SIZE = 8192;public static void io(InputStream in, OutputStream out) throws IOException {io(in, out, -1);}public static void io(InputStream in, OutputStream out, int bufferSize) throws IOException {if (bufferSize == -1) {bufferSize = DEFAULT_BUFFER_SIZE;}byte[] buffer = new byte[bufferSize];int amount;while ((amount = in.read(buffer)) >= 0) {out.write(buffer, 0, amount);}}public static void io(Reader in, Writer out) throws IOException {io(in, out, -1);}public static void io(Reader in, Writer out, int bufferSize) throws IOException {if (bufferSize == -1) {bufferSize = DEFAULT_BUFFER_SIZE >> 1;}char[] buffer = new char[bufferSize];int amount;while ((amount = in.read(buffer)) >= 0) {out.write(buffer, 0, amount);}}public static String readText(InputStream in) throws IOException {return readText(in, null, -1);}public static String readText(InputStream in, String encoding) throws IOException {return readText(in, encoding, -1);}public static String readText(InputStream in, String encoding, int bufferSize)throws IOException {Reader reader = (encoding == null) ? new InputStreamReader(in) : new InputStreamReader(in,encoding);return readText(reader, bufferSize);}public static String readText(Reader reader) throws IOException {return readText(reader, -1);}public static String readText(Reader reader, int bufferSize) throws IOException {StringWriter writer = new StringWriter();io(reader, writer, bufferSize);return writer.toString();}
}

部分代码就不全贴上来啦!!

签名算法:SHA1withRSA相关推荐

  1. 使用RSA私钥或pfx私钥签名String

    项目有个需求,使用私钥签名请求body内容,放在请求头部,作为头部一个字段内容请求外部服务,签名有二种方式,对方提供私钥串/直接提供pfx私钥文件. 一. 提供私钥串  示例代码如下: public ...

  2. MD5及公私钥数据加密工具类

    加签验签代码如下: package com.allinpay.ets.pswd.util;import java.io.BufferedReader; import java.io.ByteArray ...

  3. java生成sm2证书_(转载)Java使用IText实现PDF签章

    前文讲到了如何使用Adobe的PDF工具软件进行电子印章应用.在实际应用中还有一种情形就是需要将电子印章功能集成在我们开发的系统里,这里就要用到一些PDF的二次开发库了.做过相关开发的同学应该知道常用 ...

  4. Java使用Itext5.5.10进行pdf签章

    原文地址 :   http://blog.csdn.net/liumengya007007/article/details/53129323 啰嗦 说到PDF数字签名签章,这个其实也是数字证书信息安全 ...

  5. php pfx rsa pem,使用RSA私钥或pfx私钥签名String

    /** * @param algorithm 签名算法: SHA1WithRSA / MD5withRSA等 * @param password 密码 * @param privateKeyPath ...

  6. RSA签名算法,计算调用加密报文,安全传输

    RSA签名算法 1. 获取当前的时间戳参数 2. 计算参数签名 3. 获取请求对象的MD5密文 4. 通过私钥计算某个参数的RSA签名 5. 转换字符集到utf8 6. MD5加密字符串 7. bas ...

  7. java rsa数字签名_RSA 数字签名算法(Java版)

    数字签名算法Java版 还是上代码吧 public static final String SIGN_ALGORITHMS = "SHA1WithRSA"; /** * RSA签名 ...

  8. RSA签名算法 - Java加密与安全

    RSA签名算法在非对称加密中我们可以看到,甲乙双方要进行通信,用publicKey进行加密,用priavteKey解密,这个时候会出现一个问题,如果黑客用你的publicKey对消息进行加密,然后冒充 ...

  9. .NET Core加解密实战系列之——消息摘要与数字签名算法

    简介 加解密现状,编写此系列文章的背景: 需要考虑系统环境兼容性问题(Linux.Windows) 语言互通问题(如C#.Java等)(加解密本质上没有语言之分,所以原则上不存在互通性问题) 网上资料 ...

最新文章

  1. python 时间time()及日期date()函数
  2. 对象测试_测试|你挑恋爱对象的眼光准不准?
  3. 如果太阳系毁灭,这种神秘粒子就是真凶!
  4. 阿里云数据库开源发布:PolarDB三节点高可用的功能特性和关键技术
  5. 此图片来自微信公众平台未经允许不可引用
  6. Emacs之删除整列操作
  7. mysql 5个约束条件,Mysql入门第五课《外键约束》
  8. 用文本文档制作bat文件
  9. vmware 官方下载
  10. Springboot毕设项目监狱管理系统xu08n(java+VUE+Mybatis+Maven+Mysql)
  11. 微众银行“梦见”区块链
  12. 在线FLV播放器实现方法
  13. error CS0227: Unsafe code may only appear if compiling
  14. PHP C#-QQ网站bkn算法
  15. 接待员如何向客人upsell_前厅部接待员办理入住操作步骤
  16. mpa和pis_有关压力单位pis
  17. JS事件对象 (event)
  18. 如何将二维码巧妙放进海报里?
  19. mysql连接出错 mysqladmin flush-hosts 解决方法(mysqladmin 刷新主机解除阻塞)
  20. 【MFC】MFC中SQLite使用经验总结

热门文章

  1. 好用的三维绘图软件CREO学习删除段和分割及拐角
  2. 【报告分享】2021年职场心理健康数据洞察报告-贝智(附下载)
  3. 时间段优化oracle,九大Oracle性能优化基本方法详解
  4. Java虚拟机如何设置环境变量_Java虚拟机配置环境变量的方法
  5. artDialog——经典、优雅的网页对话框控件
  6. java 对象数组与基本类型数组区别
  7. python数字华容道算法_pyqt 简单实现3X3数字华容道
  8. sm是什么? 什么是sm? 天使人间解答 希望可以帮助大家正确的理解SM
  9. 江夏区2022年瞪羚企业认定公示 申报条件、材料
  10. x10max能升级鸿蒙系统吗,3部能直接升级鸿蒙2.0的荣耀旗舰,第一没有意外,第三实力最强...