1. 程式人生 > >php中的公鑰和私鑰

php中的公鑰和私鑰

最近公司業務需要用到公鑰和私鑰,之前接觸的很少,不是很瞭解,剛剛上網瞭解了下.發現很多地方都要用到加密.有對稱加密演算法( DES,AES)[加密和解密都使用一個金鑰]和不對稱加密演算法(RSA).這裡說的是RSA(非對稱加密演算法).
RSA就涉及到公鑰和私鑰.
這裡寫圖片描述
這裡寫圖片描述
要記住的就是:公鑰加密,私鑰解密.私鑰加密,公鑰解密.

RSA加密:

SHA-1(殺one)中的RSA演算法核心特點:有一個公鑰,有一個私鑰,二者是一套,且每一套都是獨一無二的.再無第二套一模一樣的.
公鑰可以隨便給人,但私鑰確是不可外傳的.
公鑰私鑰都可以進行加密解密,哪個加的密,就必須用這一套的另外一個鑰進行解密.鑰的加密實際就是一個規則

什麼是公鑰加密?

假設一下,兩個字母,一個是a,一個是b。我喜歡b這個數字,就保留起來,不告訴你們(私鑰),然後我告訴大家,a是我的公鑰。
我有一個檔案,不能讓別人看,我就用1加密了。別人找到了這個檔案,但是他不知道b就是解密的私鑰啊,所以他解不開,只有我可以用
數字b,就是我的私鑰,來解密。這樣我就可以保護資料了。
某人用我的公鑰a加密了字元hello,加密後成了xxxxx,放在網上。別人偷到了這個檔案,但是別人解不開,因為別人不知道b就是我的私鑰,
只有我才能解密,解密後就得到hello。這樣,我們就可以傳送加密的資料了。

私鑰簽名

如果我用私鑰加密一段資料(當然只有我可以用私鑰加密,因為只有我知道b是我的私鑰),結果所有的人都看到我的內容了,因為他們都知道我的公鑰是a,那麼這種加密有什麼用處呢?
某人說有人冒充我給他發信。怎麼辦呢?我把我要發的信,內容是c,用我的私鑰b,加密,加密後的內容是d,發給某人,再告訴他解密看是不是c。他用我的公鑰a解密,發現果然是c。這個時候,他會想到,能夠用我的公鑰解密的資料,必然是用我的私鑰加的密。只有我知道我得私鑰,因此他就可以確認確實是我發的東西。這樣我們就能確認傳送方身份了。這個過程叫做數字簽名。當然具體的過程要稍微複雜一些。用私鑰來加密資料,用途就是數字簽名


公鑰和私鑰是成對的,它們互相解密。
公鑰加密,私鑰解密。
私鑰數字簽名,公鑰驗證。
這裡寫圖片描述

下面貼上php中使用公鑰私鑰加密解密的程式碼以及其中需要注意的地方:
首先公鑰和私鑰存放的方式有檔案和字串的形式.不過作為小白要注意的是,公鑰私鑰無論是放在檔案中還是字串裡面,千萬要記得分行.我剛開始一直不分行,然後就是老是出錯,後來才知道要分行.而且不要忘了前後的註釋行.—–BEGIN PUBLIC KEY—–
下面這段是錯誤的

-----BEGIN PUBLIC KEY-----
MIGfMA0GCSqGSIb3DQEBAQUAA4GNADxdfxfgcghCBiQKBgQCIgm80UzfD9lQ/tnASRCapNNaoTcodUfDzNYLWAxEMp8EtWkD4eZmWbMdaWKyShIOGS48NKdVGsAB+F4usW1VFtrbqOfKgBUxMJKz1YcciBiV3kvhHZI4/jq94E0qy1jxTNdralRhe+0
/JklopEM9QWZScpBT4IXBfbMJ3JD5doQIDAQAB -----END PUBLIC KEY-----

這段程式碼形式才是正確的

-----BEGIN PUBLIC KEY-----
MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCIgm80UzfD9lQ/tnASRCapNNao
TcodUfDzNYLWAxEMp8EtWkD4eZmWbMdaWKyShIOGS48NKdVGsAB+F4usW1VFtrbq
OfKgBUxMJKz1YcciBiV3kvhHZI4/jq94E0qy1jxTNdralRhe+0/JklopEM9QWZSc
pBT4IXBfbMJ3JD5doQIDAQAB
-----END PUBLIC KEY-----
public function encrypt($data,$key_path){   
 $key = file_get_contents($key_path);
    $encryptedList = array();
    $step          = 117; 
    $encryptedData = ''; 
    $len = strlen($data); 
    for ($i = 0; $i < $len; $i += $step) {        
       $tmpData   = substr($data, $i, $step); 
       $encrypted = '';
        openssl_public_encrypt($tmpData, $encrypted, $key,OPENSSL_PKCS1_PADDING); 
       $encryptedList[] = ($encrypted);
    }    
     $encryptedData = base64_encode(join('', $encryptedList));
    return $encryptedData;
}

