加入收藏 | 设为首页 | 会员中心 | 我要投稿 应用网_丽江站长网 (http://www.0888zz.com/)- 科技、建站、数据工具、云上网络、机器学习!
当前位置: 首页 > 运营中心 > 建站资源 > 策划 > 正文

循序渐进学加密

发布时间:2019-06-26 05:48:36 所属栏目:策划 来源:张京
导读:副标题#e# 还记得上初二的那年夏天,班里来了一个新同学,他就住在我家对面的楼里,于是我们一起上学放学,很快便成了最要好的朋友。我们决定发明一套神秘的沟通方式,任何人看到都不可能猜到它的真实含义。我们第一个想到的就是汉语拼音,但很显然光把一个

对于私钥,因为Java只支持PKCS8,而我们用ssh-keygen生成的私钥是pkcs1的,所以还需要用以下命令把pkcs1的私钥转换为pkcs8的私钥:

  1. openssl pkcs8 -topk8 -inform PEM -outform PEM -nocrypt -in 私钥文件名 -out 导出文件名 

得到pkcs8格式的私钥之后,我们把这个文件的头和尾去掉,然后放入以下Java代码:

  1. try { 
  2.     Cipher cipher = Cipher.getInstance("RSA/ECB/OAEPWithSHA-256AndMGF1Padding"); 
  3.     cipher.init(Cipher.DECRYPT_MODE, KeyFactory.getInstance("RSA").generatePrivate(new PKCS8EncodedKeySpec(Base64.getDecoder().decode("这里是私钥")))); 
  4.     String plaintext = new String(cipher.doFinal(Base64.getDecoder().decode("这里是密文".getBytes())), "UTF-8"); 
  5.     System.out.println(plaintext); 
  6. } catch (Exception e) { 
  7.     System.out.println("解密出错:" + e.toString()); 

和上面的AES解密类似,只是增加了KeyFactory读取PKCS8格式私钥的部分,这样我们就完成了Java端的RSA解密。

以上我们用最简单的方式实现了js端加密,java端解密的过程,感兴趣的朋友可以在这里下载完整的代码亲自验证一下:

https://github.com/fengerzh/encdec

(编辑:应用网_丽江站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

推荐文章
    热点阅读