md5加密不一
1. php md5函數加密兩次的得到的值不一樣,第一個比第二個少了最後一位數字!!下面是代碼
你看纖碧看是不是有的地禪返方設置了賀豎飢限制字數啊,md5之後要麼全部一樣,要麼全一樣,不可能只差最後一位,
你看看是不是你少的那個數獲取的時候是不是因為限制字數而沒有獲取完整啊。
2. 不同語言的md5加密同一字元串,結果是不一樣的嗎
首先不同的語言的md5加密方式肯定是一樣的
使用C#的MD5加密時要注意幾點:
1.密碼是中文的:md5Hasher.ComputeHash(Encoding.GetEncoding("gb2312").GetBytes("中文"));
英文的要注意轉換字元集(對於常用的MS有點反了,反正針對密碼所用的字元集就行了)
2.如果要匹配資料庫的密碼,sql的md5加密是補足位數的,而網上的演算法沒有做這件事,所以經常會出現少幾位的情況,而且少的幾位肯定是「0」所以要注意補0,也就是ToString("X2")
貼一段代碼:
static void Main(string[] args)
{
MD5CryptoServiceProvider md5Hasher = new MD5CryptoServiceProvider();
byte[] hashedDataBytes;
hashedDataBytes = md5Hasher.ComputeHash(Encoding.GetEncoding("gb2312").GetBytes("中文"));
StringBuilder tmp = new StringBuilder();
foreach (byte i in hashedDataBytes)
{
tmp.Append(i.ToString("x2")); //就是這里的處理
}
Console.WriteLine(tmp.ToString());
Console.Read();
}
3. ASP.net 與ASP MD5加密結果不一致
要進行MD5加密的字元串不含中文時,那麼ASP.NET的加密結果和ASP是一致的: Response.Write(FormsAuthentication.("www.mzwu.com", "MD5"));
//結果:
Response.Write(MD5("www.mzwu.com",32))
'結果:
當要進行MD5加密的字元串含中文時,兩者的加密結果就不一致了:Response.Write(FormsAuthentication.("木子屋", "MD5"));
//結果: Response.Write(MD5("木子屋",32))
'結果: 我們知道,ASP.NET默認使用 utf-8編碼格式,而ASP使用的是gb2312編碼格式,正是由於這編碼格式不同,才導致了兩者對中文加密結果的不同。下邊我們看看怎麼讓 ASP.NET的編碼結果和ASP一樣,那也就意味著要讓ASP.NET採用gb2312編碼格式,這點 FormsAuthentication.()方法是辦不到的,我們得使用 System.Security.Cryptography.MD5CryptoServiceProvider對象的ComputeHash方法來進行 加密:MD5CryptoServiceProvider MD5 = new MD5CryptoServiceProvider();
Response.Write(BitConverter.ToString(MD5.ComputeHash(Encoding.GetEncoding("gb2312").GetBytes("木子屋"))).Replace("-", ""));
//結果:
若要再使用utf-8加密也非常容易:MD5CryptoServiceProvider MD5 = new MD5CryptoServiceProvider();
Response.Write(BitConverter.ToString(MD5.ComputeHash(Encoding.GetEncoding("utf-8").GetBytes("木子屋"))).Replace("-", ""));
//結果: 問題似乎是比較完美的解決了,我們再 來完善一下:當要加密的字元串是從其他頁面傳進來時,其他頁面採用的編碼格式可能是gb2312,可能是utf-8,還可能是其他的編碼格式,怎麼解決 呢?你可能會覺得很簡單啊,使用它先前的編碼格式進行加密不就行了?實際測試中你會發現兩個很嚴重的問題:1. 我們無從知道參數傳過來時是使用什麼編碼格式;
2. 如果兩個頁面使用的編碼方式不一樣,那麼Request接收到的參數值會亂碼,那就不要談加密了;問題1比較好解決,要求對方傳參數的同時必須多加一個參數說明採用的編碼格式,問題2的解決方法是不使用Request直接接收參數值,廢話不多說了,看下邊的函數:
/**//// <summary>
/// 對字元串進行MD5加密
/// </summary>
/// <param name="text">要加密的字元串</param>
/// <param name="charset">字元串編碼格式</param>
/// <example>str = MD5("木子屋","gb2312");</example>
/// <returns></returns>
public string MD5(string text, string charset)
{
return (MD5(text, charset, false));
}
/**//// <summary>
/// 對字元串或參數值進行MD5加密
/// </summary>
/// <param name="text">要加密的字元串或參數名稱</param>
/// <param name="charset">字元串編碼格式</param>
/// <param name="isArg">加密字元串類型true:參數值 false:字元串</param>
/// <returns></returns>
public string MD5(string text, string charset, bool isArg)
{
try
{
MD5CryptoServiceProvider MD5 = new MD5CryptoServiceProvider();
if (isArg)
{
NameValueCollection Collect = HttpUtility.ParseQueryString(Request.Url.Query, Encoding.GetEncoding(charset));//使用Collect接收參數值
if (Collect[text] != null)
{
return BitConverter.ToString(MD5.ComputeHash(Encoding.GetEncoding(charset).GetBytes(Collect[text].ToString()))).Replace("-", "");
}
}
else
{
return BitConverter.ToString(MD5.ComputeHash(Encoding.GetEncoding(charset).GetBytes(text))).Replace("-", "");
}
}
catch { }
return string.Empty;
}
說明1:上邊代碼需要引入的命名空間using System.Text;
using System.Web.Security;
using System.Security.Cryptography;
using System.Collections.Specialized;說明2:32位密文如何轉化成16位?16位密文是32位密文的9到24位字元。如:""→"90da023ae7aa1777"
4. 為什麼同樣的字串,在java裡面,MD5加密後密文也不同
你這個列印出來的是兩個byte數組的地址,肯定不一樣啦。
標準的md5演算法,對同一個字元串加密後的密文絕對是相同的,你需要將兩個byte數組的內容轉換成字元串類型,然後列印就沒問題啦。
5. API介面簽名驗證_MD5加密出現不同結果的解決方法
系統在提供介面給第三方系統使用時,通常為了安全性會做介面加密。
設計原則 :使用HTTPS安全協議 或 傳輸內容使用非對稱加密,這里採用後者。
在對參數進行加密,生成sign時,相同的參數兩次加密的結果不一樣。
加密規則:
1.拼接出來的字元串不一致
測試時,在加密前將要加密的字元串列印出來比較,發現兩次字元串一致。
2.編碼問題
加密時,兩次的默認編碼不一致。
在上述加上默認編碼: byte[] btInput = content.getBytes("utf-8"); ,問題解決。
簡單實現:
1.介面調用方和介面提供方約定好統一的參數加密演算法。
2.介面調用方在調用時把加密後的signature放在參數中去請求介面。
3.判斷時間戳有效期。
4.將參數用約定號的加密演算法進行加密,與參數中的signature進行比較,一致則調用介面。
6. java的32位MD5加密與php中的32位MD5加密結果不一樣。求幫助。急急急
Java的字元串是unicode編碼,不受源碼文件的編碼影響;而PHP的編碼是和源碼文件的編碼一致,受源碼編碼影響。例中java字元數據在散列時的編碼和php編碼未能保持一致,我認為這是導致輸出不同的「病理」
由於未知mad.toMd5的具體實現,問題直接成因應該在toMd5的String到byte[]轉換時的編碼上,或者未設置或者設置了錯誤的編碼
但只要java的字元串先getBytes獲得位元組串,並和php源碼編碼一致,就能獲得一致結果。
7. Delphi的MD5演算法加密中文不正確,是啥原因
這種情況與語言用的漢字編碼(內碼)有關,看是UNICODE還是什麼其他編碼?windows版本不同用的編碼也不同,表面顯示的是「中國人」,其實內存中的二進制碼不同,算出來的MD5當然不同。
8. 不同的MD5加密軟體,加密相同的兩個漢字,結果不一樣啊。
應該是由於漢字編碼的問題。比如utf-8,utf-16,utf-32,gbk等