java之電話號碼加密(密碼加密java)

本文目錄一覽:

java加密的幾種方式

基本的單向加密算法:

BASE64 嚴格地說,屬於編碼格式,而非加密算法

MD5(Message Digest algorithm 5,信息摘要算法)

SHA(Secure Hash Algorithm,安全散列算法)

HMAC(Hash Message Authentication Code,散列消息鑒別碼)

複雜的對稱加密(DES、PBE)、非對稱加密算法:

DES(Data Encryption Standard,數據加密算法)

PBE(Password-based encryption,基於密碼驗證)

RSA(算法的名字以發明者的名字命名:Ron Rivest, AdiShamir 和Leonard Adleman)

DH(Diffie-Hellman算法,密鑰一致協議)

DSA(Digital Signature Algorithm,數字簽名)

ECC(Elliptic Curves Cryptography,橢圓曲線密碼編碼學)

代碼參考:

/**

* BASE64加密

*

* @param key

* @return

* @throws Exception

*/

public static String encryptBASE64(byte[] key) throws Exception {

return (new BASE64Encoder()).encodeBuffer(key);

}

/**

* MD5加密

*

* @param data

* @return

* @throws Exception

*/

public static byte[] encryptMD5(byte[] data) throws Exception {

MessageDigest md5 = MessageDigest.getInstance(KEY_MD5);

md5.update(data);

return md5.digest();

}

/**

* SHA加密

*

* @param data

* @return

* @throws Exception

*/

public static byte[] encryptSHA(byte[] data) throws Exception {

MessageDigest sha = MessageDigest.getInstance(KEY_SHA);

sha.update(data);

return sha.digest();

}

}

/**

* 初始化HMAC密鑰

*

* @return

* @throws Exception

*/

public static String initMacKey() throws Exception {

KeyGenerator keyGenerator = KeyGenerator.getInstance(KEY_MAC);

SecretKey secretKey = keyGenerator.generateKey();

return encryptBASE64(secretKey.getEncoded());

}

/**

* HMAC加密

*

* @param data

* @param key

* @return

* @throws Exception

*/

public static byte[] encryptHMAC(byte[] data, String key) throws Exception {

SecretKey secretKey = new SecretKeySpec(decryptBASE64(key), KEY_MAC);

Mac mac = Mac.getInstance(secretKey.getAlgorithm());

mac.init(secretKey);

return mac.doFinal(data);

}

如何用java語言對即時通訊軟件進行加密

一、Java軟件加密基本思路

對於應用軟件的保護筆者從兩個方面進行考慮,第一是阻止盜版使用軟件,第二是阻止競爭對手對軟件反編譯,即阻止對軟件的逆向工程。

1、阻止盜版

在軟件運行時對自身存在的合法性進行判斷,如果認為自身的存在和運行是被授權的、合法的,就運行;否則終止運行。這樣即使軟件可以被隨意複製,只要盜版用戶沒有相應的授權信息就無法使用軟件。

2、阻止反編譯

對編譯產生的Class文件加密處理,並在運行時進行解密,解密者無法對軟件進行反編譯。

二、Java軟件加密的總體流程

為了保護用Java語言開發的軟件,我們設計並實現了一個實用、高強度的加密算法。以下稱需要保護的Java軟件為“受保護程序”,稱對“受保護程序”進行加密保護的軟件為“加密程序”。對軟件加密保護的流程如圖1所示。

三、加密算法分析設計

1、用戶信息提取器設計

為了防止用戶發布序列號而導致“一次發行,到處都是”的盜版問題,提取用戶機器中硬件相關的、具有唯一性的信息——用戶計算機的硬盤分區C的序列號,並要求用戶將此信息與用戶名一起返回,之後用“序列號生成器”根據用戶返回信息生成一個唯一合法的軟件註冊序列號發回用戶,用戶即可使用此號碼註冊使用軟件。

這個信息提取器使用Winclows 32彙編以一個獨立的小程序方式實現,程序代碼如圖2所示。

2、序列號生成器與序列號合法性判斷函數的設計

