加密解密【对称加密】

说明

针对上行参数 value,做加密处理,基本思路每个项目拥有有不同的私钥因子(通过定义后台配置),最终的私钥=md5(私钥因子 + uid),得到32位的私钥,客户端与服务端以同样逻辑来处理私钥。

加密处理流程:

aes加密;

针对密文base64编码;

进一步urlencode编码

解密时按(c)(b)(a)顺序依次执行。

每个项目使用不同的秘钥,秘钥长度32位字符串

注意

需要和客户端(iOS+Android)验证三端加密串一致,且互相能够解密。

代码

NodeJs代码

//引入nodejs加密核心库

varcrypto =require('crypto');

//加密公共密钥 32位

varkeys ='9ce62c1836d128cfc875c9026db7564c';

//编码设置

varclearEncoding ='utf8';

//加密方式

varalgorithm ='aes-256-ecb';

//向量

variv ="";

//加密类型 base64/hex...

varcipherEncoding ='hex';

exports.encodeCipher =function(data){

   try{

       varcipher = crypto.createCipheriv(algorithm, keys, iv);

       varcipherChunks = [];

        cipherChunks.push(cipher.update(data, clearEncoding, cipherEncoding));

        cipherChunks.push(cipher.final(cipherEncoding));

       returncipherChunks.join('');

    }catch(e){

       return10004;

    }

}

exports.decodeCipher =function(data){

   try{

       varcipherChunks = [data];

       vardecipher = crypto.createDecipheriv(algorithm, keys, iv);

       varplainChunks = [];

       for(vari =0;i < cipherChunks.length;i++) {

            plainChunks.push(decipher.update(cipherChunks[i], cipherEncoding, clearEncoding));

        }

        plainChunks.push(decipher.final(clearEncoding));

       returneval_r("("+plainChunks.join('')+")");//转成对象,方便程序中使用

    }catch(e){

       return10003;

    }

}

IOS代码

- (NSData*)AES256EncryptWithKey:(NSData*)key  //加密

{

   //對於塊加密算法,輸出大小總是等於或小於輸入大小加上一個塊的大小

   //所以在下邊需要再加上一個塊的大小

   NSUIntegerdataLength = [selflength];

    size_t bufferSize = dataLength + kCCBlockSizeAES128;

   void*buffer = malloc(bufferSize);

    size_t numBytesEncrypted =0;

    CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmAES128,

                                          kCCOptionPKCS7Padding | kCCOptionECBMode,

                                          [key bytes], kCCKeySizeAES256,

                                         NULL,

                                          [selfbytes], dataLength,

                                          buffer, bufferSize,

                                          &numBytesEncrypted);

   if(cryptStatus == kCCSuccess) {

       return[NSDatadataWithBytesNoCopy:buffer length:numBytesEncrypted];

    }

    free(buffer);//釋放buffer

   returnnil;

}

- (NSData*)AES256DecryptWithKey:(NSData*)key  //解密

{

   //同理,解密中,密鑰也是32位的

   constvoid* keyPtr2 = [key bytes];

   constchar(*keyPtr)[32] = keyPtr2;

   //對於塊加密算法,輸出大小總是等於或小於輸入大小加上一個塊的大小

   //所以在下邊需要再加上一個塊的大小

   NSUIntegerdataLength = [selflength];

    size_t bufferSize = dataLength + kCCBlockSizeAES128;

   void*buffer = malloc(bufferSize);

    size_t numBytesDecrypted =0;

    CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt, kCCAlgorithmAES128,

                                          kCCOptionPKCS7Padding | kCCOptionECBMode,

                                          keyPtr, kCCKeySizeAES256,

                                         NULL,

                                          [selfbytes], dataLength,

                                          buffer, bufferSize,

                                          &numBytesDecrypted);

   if(cryptStatus == kCCSuccess) {

       return[NSDatadataWithBytesNoCopy:buffer length:numBytesDecrypted];

    }

    free(buffer);

   returnnil;

}

JAVA代码

packagecom.cityfore.smarthome.hd.util;

importjava.security.Key;

importjava.security.Security;

importjavax.crypto.Cipher;

importjavax.crypto.SecretKey;

importjavax.crypto.spec.SecretKeySpec;

importorg.bouncycastle.jce.provider.BouncyCastleProvider;

