RSA加密,解密 与数字签名

package com.e

                             RSA加密算法的简单使用原理

xample.subang.advancesix;

import android.content.SharedPreferences;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Base64;
import android.util.Log;
import android.view.View;
import android.widget.TextView;

import java.security.InvalidKeyException;
import java.security.Key;
import java.security.KeyFactory;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.NoSuchAlgorithmException;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.Signature;
import java.security.SignatureException;
import java.security.spec.InvalidKeySpecException;
import java.security.spec.KeySpec;
import java.security.spec.PKCS8EncodedKeySpec;
import java.security.spec.X509EncodedKeySpec;

import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.NoSuchPaddingException;

public class MainActivity extends AppCompatActivity {
    private TextView text;
    private String data = "怒发冲冠,凭栏处,潇潇雨歇";
    private PrivateKey aPrivate;
    private PublicKey aPublic;
    private SharedPreferences sp;
    private PrivateKey privateKey1;
    private PublicKey publicKey1;
    private String s;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        text = (TextView) findViewById(R.id.text);
        sp = getSharedPreferences("config", MODE_PRIVATE);


        //从sp中获取私钥
        String privateKey = sp.getString("privateKey", null);
        byte[] decode = Base64.decode(privateKey, Base64.DEFAULT);
        KeyFactory keyFactory = null;
        try {
            keyFactory = KeyFactory.getInstance("RSA");
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
        KeySpec keySpec = new PKCS8EncodedKeySpec(decode);
        try {
            privateKey1 = keyFactory.generatePrivate(keySpec);
        } catch (InvalidKeySpecException e) {
            e.printStackTrace();
        }


        //从sp中获取公钥
        String publicKey = sp.getString("publicKey", null);
        byte[] decode1 = Base64.decode(publicKey, Base64.DEFAULT);
        KeyFactory keyFactory2 = null;
        try {
            keyFactory2 = KeyFactory.getInstance("RSA");
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
        KeySpec keySpec2 = new X509EncodedKeySpec(decode1);
        try {
            publicKey1 = keyFactory2.generatePublic(keySpec2);
        } catch (InvalidKeySpecException e) {
            e.printStackTrace();
        }

    }

    public void start(View view) throws BadPaddingException, InvalidKeyException, IllegalBlockSizeException, NoSuchAlgorithmException, InvalidKeySpecException, SignatureException {
        switch (view.getId()) {
            case R.id.btn1:
                generateRsa();
                break;

            case R.id.btn2:
                String cyrpt = cyrpt(data, privateKey1, 0);
                text.setText(cyrpt);
                break;

            case R.id.btn3:
                String trim = text.getText().toString().trim();
                String cyrpt1 = cyrpt(trim, publicKey1, 1);
                text.setText(cyrpt1);
                break;

            case  R.id.md5Rsa://数字签名,使用私钥进行
                Signature signature=Signature.getInstance("MD5withRSA");
                signature.initSign(privateKey1);
                signature.update(this.data.getBytes());
                byte[] sign = signature.sign();//签名的数据
                //将原文件和签名之后的数据一块发送给合作伙伴
                s = Base64.encodeToString(sign, Base64.DEFAULT);
                text.setText(s);
                break;

            case  R.id.md5vertify://数字验证,使用公钥
                Signature signature1=Signature.getInstance("MD5withRSA");
                signature1.initVerify(publicKey1);
                //update 将原文件上传给signature
                signature1.update(this.data.getBytes());
                //对签名进行验证 s
                boolean verify = signature1.verify(Base64.decode(s, Base64.DEFAULT));
                Log.e("flag", "--------------------->start: 验证的结果"+verify);

                break;
            default:
                break;
        }
    }

    private String cyrpt(String data, Key key, int type) throws InvalidKeyException, BadPaddingException, IllegalBlockSizeException {

        try {
            //1.加密引擎
            Cipher cipher = Cipher.getInstance("RSA");
            //2.设置密码
            switch (type) {
                case 0://加密
                    cipher.init(Cipher.ENCRYPT_MODE, key);
                    break;
                case 1://解密
                    cipher.init(Cipher.DECRYPT_MODE, key);
                    break;
                
                default:
                    break;
            }

            //3.区分加密 解密
            switch (type) {
                case 0://加密
                    byte[] bytes = cipher.doFinal(data.getBytes());
                    byte[] encode = Base64.encode(bytes, Base64.DEFAULT);
                    String result = new String(encode);
                    return result;


                case 1://解密
                    byte[] decode = Base64.decode(data, Base64.DEFAULT);
                    byte[] bytes1 = cipher.doFinal(decode);
                    String result1 = new String(bytes1);
                    return result1;


                default:
                    break;
            }
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        } catch (NoSuchPaddingException e) {
            e.printStackTrace();
        }

        return data;
    }


    private void generateRsa() {
        new Thread(new Runnable() {
            @Override
            public void run() {
                //1.获取KeyPareGenerator
                try {
                    KeyPairGenerator keypairGenerator = KeyPairGenerator.getInstance("RSA");

                    //2.初始化
                    keypairGenerator.initialize(1024);
                    //3.获取密码
                    KeyPair keyPair = keypairGenerator.generateKeyPair();
                    //4.获取公钥 ,私钥
                    aPrivate = keyPair.getPrivate();
                    aPublic = keyPair.getPublic();
                    //5.展示数据
                    final byte[] aByte = aPrivate.getEncoded();
                    final byte[] pByte = aPublic.getEncoded();

                    //将公钥 , 私钥 进行保存 保存到sp中
                    SharedPreferences sp = MainActivity.this.getSharedPreferences("config", MODE_PRIVATE);
                    SharedPreferences.Editor editor = sp.edit();
                    editor.putString("privateKey", Base64.encodeToString(aByte, Base64.DEFAULT));
                    editor.putString("publicKey", Base64.encodeToString(pByte, Base64.DEFAULT));
                    editor.commit();


                    runOnUiThread(new Runnable() {
                        @Override
                        public void run() {
                            StringBuilder builder = new StringBuilder();
                            builder.append("私钥是:" + "\n");
                            builder.append(Base64.encodeToString(aByte, Base64.DEFAULT) + "\n");
                            builder.append("公钥是:" + "\n");
                            builder.append(Base64.encodeToString(pByte, Base64.DEFAULT));
                            text.setText(builder.toString());
                        }
                    });

                } catch (NoSuchAlgorithmException e) {
                    e.printStackTrace();
                }
            }
        }).start();
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        text = null;
        data = null;
    }
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值