這篇文章主要介紹了在Linux中怎么使用MD5實現(xiàn)用戶驗證的相關(guān)知識,內(nèi)容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇在Linux中怎么使用MD5實現(xiàn)用戶驗證文章都會有所收獲,下面我們一起來看看吧。
龍門網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),龍門網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為龍門上千余家提供企業(yè)網(wǎng)站建設(shè)服務。企業(yè)網(wǎng)站搭建\外貿(mào)網(wǎng)站制作要多少錢,請找那個售后服務好的龍門做網(wǎng)站的公司定做!使用openssl中的md5函數(shù),該函數(shù)返回16字節(jié)的unsigned char類型的數(shù)據(jù),每個字節(jié)的范圍都在0~255間,把
它格式化為十六進制就是32位md5編碼。注:一個字節(jié)為8位,正好可以表示2位的十六進制。
使用登錄客戶端的用戶名從redis數(shù)據(jù)庫中得到salt值和加密后的密碼,然后把登錄客戶端的密碼經(jīng)過salt加密后,與
redis數(shù)據(jù)庫中的密碼進行比較。相同則驗證通過,否則驗證失敗。
redis數(shù)據(jù)庫中密碼的存儲格式為password:salt
用戶驗證算法如下:
int user_authenticate(char *username, char *password)
{
char *salt_pw, *salt, *pw;
char buf[40];
char tmp[3]={'\0'}, md5_str[33]={'\0'};
unsigned char md[16];
int i;
//get_salt_pw調(diào)用redis數(shù)據(jù)庫獲得password:salt
salt_pw = get_salt_pw(db, username);
pw = strtok(salt_pw, ":");
if(!pw){
return 0;
}
salt = strtok(null, ":");
if(!salt){
return 0;
}
strcpy(buf, password);
strcat(buf, salt);
md5((const unsigned char*)buf, strlen(buf), md);
//transform to md5 string
for(i = 0; i < 16; i++){
sprintf(tmp, "%02x", md[i]);
strcat(md5_str, tmp);
}
//compare encode password using md5
if(strcmp((char*)md5_str, pw)){
return 0;
}
return 1;
}
其中要注意strtok函數(shù)的使用,以及16字節(jié)的unsigned char轉(zhuǎn)換為32位十六進制數(shù)的過程。
關(guān)于“在Linux中怎么使用MD5實現(xiàn)用戶驗證”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“在Linux中怎么使用MD5實現(xiàn)用戶驗證”知識都有一定的了解,大家如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
文章名稱:在Linux中怎么使用MD5實現(xiàn)用戶驗證-創(chuàng)新互聯(lián)
文章URL:http://bm7419.com/article18/dsssgp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、外貿(mào)網(wǎng)站建設(shè)、定制網(wǎng)站、網(wǎng)站策劃、ChatGPT、網(wǎng)站導航
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容