這幾章主要介紹了一些為什麼要加密,加密的歷史原因以及演變過程,並介紹了幾種常見的加密演算法,畫出了對稱與非對稱加密在實際應用中的思維導圖。
(了解到加密技術分為對稱加密,非對稱加密,單向加密(散列加密))
(一般單向加密用於提供數據完整性的校驗,使用到的演算法有MD5,SHA1等Hash演算法),(消息認證,鑒權等多用非對稱加密演算法,通過使用數字證書,公鑰私鑰來實現)
另外,JCA 是提供基礎的加密框架,類似於一個工廠,生產密鑰產生器,數字證書,簽名等基礎設施。JCE 是JCA的擴展,也就是加工廠,拿到JCA的基礎設施後,放入一些亂七八糟的演算法,讓產出的產品具有保密性。JSSE 是負責在網路傳輸中加密的,是基於SSL的。
JCE 最後封裝成了一套介面,作為安全提供者介面。據說,它的精髓就是,引擎和演算法。一個演算法是一個引擎的具體實現,例如(provider + rsa演算法)
↑ 這裡面使用到了提供者模式。↑ 即,基礎功能提供者只需要關注提供哪種服務(加密,解密,or anyone else),不需要關心演算法是否又推層出新了。
(據書里說,java.security.Provider 和 java.security.Security 這兩個類是JCE的核心,於是我去翻了翻API)……基本看不到什麼有意思的。
於是人書里繼續說了,其實真的要實現加密解密,還要用javax.crypto里的功能。好吧,這樣就和我見過的匹配上了。所以上面說的核心只是說掌握如何操作,這里的核心是干實事,基層核心。
Ⅱ 如何使用java進行sha1加密
使用下面的語句即可:
digestutils.shahex(要加密的字元);加密參數最好用位元組數組,畢竟sha1演算法是使用位元組為單位進行運算的,字元串轉位元組還與字元編碼有關。
Ⅲ java 3des和sha1的區別
公開密鑰加密(英語:public-key cryptography,又譯為公開密鑰加密),也稱為非對稱加密(asymmetric cryptography),一種密碼學演算法類型,在這種密碼學方法中,需要一對密鑰,一個是私人密鑰,另一個則是公開密鑰。這兩個密鑰是數學相關,用某用戶密鑰加密後所得的信息,只能用該用戶的解密密鑰才能解密。如果知道了其中一個,並不能計算出另外一個。因此如果公開了一對密鑰中的一個,並不會危害到另外一個的秘密性質。稱公開的密鑰為公鑰;不公開的密鑰為私鑰。
Ⅳ 用java語言SHA1加密演算法隨即顯示數字,運行時顯示錯誤java.lang.NullPointerException: String is null
無需各個都看,第一行已經提示了…無指向,string 不能為空…仔細瞧瞧各個參數設置是否正確吧…
Ⅳ 請求Java的SHA1加密演算法轉換為NET怎麼寫的
首先引用這個命名空間usingSystem.Security.Cryptography;//建立SHA1對象SHA1sha=newSHA1CryptoServiceProvider();//將mystr轉換成byte[]ASCIIEncodingenc=newASCIIEncoding();byte[]dataToHash=enc.GetBytes(mystr);//Hash運算byte[]dataHashed=SHA1.ComputeHash(dataToHash);//將運算結果轉換成stringstringhash=BitConverter.ToString(dataHashed).Replace("-","");returnhash;
Ⅵ java sha1與objc sha1加密
檢查一下 digesta值的編碼是否於objc的編碼相同
Ⅶ 用java程序進行sha1加密,怎麼弄
publicclassSha1{
/**
*SHA1安全加密演算法
*@parammaps參數key-valuemap集合
*@return
*@throwsDigestException
*/
publicstaticStringSHA1(Map<String,Object>maps)throwsDigestException{
//獲取信息摘要-參數字典排序後字元串
Stringdecrypt=getOrderByLexicographic(maps);
try{
//指定sha1演算法
MessageDigestdigest=MessageDigest.getInstance("SHA-1");
digest.update(decrypt.getBytes());
//獲取位元組數組
bytemessageDigest[]=digest.digest();
//CreateHexString
StringBufferhexString=newStringBuffer();
//位元組數組轉換為十六進制數
for(inti=0;i<messageDigest.length;i++){
StringshaHex=Integer.toHexString(messageDigest[i]&0xFF);
if(shaHex.length()<2){
hexString.append(0);
}
hexString.append(shaHex);
}
returnhexString.toString().toUpperCase();
}catch(NoSuchAlgorithmExceptione){
e.printStackTrace();
thrownewDigestException("簽名錯誤!");
}
}
/**
*獲取參數的字典排序
*@parammaps參數key-valuemap集合
*@returnString排序後的字元串
*/
(Map<String,Object>maps){
returnsplitParams(lexicographicOrder(getParamsName(maps)),maps);
}
/**
*獲取參數名稱key
*@parammaps參數key-valuemap集合
*@return
*/
privatestaticList<String>getParamsName(Map<String,Object>maps){
List<String>paramNames=newArrayList<String>();
for(Map.Entry<String,Object>entry:maps.entrySet()){
paramNames.add(entry.getKey());
}
returnparamNames;
}
/**
*參數名稱按字典排序
*@paramparamNames參數名稱List集合
*@return排序後的參數名稱List集合
*/
privatestaticList<String>lexicographicOrder(List<String>paramNames){
Collections.sort(paramNames);
returnparamNames;
}
/**
*拼接排序好的參數名稱和參數值
*@paramparamNames排序後的參數名稱集合
*@parammaps參數key-valuemap集合
*@returnString拼接後的字元串
*/
(List<String>paramNames,Map<String,Object>maps){
StringBuilderparamStr=newStringBuilder();
for(StringparamName:paramNames){
paramStr.append(paramName);
for(Map.Entry<String,Object>entry:maps.entrySet()){
if(paramName.equals(entry.getKey())){
paramStr.append(String.valueOf(entry.getValue()));
}
}
}
returnparamStr.toString();
}
Ⅷ java的sha1加密和object-c的sha1加密後的值不一樣,誰能幫我解決一下。多謝了
結果是一樣的, 但是你多搞了一點: java你是用Base64編碼成字元串, 而ObjC你是直接用16進制輸出的, 你java上不Base64編碼, 也輸出成16進制, 就一樣了;
Ⅸ (java加密解密)如何實現JCE介面的各種演算法
關於如何去實現Provider,官方文檔中有詳細的說明。
請參照:http://download.oracle.com/javase/6/docs/technotes/guides/security/crypto/HowToImplAProvider.html#Steps
Ⅹ java 怎樣實現 64位的md5加密演算法
直接引入「commons-codec-1.10.jar」這個java包,然後調用相應方法即可
比如我們可以寫一個方法類,把常用的方法都寫進去:
publicclassEncryptionUtil{
/**
*Base64encode
**/
(Stringdata){
returnBase64.encodeBase64String(data.getBytes());
}
/**
*Base64decode
*@
**/
(Stringdata){
returnnewString(Base64.decodeBase64(data.getBytes()),"utf-8");
}
/**
*md5
**/
publicstaticStringmd5Hex(Stringdata){
returnDigestUtils.md5Hex(data);
}
/**
*sha1
**/
publicstaticStringsha1Hex(Stringdata){
returnDigestUtils.sha1Hex(data);
}
/**
*sha256
**/
publicstaticStringsha256Hex(Stringdata){
returnDigestUtils.sha256Hex(data);
}
}
(PS:純手打,望採納)