加密算法

MD5:登錄注冊,
SHA1

對稱加密

  • 1.DES:Data Encryption Standard,數據加密標準
  • 2.AES:Advanced Encryption Standard ,更高級的方式

對稱加密特點:加密速度快,只有一把鑰匙,鑰匙泄露文件就暴露

非對稱加密

  • 加密算法:RSA
  • 特點:
    • 秘鑰對:私鑰和公鑰,秘鑰對不是指定的,系統生成的
    • 私鑰自己保留,公鑰可以給別人
    • 公鑰加密、使用解密
    • 私鑰加密、公鑰解密
    • 公鑰互換:兩個組織或者兩個人互換公鑰
    • 數字簽名:驗證所屬關系(驗證私鑰在哪里,舉例:比如使用支付寶支付,支付寶它會有我們的公鑰)

我們來看看本地keystore涉及的算法

搜狗截圖20170709152342.png
搜狗截圖20170709152529.png
下面我們通過簡單的Demo來了解對稱加密
public class MainActivity  extends AppCompatActivity  {
private TextView mTv_result;
private String   data;
private String   key;
private boolean  isDes;
private String mDesEncrypt;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    mTv_result = (TextView) findViewById(R.id.tv_result);
    data = "我的微信密碼: 123456789";//要加密的內容
    key = "123456789";//解密/加密的key
}

public void des(View view) {
    try {
        if (!isDes) {
            //加密
            mDesEncrypt = Des.encrypt(data, key);
            mTv_result.setText("DES加密:" + mDesEncrypt);
        } else {
            String desDecrypt = Des.decrypt(mDesEncrypt, key);//解密
            mTv_result.setText("DES解密:" + desDecrypt);
        }
        isDes = !isDes;
    } catch (Exception e) {
        e.printStackTrace();
    }
 }
}
GIF.gif

AES 加密解密

   public void aes(View view) {
    if (!isAes) {
        //加密
        mAesEncrypt = Aes.encrypt(data, key);
        mTv_result.setText("AES加密:" + mAesEncrypt);
    } else {
        //解密
        String aesEecrypt = Aes.decrypt(mAesEncrypt, key);
        mTv_result.setText("AES解密:" + aesEecrypt);
    }
    isAes = !isAes;
 }

非對稱加密(RSA)

 /**
 * 初始化秘鑰對
 */
private void initKeyPair() {
    // 初始化秘鑰對: 公鑰和私鑰
    try {
        Map<String, Object> keyPair = RSACrypt.genKeyPair();
        privateKey = RSACrypt.getPrivateKey(keyPair);
        publicKey = RSACrypt.getPublicKey(keyPair);

        Log.e("result", "privateKey=" + privateKey);
        Log.e("result", "publicKey=" + publicKey);
    } catch (Exception e) {
        e.printStackTrace();
    }
}


public void rsa(View view) {
    try {
        if (!isRsa) {
            //私鑰加密
            encryptByPrivateKey = RSACrypt.encryptByPrivateKey(data.getBytes(), privateKey);
            mTv_result.setText("RSA加密:"+RSACrypt.encode(encryptByPrivateKey));
        }else {
            //公鑰解密
            byte[] decryptByPublicKey = RSACrypt.decryptByPublicKey(encryptByPrivateKey, publicKey);
            mTv_result.setText("RSA解密:"+new String(decryptByPublicKey));
        }
        isRsa=!isRsa;
    } catch (Exception e) {
        e.printStackTrace();
    }
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 最近公司用到RSA數據加密傳輸,本人也只會使用,并不知其原理,剛好今天在csdn看到一位大牛的博客寫得很到位,遂搬...
    爸比好酷閱讀 1,428評論 0 1
  • 數據傳輸加密 在開發應用過程中,客戶端與服務端經常需要進行數據傳輸,涉及到重要隱私信息時,開發者自然會想到對其進行...
    chaychan閱讀 7,020評論 8 93
  • 作者簡介 原創微信公眾號郭霖 WeChat ID: guolin_blog 大家早上好,轉眼假期就結束了,又到了...
    木木00閱讀 1,223評論 0 9
  • 概述 之前一直對加密相關的算法知之甚少,只知道類似DES、RSA等加密算法能對數據傳輸進行加密,且各種加密算法各有...
    Henryzhu閱讀 3,060評論 0 14
  • 故事里說,王子愛上了巫婆卻拋棄了白雪公主,王后善妒的嘴臉從此徹底暴露無遺,她瘋狂的虐待著白雪公主,直到七個小矮人都...
    心事于你閱讀 483評論 0 2