字节与字符串之间的转化

最近在研究国密bouncycastle国密加解密算法。

用的是csdn上 大神基于140的版本,我下载了163的最新版,发现好多ECPoint.getX()和ECPoint.getY()方法不存在,改成了ECPoint.getAffientX()(PS:这个函数什么意思,我也没有搞清楚……^_^)结果,运行测试用例失败,改成了140版本,结果成功了。

在测试用例中,发现加密后的byte字节,先转换成string,再转换成byte进行解密,出来的数据跟明文不一样,研究了半天,才发现问题出在这里。查阅了大神的方法,改成由BASE64Encoder转换成字符串。再由BASE64解码成字节。最后成功。可能是编码不同导致的。

正确代码如下:

        // 国密规范正式私钥
		String prik = "3690655E33D5EA3D9A4AE1A1ADD766FDEA045CDEAA43A9206FB8C430CEFE0D94";
		// 国密规范正式公钥
		String pubk = "04F6E0C3345AE42B51E06BF50B98834988D54EBC7460FE135A48171BC0629EAE205EEDE253A530608178A98F1E19BB737302813BA39ED3FA3C51639D7A20C7391A";

		System.out.println("加密: ");

		byte[] cipherText = SM2Utils.encrypt(Util.hexToByte(pubk), sourceData);

		String data = new sun.misc.BASE64Encoder().encodeBuffer((cipherText));

		System.out.prin
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值