序列號生成器與序列號合法性判斷函數中運用RSA加密算法。在序列號生成器中是使用私鑰將用戶返回的信息(硬盤序列號,用戶名)進行加密得到相應的註冊序列號;在序列號合法性判斷函數中使用私鑰將用戶輸入的註冊序列號解密,再與(硬盤序列號,用戶名)進行比較,一致則調用程序裝載器將程序其他部分解密裝入內存,初始化刪環境並運行程序主體;否則退出。

RSA加密算法的實現需要使用大數運算庫,我們使用MIRACL大數庫來實現RSA計算,序列號生成器的主要代碼如下:

char szlnputString[]=”機器碼和用戶名組成的字符串”;

char szSerial[256]=[0];//用於存放生成的註冊碼

bign,d,c,m; //MIRACL中的大數類型

mip→IBASE=16; //以16進制模式

n= mlrvar(0); //初始化大數

d= mirvar(0);

c= mirvar(0); //C存放輸入的字符串大數

m= mlrva(o);

bytes to big( len, szlnputString,c);

//將輸入字符串轉換成大數形式並存入變量c中

cinstr(n,”以字符串形成表示的模數”);//初始化模數

cinstr(d,”以字符串形成表示的公鑰”)://初始化公鑰

powmod(c,d,n,m); //計算m=cdmod n

cotstr(m,szSerial);//m的16進制字符串即為註冊碼

序列號合法性檢測函數的主要代碼如下:

char szlnputStringL]=”機器碼和用戶名組成的字符串”;

char szSerial[ 256]=”用戶輸入的序列號”

bign,e,c,m; //MIRACL中的大數類型

mip→IBASE=16; //以16進制模式

cinstr(m,szSerial); //將序列號的16進制轉成大數形式

cinstr(n,”模數n的字符串形式”);//初始化模數n

cinstr(e,”字符串形式的公鑰”);//初始化公鑰

if compare(m,n)==-1) //mn時才進行解密

{

powmod(m,e,n,c);//計算m=me mod n

big_to _bytes(0,c,szSerial,0); //轉為字符串

return lstrcmp( szlnputString,szSerial);

}

3、強耦合關係的設計

如果在序列號合法性檢測函數中簡單地使用圖3所示流程:

解密者可以使用以下幾種手段進行攻擊:

(1)修改“判斷合法性子函數”的返回指令,讓它永遠返回正確值,這樣可以使用任意的序列號,安裝/使用軟件。

(2)修改判斷後的跳轉指令,使程序永遠跳到正確的分支運行,效果和上一種一樣。

(3)在“判斷合法性子函數”之前執行一條跳轉指令,繞過判斷,直接跳轉到“正常執行”分支運行,這樣可以不用輸入序列號安裝/使用軟件。

為阻止以上攻擊手段,筆者在程序中增加了“序列號合法性檢測函數”與程序其他部分“強耦合”(即增強其與程序其他部分的關聯度,成為程序整體密不可分的一部分,一旦被修改程序將無法正常工作)的要求(見圖1),並且設置一個“完整性檢測函數”用於判斷相關的代碼是否被修改過。當然,基於同樣的原因,“完整性檢測函數”也必須與程序其他部分存在“強耦合”關係。

強耦合關係通過以下方式建立:

在程序其他部分的函數(例如函數A)中隨機的訪問需要強耦合的“序列號合法性檢測函數”和“完整性檢測函數”,在調用時隨機的選擇使用一個錯誤的序列號或是用戶輸入的序列號,並根據返回結果選擇執行A中正常的功能代碼還是錯誤退出的功能代碼,流程如圖4所示。

經過這種改進,如果破解者通過修改代碼的方式破解將因“完整性檢測”失敗導致程序退出;如果使用SMC等技術繞過“序列號合法性判斷函數”而直接跳至序列號正確時的執行入口,在後續的運行中,將因為隨機的耦合調用失敗導致程序退出。破解者要破解軟件將不得不跟蹤所有進行了耦合調用的函數,這顯然是一個艱巨的任務。

4、完整性檢測函數的設計

我們使用CRC算法算出需進行完整性檢測的文件的校驗碼,並用RSA加密算法的公鑰(不同於序列號合法性檢測中的公鑰/私鑰對)將其加密存放在特定的文件中,在檢測時先用CRC算法重新生成需進行完

