您好,欢迎访问一九零五行业门户网

Java公钥私钥的解析(附代码)

本篇文章给大家带来的内容是关于java公钥私钥的解析(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
在编程中,我们为了保证数据安全,免不了要经常进行数据加密,于是产生了各种各样的加密算法.无论怎样,都还是存在被破解的风险.今天就来说说rsa算法.
背景
rsa公钥加密算法是1977年由ron rivest、adi shamirh和lenadleman在(美国麻省理工学院)开发的。rsa取名来自开发他们三者的名字。rsa是目前最有影响力的公钥加密算法,它能够抵抗到目前为止已知的所有密码攻击,已被iso推荐为公钥数据加密标准。rsa算法基于一个十分简单的数论事实:将两个大素数相乘十分容易,但那时想要对其乘积进行因式分解却极其困难,因此可以将乘积公开作为加密密钥。
虽然上面的解释很深奥,但是你只要知道,这个算法非常安全就行了.
加密解密过程
假设有两个用户a,b. b在它的一侧,生成了公钥和私钥,私钥只有b自己知道,然后把公钥分享给a,当然不仅是a,b的公钥只要分享给了所有他信赖的人,那么这些人都将能解密a的数据.
过程1:
a使用b的公钥加密数据,然后b使用私钥解密数据.这时所有拥有公钥的用户是不能解密数据的,因为他们没有私钥.这个数据只有a和b能够获取,这就保证了数据的安全.
过程2:
b使用私钥加密数据,那么所有有公钥的用户都可以使用公要解密数据.其他没有公钥的人是没有办法获取到数据的,这也保证了数据的安全性.
非对称加密
通过上面的过程,我们可以看到这样一个不同于以往加密算法的现象,那就是非对称.什么是非对称?
你不能通过自己的加密密钥,反向解密,这个过程是不可逆的,正是因为如此才大大提高了它的安全性.公钥和私钥都可以进行加密解密,但他们必须配对使用.在私钥被高度保护的情况下,永远不会出现被破解的可能.
java实现
package com.mike;import java.io.fileinputstream;import java.io.fileoutputstream;import java.io.objectinputstream;import java.io.objectoutputstream;import java.security.key;import java.security.keypair;import java.security.keypairgenerator;import javax.crypto.cipher;import org.apache.commons.codec.binary.base64;/** * the class rsa.java */public class rsa {    private static string public_key_file = c:\\my\\publickey;    private static string private_key_file = c:\\my\\privatekey;    /**     * 初始化密钥     *     * @return     */    public static void productkey() {        try {            keypairgenerator keygen = keypairgenerator.getinstance(rsa);            keygen.initialize(1024);            keypair keypair = keygen.generatekeypair();// 生成密钥对            key pubkey = keypair.getpublic(); // 获取公钥            key prikey = keypair.getprivate(); // 获取私钥            objectoutputstream oos1 = null;            objectoutputstream oos2 = null;            try {                /** 用对象流将生成的密钥写入文件 */                oos1 = new objectoutputstream(new fileoutputstream(public_key_file));                oos2 = new objectoutputstream(new fileoutputstream(private_key_file));                oos1.writeobject(pubkey);                oos2.writeobject(prikey);            } catch (exception e) {                throw e;            } finally {                /** 清空缓存,关闭文件输出流 */                oos1.close();                oos2.close();            }        } catch (exception e) {            e.printstacktrace();        }    }    /**     * 公钥加密方法 私钥加密也一样     *      * @param source     *            源数据     * @return     * @throws exception     */    public static string encrypt(string source) throws exception {        key publickey;        objectinputstream ois = null;        try {            /** 将文件中的公钥对象读出 */            ois = new objectinputstream(new fileinputstream(public_key_file));            publickey = (key) ois.readobject();        } catch (exception e) {            throw e;        } finally {            ois.close();        }        /** 得到cipher对象来实现对源数据的rsa加密 */        cipher cipher = cipher.getinstance(rsa);        cipher.init(cipher.encrypt_mode, publickey);        byte[] b = source.getbytes();        /** 执行加密操作 */        byte[] b1 = cipher.dofinal(b);        return base64.encodebase64string(b1);    }    /**     * 私钥解密算法 公钥解密一样     *      * @param cryptograph     *            密文     * @return     * @throws exception     */    public static string decrypt(string cryptograph) throws exception {        key privatekey;        objectinputstream ois = null;        try {            /** 将文件中的私钥对象读出 */            ois = new objectinputstream(new fileinputstream(private_key_file));            privatekey = (key) ois.readobject();        } catch (exception e) {            throw e;        } finally {            ois.close();        }        /** 得到cipher对象对已用公钥加密的数据进行rsa解密 */        cipher cipher = cipher.getinstance(rsa);        cipher.init(cipher.decrypt_mode, privatekey);        byte[] b1 = base64.decodebase64(cryptograph);        /** 执行解密操作 */        byte[] b = cipher.dofinal(b1);        return new string(b);    }    public static void main(string[] args) throws exception {        rsa.productkey();        string msg = 我是加密信息;        string encryt = rsa.encrypt(msg);        system.out.println(加密后的字符:+encryt);        system.out.println(解密后的字符:+rsa.decrypt(encryt));    }}
这样有了密钥文件,你就可以进行加密和签名了。
本篇文章到这里就已经全部结束了,更多其他精彩内容可以关注的java教程视频栏目!
以上就是java公钥私钥的解析(附代码)的详细内容。
其它类似信息

推荐信息