客户端使用公钥进行加密,服务端使用密钥进行解密

来源:互联网 发布:欧洲知乎 编辑:程序博客网 时间:2024/06/03 15:21

使用rsa非对称加密吧,客户端使用公钥进行加密,服务端使用密钥进行解密。



我觉得你最好使用JAVA 进行DES加密和解密 

(JAVA 的核心API中已经实现过DES加密,JAVASCRIPT实现DES加密我没做过)

下面是JAVA版的DES加密 希望对你有帮助:

Java code
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
import java.security.Key;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
 
public class Des {
    Key key;
 
  /**
   * 根据参数生成KEY
   * @param strKey
   */
   public void getKey(String strKey) {
    try {
      KeyGenerator _generator = KeyGenerator.getInstance("DES");
      _generator.init(new SecureRandom(strKey.getBytes()));
      this.key = _generator.generateKey();
      _generator = null;
    catch (Exception e) {
      e.printStackTrace();
    }
  }
 
  /**
   * 加密String明文输入,String密文输出
   * @param strMing             String明文
   * @return                    String密文
   */
  public String getEncString(String strMing) {
    byte[] byteMi = null;
    byte[] byteMing = null;
    String strMi = "";
    BASE64Encoder base64en = new BASE64Encoder();
    try {
      byteMing = strMing.getBytes("UTF8");
      byteMi = this.getEncCode(byteMing);
      strMi = base64en.encode(byteMi);
    catch (Exception e) {
      e.printStackTrace();
    finally {
      base64en = null;
      byteMing = null;
      byteMi = null;
    }
    return strMi;
  }
 
  /**
   * 解密 以String密文输入,String明文输出
   * @param strMi               String密文
   * @return                    String明文
   */
  public String getDesString(String strMi) {
    BASE64Decoder base64De = new BASE64Decoder();
    byte[] byteMing = null;
    byte[] byteMi = null;
    String strMing = "";
    try {
      byteMi = base64De.decodeBuffer(strMi);
      byteMing = this.getDesCode(byteMi);
      strMing = new String(byteMing, "UTF8");
    catch (Exception e) {
      e.printStackTrace();
    finally {
      base64De = null;
      byteMing = null;
      byteMi = null;
    }
    return strMing;
  }
 
  /**
   * 加密以byte[]明文输入,byte[]密文输出
   * @param byteS
   * @return
   */
  private byte[] getEncCode(byte[] byteS) {
    byte[] byteFina = null;
    Cipher cipher;
    try {
      cipher = Cipher.getInstance("DES");
      cipher.init(Cipher.ENCRYPT_MODE, key);
      byteFina = cipher.doFinal(byteS);
    catch (Exception e) {
      e.printStackTrace();
    finally {
      cipher = null;
    }
    return byteFina;
  }
 
  /**
   * 解密以byte[]密文输入,以byte[]明文输出
   * @param byteD
   * @return
   */
  private byte[] getDesCode(byte[] byteD) {
    Cipher cipher;
    byte[] byteFina = null;
    try {
      cipher = Cipher.getInstance("DES");
      cipher.init(Cipher.DECRYPT_MODE, key);
      byteFina = cipher.doFinal(byteD);
    catch (Exception e) {
      e.printStackTrace();
    finally {
      cipher = null;
    }
    return byteFina;
  }
   
  //转化为16进制字符串
  public static String byte2hex(byte[] b){   
      String hs="";   
      String stmp="";   
      for(int n=0;n<b.length;n++){
          stmp=(java.lang.Integer.toHexString(b[n]&0XFF));   
          if(stmp.length()==1)hs=hs+"0"+stmp;   
          else hs=hs+stmp;   
          if(n<b.length-1) hs=hs+":";   
      }   
      return hs.toUpperCase();   
}   
 
 
  public static void main(String args[]) {
     Des des=new Des();//实例化一个对像
     des.getKey("aadd");//生成密匙
 
     String strEnc = des.getEncString("明文");//加密字符串,返回String的密文
     System.out.println("加密文:"+strEnc);
 
     String strDes = des.getDesString(strEnc);//把String 类型的密文解密
     System.out.println("解密文:"+strDes);
  }
}

0 0