整性檢測的文件的校驗碼,並用私鑰將保存的校驗碼解密,兩者相比較,相等則正常運行;否則退出。

5、程序加載器的設計

與編譯成機器碼執行的程序不同,Java程序只能由Java虛擬機解釋執行,因此程序加載器的工作包括:初始化Java虛擬機;在內存中解密當前要運行的class文件;使解密後的c:lass文件在虛擬機中運行,在

需要時解密另一個class文件。圖5是用於初始化JVM的代碼:

以上介紹了我們設計的針對Java軟件的加密保護方法,其中綜合運用了多種加密技術,抗破解強度高;使用純軟件保護技術,成本低。經筆者在Windows系列平台上進行測試,運行穩定,效果良好。

在研宄開發過程中,我們還總結出加密保護軟件的一些經驗:

1、對關鍵代碼和數據要靜態加密,再動態解密執行;要結合具體的工作平台使用反跟蹤/調試技術;

2、要充分利用系統的功能,如在Windows下使用DLL文件或驅動程序形式能得到最大的豐又限,可以充分利用系統具有的各種功能;

3、如果可能應該將關鍵代碼存放在不可禚複製的地方;

4、序列號要與機器碼等用戶信息相關以阻止鹽復布序列號;

5、加密流程的合理性比加密算法本身的強度更重要。

java中將一個手機電話號碼的後6為作為密碼怎麼截取拆分?給出具體例子

s.substing(5)//從第5位階段字符串

再比如:

“unhappy”.substring(2) returns “happy”

參考java api

java編寫數字加密解密

加多一個判斷,當輸入的長度小於指定長度的時候,出錯;

如果超出指定長度,則取前幾位,譬如指定6位,輸入123, 出錯;輸入123456789,那就只處理123456,忽略後面的789

import java.util.HashMap;

import java.util.Map;

import java.util.Scanner;

public class Test {

public static void main(String[] args) throws Exception {

System.out.print(“請輸入加密(解密)和要處理的數字個數:1為加密,2為解密; “);

Scanner scanner = new Scanner(System.in);

String[] input1 = scanner.nextLine().split(“\\s+”);

String choice = input1[0];

int count = Integer.parseInt(input1[1]);

System.out.print(“請輸入要處理的數字,用空格隔開:”);

String input = scanner.nextLine().replaceAll(“\\s+”, “”);

if(input.length() count){

throw new Exception(“不足” + count + “位數字,請檢查輸入”);

}else if(input.length() count){

System.out.println(“太多數字,將處理前” + count + “個數字:” +

input.substring(0, 6));

input = input.substring(0, 6);

}

if(choice.equals(“1”)){

if(input.length() count){

}

String encode = EncodeUtil.encode(input);

System.out.println(“加密後的數字是: ” + encode);

}else{

String decode = EncodeUtil.decode(input);

System.out.println(“解密後的數字: ” + decode);

}

}

}

class EncodeUtil{

private static MapString, String encodeMap = null;

private static MapString, String decodeMap = null;

public final static String encode(String strToEncode){

if(encodeMap == null){

encodeMap = new HashMapString, String();

encodeMap.put(“0”, “7”);

encodeMap.put(“1”, “5”);

encodeMap.put(“2”, “9”);

encodeMap.put(“3”, “1”);

encodeMap.put(“4”, “3”);

encodeMap.put(“5”, “6”);

encodeMap.put(“6”, “8”);

encodeMap.put(“7”, “0”);

encodeMap.put(“8”, “2”);

encodeMap.put(“9”, “4”);

}

StringBuilder sb = new StringBuilder();

for(int i = 0; i strToEncode.length(); i++){

sb.append(encodeMap.get(String.valueOf(strToEncode.charAt(i))));

}

return sb.toString();

}

public final static String decode(String strToDecode){

if(decodeMap == null){

decodeMap = new HashMapString, String();

decodeMap.put(“7”, “0”);

decodeMap.put(“5”, “1”);

decodeMap.put(“9”, “2”);

decodeMap.put(“1”, “3”);

decodeMap.put(“3”, “4”);

decodeMap.put(“6”, “5”);

decodeMap.put(“8”, “6”);

decodeMap.put(“0”, “7”);

decodeMap.put(“2”, “8”);

decodeMap.put(“4”, “9”);

}

StringBuilder sb = new StringBuilder();

for(int i = 0; i strToDecode.length(); i++){

sb.append(decodeMap.get(String.valueOf(strToDecode.charAt(i))));

}

return sb.toString();

}

}