publicclassAES256{

 privatestaticfinalString KEY_ALGORITHM ="AES";

 privatestaticfinalString CIPHER_ALGORITHM ="AES/ECB/PKCS7Padding";

 privatestaticKeytoKey(byte[] key)throwsException{

   //实例化DES密钥

   //生成密钥

    SecretKey secretKey =newSecretKeySpec(key, KEY_ALGORITHM);

   returnsecretKey;

  }

 publicstaticStringbytes2String(bytebuf[]){

    StringBuffer sb =newStringBuffer();

   for(inti =0; i < buf.length; i++) {

      String hex = Integer.toHexString(buf[i] &0xFF);

     if(hex.length() ==1) {

        hex ='0'+ hex;

      }

      sb.append(hex);

    }

   returnsb.toString();

  }

 publicstaticbyte[] string2Bytes(String hexString) {

   intlen = hexString.length() /2;

   byte[] result =newbyte[len];

   for(inti =0; i < len; i++) {

      result[i] = Integer.valueOf(hexString.substring(2* i,2* i +2),16).byteValue();

    }

   returnresult;

  }

 publicstaticStringencrypt(String data, String key){

   try{

     //还原密钥

      Key k = toKey(key.getBytes());

      Security.addProvider(newBouncyCastleProvider());

      Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM,"BC");

     //初始化,设置为加密模式

      cipher.init(Cipher.ENCRYPT_MODE, k);

     //执行操作

     returnbytes2String(cipher.doFinal(data.getBytes()));

    }catch(Exception e) {

    }

   returnnull;

  }

 publicstaticStringdecrypt(String data, String key){

   try{

      Key k = toKey(key.getBytes());

      Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM);

     //初始化,设置为解密模式

      cipher.init(Cipher.DECRYPT_MODE, k);

     //执行操作

     returnnewString(cipher.doFinal(string2Bytes(data)));

    }catch(Exception e) {

    }

   returnnull;

  }

}

PHP代码

classOpensslAES

{

   // PHP >= 5.3.0

   constMETHOD ='aes-256-ecb';

   publicstaticfunctionencrypt($message,$key)

   {

       if(mb_strlen($key,'8bit') !==32) {

           thrownewException("Needs a 256-bit key!");

        }

       $ivsize= openssl_cipher_iv_length(self::METHOD);

       $iv= openssl_random_pseudo_bytes($ivsize);

       $ciphertext= openssl_encrypt(

           $message,

           self::METHOD,

           $key,

            OPENSSL_RAW_DATA,

           $iv

        );

       return$iv.$ciphertext;

    }

   publicstaticfunctiondecrypt($message,$key)

   {

       if(mb_strlen($key,'8bit') !==32) {

           thrownewException("Needs a 256-bit key!");

        }

       $ivsize= openssl_cipher_iv_length(self::METHOD);

       $iv= mb_substr($message,0,$ivsize,'8bit');

       $ciphertext= mb_substr($message,$ivsize,null,'8bit');

       returnopenssl_decrypt(

           $ciphertext,

           self::METHOD,

           $key,

            OPENSSL_RAW_DATA,

           $iv

        );

    }

}

// string

$original='9.9';

// encrypt key

$key='9642f6b792d86dadf1144367111964b9';

// uid

$uid='1133317534580800';

// 加密

$toEnc= OpensslAES::encrypt($original, md5($key.$uid);

$toEnc= bin2hex($toEnc);

$toEnc= base64_encode($toEnc);

$toEnc= urlencode($toEnc);

print_r($toEnc);// NmI5ODI0ZjgyMWZiZDM1NTkzOThkYzY1NWIxZjE1OGQ%3D

// 解密

$toDec='NmI5ODI0ZjgyMWZiZDM1NTkzOThkYzY1NWIxZjE1OGQ%3D';

$toDec= urldecode($toDec);

$toDec= base64_decode($toDec);

$toDec= hex2bin($toDec);

$original= OpensslAES::decrypt($toDec, md5($key.$uid));

print_r($original);// 9.9

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,084评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,623评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,450评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,322评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,370评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,274评论 1 300
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,126评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,980评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,414评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,599评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,773评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,470评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,080评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,713评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,852评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,865评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,689评论 2 354

推荐阅读更多精彩内容