用私鑰解密(用到的函式openssl_private_decrypt)

 private function decrypt($encryptedData){
        if (empty($encryptedData)) {
            return '';
        }
        $encryptedData = base64_decode($encryptedData);
        $decryptedList = array();
        $step          = 128;
        $len = strlen($encryptedData);
        for ($i = 0; $i < $len; $i += $step) {
            $data      = substr($encryptedData, $i, $step);
            $decrypted = '';
            openssl_private_decrypt($data, $decrypted, file_get_contents($this->_key_pri), OPENSSL_PKCS1_PADDING);
            $decryptedList[] = $decrypted;
        }
        return join('', $decryptedList);

用私鑰加簽,用到的函式(openssl_get_privatekey)

 private function rsa_sign($data){
        //私鑰加簽
        $res = openssl_get_privatekey(file_get_contents($this->_key_priva_mime));
        openssl_sign($data, $sign, $res, OPENSSL_ALGO_SHA1);
        openssl_free_key($res);
        $sign = base64_encode($sign);
        return $sign;

公鑰驗籤(openssl_get_publickey)

private function _rsaCheckSign($data, $sign){
        $pubKey = file_get_contents($this->_key_pub_mime);
        $res = openssl_get_publickey($pubKey);
        $result = (bool)openssl_verify($data, base64_decode($sign), $res);
        openssl_free_key($res);    
        return $result;
    }

ps:如果是檔案形式的公私鑰,需要使用file_get_contents,括號中可以是地址.

相關推薦

php

最近公司業務需要用到公鑰和私鑰,之前接觸的很少,不是很瞭解,剛剛上網瞭解了下.發現很多地方都要用到加密.有對稱加密演算法( DES,AES)[加密和解密都使用一個金鑰]和不對稱加密演算法(RSA).這裡說的是RSA(非對稱加密演算法). RSA就涉及到公鑰和私

數字簽名是什麼?

數字簽名中公鑰和私鑰是什麼?今天終於弄懂了 鮑勃有兩把鑰匙,一把是公鑰,另一把是私鑰。 鮑勃把公鑰送給他的朋友們----帕蒂、道格、蘇珊----每人一把。 蘇珊要給鮑勃寫一封保密的信。她寫完後用鮑勃的公鑰加密,就可以達到保密的效果。 鮑勃收信後,用私鑰解密,就看到了信件內容。

Linux原理

一直以來對公鑰和私鑰都理解得不是很透徹,感覺到模稜兩可,心裡直打鼓呢。公鑰怎麼會事?私鑰怎麼會事?工作原理是怎麼的?今天在網上找了半天,通過檢視大家對這個金鑰對的理解,總算弄清楚了,咱就把我的心得寫出來給大家對金鑰對有疑問的同志們看看。       公鑰和私鑰就是俗稱的不

數字簽名是什麼?今天終於弄懂了

https://www.sohu.com/a/198919210_100027651   數字簽名中公鑰和私鑰是什麼?今天終於弄懂了 2017-10-19 17:00 鮑勃有兩把鑰匙,一把是公鑰,另一把是私鑰。 鮑勃把公鑰送給他的朋友們----帕蒂、道格、蘇

支付寶PHP-RSA的生成

/* * 生成RSA私鑰和公鑰 * @success array privKey,pubKey * */ public function pkey_new

給我一對,我就能破解此RSA

logs 計算 mar == while clas 需要 最終 最大公約數 RSA密碼系統如果暴露了一套公鑰和私鑰,那麽這套密碼系統就全部失效了。因為根據公鑰和私鑰可以完成大整數的分解、暴露了兩個質數。 記公鑰為e,私鑰為d,因為ed%phi=1,所以就得到了一個k=ed-

Git簡單生成生成方法

wap .com strong file art 代碼 秘鑰 ron div Git配置 Git安裝完之後,需做最後一步配置。打開git bash,分別執行以下兩句命令 git config --global user.name “用戶名” git config --

在OpenSSH上采用登錄並設置代理登錄

lis 0.10 需要 密鑰驗證 客戶 png 客戶機 文件 重啟 驗環境:RHEL6.5版本兩臺 客戶機IP地址 192.168.100.222 服務器IP地址 192.168.100.100 兩臺linux能實現相互通信 ------------------------

如何使用openssl生成RSA

在ubuntu上要使用openssl的話需要先進行安裝,命令如下: sudo apt-get install openssl 安裝完成就可以使用openssl了。 首先需要進入openssl的互動介面,在命令行了輸入openssl即可; 1)生成RSA私鑰:

GIT的

一、為什麼要使用金鑰 Git使用Https協議,每次pull,push都要輸入密碼,使用相當不便利,使用git協議,然後使用ssh金鑰,就可以省去每次都輸入密碼。 二、Git公鑰和私鑰的作用 公鑰我們一般是給伺服器的,他們到時候在許可權中加入我給的公鑰,然後當我從遠地倉庫中下載專

淺析

  關於公鑰和私鑰,簡單來理解你可以將它們視做你的使用者名稱和密碼。使用者名稱就是公鑰,密碼就是私鑰。區塊鏈數字錢包由公鑰和私鑰組成。熟悉密碼學的人都會了解公鑰和私鑰。要是作為開發人員,則能夠使用公鑰和私鑰在兩個不同的通訊之間建立安全連線。   但要是可以擴充套件這個概念來發送和接收資金該如何呢?這就是

eos 建立兩對的, 錢包,交易所轉賬到主網,主網到交易所

在ubuntu18.04上安裝EOS的目的: 在ubuntu中,進行eos原始碼編譯和安裝 在不聯網的安全環境下,用eos官方的命令列工具,建立自己的公鑰和私鑰 用eos官方的命令列工具,建立錢包,執行轉賬 一,用eos官方的命令列工具cleos,建立兩對的公鑰和私鑰 注意:做下

RSA加密演算法生成

Java RSA加密演算法生成公鑰和私鑰 import java.security.Key; import java.security.KeyPair; import java.security.KeyPairGenerator; import java.security.interf

提取pfx證書

從pfx提取金鑰資訊,並轉換為key格式(pfx使用pkcs12模式補足) 1、提取金鑰對(如果pfx證書已加密,會提示輸入密碼。) openssl pkcs12 -in 1.pfx -nocerts -nodes -out 1.key 2、從金鑰對提取私鑰 openssl rsa -in 1.key -

的區別-一封雞毛信舉例說明

便於理解簡單舉個例子,如有不正確地方敬請指出 地下黨間傳輸檔案保密性要求: 1.檔案必須加密傳送。如:不能用明文寫一封信,這封信必須是密文或者用澱粉寫的。。。 2.收到的加密檔案必須是黨內接頭同志的。如:收到一封加密信若是國民黨或者叛徒發的,按照信上做了就完蛋了。。 比如: A同

【資料加密】的區別

  非對稱加密 第一種用法:公鑰加密,私鑰解密。---用於加解密 第二種用法:私鑰簽名,公鑰驗籤。---用於簽名 有點混亂,不要去硬記,總結一下: 你只要想: 既然是加密,那肯定是不希望別人知道我的訊息,所以只有我才能解密,所以可得出公鑰負責加密,私鑰負責解密; 既然是簽名,那

淺談的概念

**關於公鑰和私鑰,簡單來理解你可以將它們視做你的使用者名稱和密碼。**使用者名稱就是公鑰,密碼就是私鑰。區塊鏈數字錢包由公鑰和私鑰組成。熟悉密碼學的人都會了解公鑰和私鑰。要是作為開發人員,則能夠使用公鑰和私鑰在兩個不同的通訊之間建立安全連線。 但要是可以擴充套件這個概念來發送和接收資金

詳解win10 64位系統下是如何安裝OpenSSL? 及通過openssl工具生成RSA的

預備工具: 安裝環境:Windows10旗艦版 -64位  +  Microsoft Visual Studio2013 相關軟體:vs2013、ActivePerl-5.24.3、openssl-1

【python RAS驗籤】RSA生成,並驗籤

1、RSA加密解密過程 公鑰加密,私鑰解密 2、RSA驗簽過程 私鑰產生簽名,公鑰驗證簽名 1.服務端產生公鑰和私鑰 私鑰,去掉換行,空格,頭部,利用阿里的工具轉成pkcs8給客戶端 2.客戶端用私鑰對

openssl pem 生成及檔案

原文地址:https://www.cnblogs.com/cocoajin/p/6137651.html   openssl pem.h 中提供了關於pem格式金鑰對的操作介面 通常使用.pem的格式檔案來儲存openssl 生成的金鑰對; 在終端下 cat xxx.pem