——————測試

C:\Program Files\IBM\RAD 7\jdk\binjava Test

請輸入加密(解密)和要處理的數字個數:1為加密,2為解密; 1 6

請輸入要處理的數字,用空格隔開:1 2 3

Exception in thread “main” java.lang.Exception: 不足6位數字,請檢查輸入

at Test.main(Test.java:19)

C:\Program Files\IBM\RAD 7\jdk\binjava Test

請輸入加密(解密)和要處理的數字個數:1為加密,2為解密; 1 6

請輸入要處理的數字,用空格隔開:1 2 3 4 5 6 7

太多數字,將處理前6個數字:123456

加密後的數字是: 591368

C:\Program Files\IBM\RAD 7\jdk\binjava Test

請輸入加密(解密)和要處理的數字個數:1為加密,2為解密; 1 6

請輸入要處理的數字,用空格隔開:1 9 9 7 7 1

加密後的數字是: 544005

C:\Program Files\IBM\RAD 7\jdk\binjava Test

請輸入加密(解密)和要處理的數字個數:1為加密,2為解密; 2 6

請輸入要處理的數字,用空格隔開:5 4 4 0 0 5

解密後的數字: 199771

java輸入一個6位數的電話號碼傳入方法,方法返回加密後的號碼,使用stringbuffe

package com;

import java.io.UnsupportedEncodingException;

import java.security.MessageDigest;

import java.security.NoSuchAlgorithmException;

public class Yugi

{

public static final String CHARSET = “UTF-8”;

private String sign(String prestr)

{

StringBuffer buffer = new StringBuffer(32);

try

{

MessageDigest md5 = MessageDigest.getInstance(“MD5”);

byte[] t = md5.digest(prestr.getBytes(CHARSET));

for(int i = 0; i  t.length; i++)

{

buffer.append(Byte.toString(t[i]));

}

return buffer.toString();

}

catch(NoSuchAlgorithmException e)

{

e.printStackTrace();

}

catch(UnsupportedEncodingException e)

{

e.printStackTrace();

}

return prestr;

}

public static void main(String[] args)

{

Yugi yugi = new Yugi();

System.out.println(yugi.sign(“123456”));

}

}

Java編程如何給數字加密

最簡單的,用異或運算。

你也可以自己寫個加密方法啊。

比如說:利用unicode字符加密啊。假設一個數字a它的unicode值是1234,你自己設計個函數,比如說y=2x^3+3,得到一個新的unicode字符,然後把這個unicode字符轉換為字母,這個字母可能是漢字,但更可能是外國符文,反正一般人不會認出來的。你解密的時候,倒推一下就行了。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/300525.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-29 12:51
下一篇 2024-12-29 12:51

相關推薦

  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java Bean加載過程

    Java Bean加載過程涉及到類加載器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean加載的過程。 一、類加載器 類加載器是Java虛擬機…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發布。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字符串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字符串中是否存在多個指定字符: 一、字符串遍歷 字符串是Java編程中非常重要的一種數據類型。要判斷字符串中是否存在多個指定字符…

    編程 2025-04-29
  • VSCode為什麼無法運行Java

    解答:VSCode無法運行Java是因為默認情況下,VSCode並沒有集成Java運行環境,需要手動添加Java運行環境或安裝相關插件才能實現Java代碼的編寫、調試和運行。 一、…

    編程 2025-04-29
  • Java任務下發回滾系統的設計與實現

    本文將介紹一個Java任務下發回滾系統的設計與實現。該系統可以用於執行複雜的任務,包括可回滾的任務,及時恢復任務失敗前的狀態。系統使用Java語言進行開發,可以支持多種類型的任務。…

    編程 2025-04-29
  • Java 8 Group By 會影響排序嗎?

    是的,Java 8中的Group By會對排序產生影響。本文將從多個方面探討Group By對排序的影響。 一、Group By的概述 Group By是SQL中的一種常見操作,它…

    編程 2025-04-29

發表回復

登錄後才能評論