简单的验证公钥私钥签名认证;

公钥是对外公开的部分,私钥是不公开的部分,一般在项目开发中公钥是给用户,私钥是存于服务器上,二者中有一个加密,则需要另外一个来解密。

下面是java实现的一个比较简单的示例:示例中注释写的很详细,可以大致看下,供参考

import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.NoSuchAlgorithmException;
import java.security.Signature;
/**
*
* @since 2015年8月20日 下午2:22:08
* @author hym
*/
public class SignDemo { /**得到产生的私钥/公钥对
* @return
* @author hym
*/
public static KeyPair getKeypair(){
//产生RSA密钥对(myKeyPair)
KeyPairGenerator myKeyGen = null;
try {
myKeyGen = KeyPairGenerator.getInstance("RSA");
myKeyGen.initialize(1024);
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
KeyPair myKeyPair = myKeyGen.generateKeyPair();
return myKeyPair;
}
/**根据密钥对对信息进行加密,返回公钥值
* @param mySig
* @param myKeyPair
* @param infomation
* @return
* @author hym
*/
public static byte[] getpublicByKeypair(Signature mySig,KeyPair myKeyPair,byte[] infomation){
byte[] publicInfo=null;
try {
mySig.initSign(myKeyPair.getPrivate()); //用私钥初始化签名对象
mySig.update(infomation); //将待签名的数据传送给签名对象
publicInfo = mySig.sign(); //返回签名结果字节数组
} catch (Exception e) {
e.printStackTrace();
}
return publicInfo;
} /**公钥验证签名
* @param mySig
* @param myKeyPair
* @param infomation
* @param publicInfo
* @return
* @author hym
*/
public static boolean decryptBypublic(Signature mySig, KeyPair myKeyPair,String infomation,byte[] publicInfo){
boolean verify=false;
try {
mySig.initVerify(myKeyPair.getPublic()); //使用公钥初始化签名对象,用于验证签名
mySig.update(infomation.getBytes()); //更新签名内容
verify= mySig.verify(publicInfo); //得到验证结果
} catch (Exception e) {
e.printStackTrace();
}
return verify;
} public static void main(String[] args) {
try {
KeyPair keyPair=getKeypair();
Signature mySig = Signature.getInstance("MD5WithRSA");//用指定算法产生签名对象
byte[] publicinfo=getpublicByKeypair(mySig,keyPair,"验证我".getBytes());
boolean verify=decryptBypublic(mySig, keyPair, "验证我", publicinfo);
System.out.println("验证签名的结果是:"+verify);
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
}
}

步骤:

1.首先获得公钥/私钥对

2.根据获得公钥/私钥对,根据指定的算法来加密指定的内容,根据私钥加密获得相对应的公钥,公开,给用户;

3.用户根据内容来验证自己是否是跟传来的公钥是一对。。。

怀有希望!!

最新文章

  1. Oracle函数组的使用
  2. java复杂枚举
  3. Apache本地配置多域名
  4. 轻量级SaaS在线作图工具(继之前介绍后完整介绍)
  5. 手把手教你如何用ZBrush刻画脸部
  6. 浅谈SQL中的单引号
  7. zoj 3778 Talented Chef(思维题)
  8. 【HDOJ】3436 Queue-jumpers
  9. ios蓝牙开发(二)ios连接外设的代码实现
  10. 值集&快速编码(Lookup_code)
  11. 使用yum安装不知道到底安装在什么文件夹
  12. 从.Net到Java学习第五篇——Spring Boot &&Profile &&Swagger2
  13. redis 初步认识四(redis锁,防并发)
  14. 用R语言做数据清理
  15. 使用python脚本实现iOS图片资源压缩
  16. js对象属性名驼峰式转下划线
  17. Java Swing 中使用 EventQueue
  18. Struts2_learning
  19. logstash获取日志,时间戳相差8小时
  20. Unity3D 中鼠标按下时OnMouseDown()、Input.GetMouseButtonDown()和EventType.MouseDown的响应验证

热门文章

  1. oracle 创建包体的一些问题
  2. 二 random模块
  3. 如何修改Eclipse的 workspace目录
  4. hdoj1004(查找众多字符串中个数最多的字符串)
  5. DHCP server 冒充及DOS攻击处理方案
  6. 项目的发布(nginx、uwsgi、django、virtualenv、supervisor)
  7. nexus(Maven仓库私服)的安装、配置、使用和仓库迁移
  8. 155. Min Stack (stack)
  9. HDU 6214 Smallest Minimum Cut(最少边最小割)
  10. 【c++】c++ 11之lamba表达式