des加密 ios java_ios des3加密和3des加密是一样的吗 - CSDN
  • IOSjava支持DES加密

    2014-10-12 10:28:11
    现在我们需要实现的是移动端和后台(java)数据加解密的配合,开始的时候考虑的使用RSA,因为RSA是非对称加密,更加安全点,但是RSA加密的过程中,ios公钥加密的数据,后台java是能够解密成功,但是后台java私钥加密...

    转载请注明博客地址:http://blog.csdn.net/mengxiangyue/article/details/40015727

    最近在考虑数据加密方面的需求,所以对数据加密简单的看了一下,当然不是看的原理,只是看看怎么能够实现。现在我们需要实现的是移动端和后台(java)数据加解密的配合,开始的时候考虑的使用RSA,因为RSA是非对称加密,更加安全点,但是RSA加密的过程中,ios公钥加密的数据,后台java是能够解密成功,但是后台java私钥加密的东西,前端ios,就没有解密成功,实验了很多方法,最终也没有成功,所以就放弃了,转向了安全性差一点的DES加密。

    对于DES、RSA的介绍,自己百度去吧,因为我也说不明白。(上面我没有提Android,因为Android使用的是java,所以应该跟后台一致)

    下面废话不多说,直接贴上代码:

    IOS,需要引入GTMBase64.h、GTMBase64.m、GTMDefines.h,这个github上面有我,自己搜搜吧,还有<CommonCrypto/CommonCryptor.h>。

    #import "ViewController.h"
    #import <CommonCrypto/CommonCryptor.h>
    #import "GTMBase64.h"
    
    @interface ViewController ()
    
    @end
    
    @implementation ViewController
    
    - (void)viewDidLoad {
        [super viewDidLoad];
        
        NSString *key = @"这是个key";
        NSString *encryptedData = [self encryptUseDES:@"this is a text" key:key];
        NSLog(@"加密后的数据是:%@", encryptedData);
        NSLog(@"解密后的数据是:%@", [self decryptUseDES:encryptedData key:key]);
    }
    
    - (void)didReceiveMemoryWarning {
        [super didReceiveMemoryWarning];
        // Dispose of any resources that can be recreated.
    }
    
    /*字符串加密
     *参数
     *plainText : 加密明文
     *key        : 密钥 64位
     */
    - (NSString *) encryptUseDES:(NSString *)plainText key:(NSString *)key
    {
        NSString *ciphertext = nil;
        const char *textBytes = [plainText UTF8String];
        NSUInteger dataLength = [plainText length];
        unsigned char buffer[1024];
        memset(buffer, 0, sizeof(char));
        Byte iv[] = {1,2,3,4,5,6,7,8};
        size_t numBytesEncrypted = 0;
        CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmDES,
                                              kCCOptionPKCS7Padding,
                                              [key UTF8String], kCCKeySizeDES,
                                              iv,
                                              textBytes, dataLength,
                                              buffer, 1024,
                                              &numBytesEncrypted);
        if (cryptStatus == kCCSuccess) {
            NSData *data = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesEncrypted];
            
            ciphertext = [[NSString alloc] initWithData:[GTMBase64 encodeData:data] encoding:NSUTF8StringEncoding];
        }
        return ciphertext;
    }
    
    //解密
    - (NSString *) decryptUseDES:(NSString*)cipherText key:(NSString*)key
    {
        NSData* cipherData = [GTMBase64 decodeString:cipherText];
        unsigned char buffer[1024];
        memset(buffer, 0, sizeof(char));
        size_t numBytesDecrypted = 0;
        Byte iv[] = {1,2,3,4,5,6,7,8};
        CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt,
                                              kCCAlgorithmDES,
                                              kCCOptionPKCS7Padding,
                                              [key UTF8String],
                                              kCCKeySizeDES,
                                              iv,
                                              [cipherData bytes],
                                              [cipherData length],
                                              buffer,
                                              1024,
                                              &numBytesDecrypted);
        NSString* plainText = nil;
        if (cryptStatus == kCCSuccess) {
            NSData* data = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesDecrypted];
            plainText = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
        }
        return plainText;
    }
    
    
    @end
    java 代码:需要自己引入sun.misc.BASE64Decoder.jar

    package com.yue;
    
    import java.io.IOException;
    import java.security.SecureRandom;
    
    import javax.crypto.Cipher;
    import javax.crypto.SecretKey;
    import javax.crypto.SecretKeyFactory;
    import javax.crypto.spec.DESKeySpec;
    
    import Decoder.BASE64Decoder;
    import Decoder.BASE64Encoder;
     
     
    public class DesUtil {
     
        private final static String DES = "DES";
     
        public static void main(String[] args) throws Exception {
            String data = "123 456";
            String key = "abcdefgh";
            System.err.println(encrypt(data, key));
            System.err.println(decrypt(encrypt(data, key), key));
            
            System.out.println(decrypt("JF5dX/TlOg529KAhh+vywjzIp5Msktmf", key));
     
        }
         
        /**
         * Description 根据键值进行加密
         * @param data 
         * @param key  加密键byte数组
         * @return
         * @throws Exception
         */
        public static String encrypt(String data, String key) throws Exception {
            byte[] bt = encrypt(data.getBytes(), key.getBytes());
            String strs = new BASE64Encoder().encode(bt);
            return strs;
        }
     
        /**
         * Description 根据键值进行解密
         * @param data
         * @param key  加密键byte数组
         * @return
         * @throws IOException
         * @throws Exception
         */
        public static String decrypt(String data, String key) throws IOException,
                Exception {
            if (data == null)
                return null;
            BASE64Decoder decoder = new BASE64Decoder();
            byte[] buf = decoder.decodeBuffer(data);
            byte[] bt = decrypt(buf,key.getBytes());
            return new String(bt);
        }
     
        /**
         * Description 根据键值进行加密
         * @param data
         * @param key  加密键byte数组
         * @return
         * @throws Exception
         */
        private static byte[] encrypt(byte[] data, byte[] key) throws Exception {
            // 生成一个可信任的随机数源
            SecureRandom sr = new SecureRandom();
     
            // 从原始密钥数据创建DESKeySpec对象
            DESKeySpec dks = new DESKeySpec(key);
     
            // 创建一个密钥工厂,然后用它把DESKeySpec转换成SecretKey对象
            SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
            SecretKey securekey = keyFactory.generateSecret(dks);
     
            // Cipher对象实际完成加密操作
            Cipher cipher = Cipher.getInstance(DES);
     
            // 用密钥初始化Cipher对象
            cipher.init(Cipher.ENCRYPT_MODE, securekey, sr);
     
            return cipher.doFinal(data);
        }
         
         
        /**
         * Description 根据键值进行解密
         * @param data
         * @param key  加密键byte数组
         * @return
         * @throws Exception
         */
        private static byte[] decrypt(byte[] data, byte[] key) throws Exception {
            // 生成一个可信任的随机数源
            SecureRandom sr = new SecureRandom();
     
            // 从原始密钥数据创建DESKeySpec对象
            DESKeySpec dks = new DESKeySpec(key);
     
            // 创建一个密钥工厂,然后用它把DESKeySpec转换成SecretKey对象
            SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
            SecretKey securekey = keyFactory.generateSecret(dks);
     
            // Cipher对象实际完成解密操作
            Cipher cipher = Cipher.getInstance(DES);
     
            // 用密钥初始化Cipher对象
            cipher.init(Cipher.DECRYPT_MODE, securekey, sr);
     
            return cipher.doFinal(data);
        }
    }

    代码下载地址:http://download.csdn.net/detail/mengxiangyue/8028311


    展开全文
  • des加密java-ios.zip

    2020-06-01 23:32:50
    des加密java-ios.zip博客地址http://blog.csdn.net/mengxiangyue/article/details/40015727
  • 对称加密算法 3desiOS 客户端加密算法 首先进入头文件: #import #import #import -(NSString*)TripleDES:(NSString*)plainText encryptOrDecrypt:(CCOperation)encryptOrDecrypt { const void ...

     对称加密算法 3des 在iOS 客户端加密算法

    首先进入头文件:

    #import <CommonCrypto/CommonDigest.h>  

    #import <CommonCrypto/CommonCryptor.h>

    #import <Security/Security.h>


    -(NSString*)TripleDES:(NSString*)plainText encryptOrDecrypt:(CCOperation)encryptOrDecrypt
    {
        
        const void *vplainText;
        size_t plainTextBufferSize;
        
        if (encryptOrDecrypt == kCCDecrypt)//解密
        {
            NSData *EncryptData = [GTMBase64 decodeData:[plainText dataUsingEncoding:NSUTF8StringEncoding]];
            plainTextBufferSize = [EncryptData length];
            vplainText = [EncryptData bytes];
        }
        else //加密
        {
            NSData* data = [plainText dataUsingEncoding:NSUTF8StringEncoding];
            plainTextBufferSize = [data length];
            vplainText = (const void *)[data bytes];
        }
        
        CCCryptorStatus ccStatus;
        uint8_t *bufferPtr = NULL;
        size_t bufferPtrSize = 0;
        size_t movedBytes = 0;
        
        bufferPtrSize = (plainTextBufferSize + kCCBlockSize3DES) & ~(kCCBlockSize3DES - 1);
        bufferPtr = malloc( bufferPtrSize * sizeof(uint8_t));
        memset((void *)bufferPtr, 0x0, bufferPtrSize);
        // memset((void *) iv, 0x0, (size_t) sizeof(iv));
        
        const void *vkey = (const void *)[DESKEY UTF8String];
        // NSString *initVec = @"init Vec";
        //const void *vinitVec = (const void *) [initVec UTF8String];
        //  Byte iv[] = {0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF};
        ccStatus = CCCrypt(encryptOrDecrypt,
                           kCCAlgorithm3DES,
                           kCCOptionPKCS7Padding | kCCOptionECBMode,
                           vkey,
                           kCCKeySize3DES,
                           nil,
                           vplainText,
                           plainTextBufferSize,
                           (void *)bufferPtr,
                           bufferPtrSize,
                           &movedBytes);
        //if (ccStatus == kCCSuccess) NSLog(@"SUCCESS");
        /*else if (ccStatus == kCC ParamError) return @"PARAM ERROR";
         else if (ccStatus == kCCBufferTooSmall) return @"BUFFER TOO SMALL";
         else if (ccStatus == kCCMemoryFailure) return @"MEMORY FAILURE";
         else if (ccStatus == kCCAlignmentError) return @"ALIGNMENT";
         else if (ccStatus == kCCDecodeError) return @"DECODE ERROR";
         else if (ccStatus == kCCUnimplemented) return @"UNIMPLEMENTED"; */
        
        NSString *result;
        
        if (encryptOrDecrypt == kCCDecrypt)
        {
            result = [[[NSString alloc] initWithData:[NSData dataWithBytes:(const void *)bufferPtr
                                                                    length:(NSUInteger)movedBytes]
                                            encoding:NSUTF8StringEncoding]
                      autorelease];
        }
        else
        {
            NSData *myData = [NSData dataWithBytes:(const void *)bufferPtr length:(NSUInteger)movedBytes];
            result = [GTMBase64 stringByEncodingData:myData];
        }
        
        return result;
    }
    

    上面还有个DESKEY宏定义是

    #define kChosenDigestLength		CC_SHA1_DIGEST_LENGTH
     
    #define DESKEY @"D6D2402F1C98E208FF2E863AA29334BD65AE1932A821502D9E5673CDE3C713ACFE53E2103CD40ED6BEBB101B484CAE83D537806C6CB611AEE86ED2CA8C97BBE95CF8476066D419E8E833376B850172107844D394016715B2E47E0A6EECB3E83A361FA75FA44693F90D38C6F62029FCD8EA395ED868F9D718293E9C0E63194E87"


    java客户端 3DES 解密和加密算法

    public static String encryptThreeDESECB(String src,String key) throws Exception
    {
        DESedeKeySpec dks = new DESedeKeySpec(key.getBytes("UTF-8"));
        SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DESede");
        SecretKey securekey = keyFactory.generateSecret(dks);
        
        Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS5Padding");
        cipher.init(Cipher.ENCRYPT_MODE, securekey);
        byte[] b=cipher.doFinal(src.getBytes());
        
        BASE64Encoder encoder = new BASE64Encoder();
        return encoder.encode(b).replaceAll("\r", "").replaceAll("\n", "");
        
    }
    
    //3DESECB解密,key必须是长度大于等于 3*8 = 24 位
    public static String decryptThreeDESECB(String src,String key) throws Exception
    {
        //--通过base64,将字符串转成byte数组
        BASE64Decoder decoder = new BASE64Decoder();
        byte[] bytesrc = decoder.decodeBuffer(src);
        //--解密的key
        DESedeKeySpec dks = new DESedeKeySpec(key.getBytes("UTF-8"));
        SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DESede");
        SecretKey securekey = keyFactory.generateSecret(dks);
        
        //--Chipher对象解密
        Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS5Padding");
        cipher.init(Cipher.DECRYPT_MODE, securekey);
        byte[] retByte = cipher.doFinal(bytesrc);
        
        return new String(retByte);
    }
    



    亲自测试方法都ok!


    展开全文
  • 转载地址:https://www.cnblogs.com/innchina/p/5066396.html引言 如今手机app五彩缤纷...DES加密是目前最常用的对称加密方式,性能优于非对称加密(RSA),是手机app请求数据加密的优先选择。 DES简介: DES全称...

    引言
         如今手机app五彩缤纷,确保手机用户的数据安全是开发人员必须掌握的技巧,下面通过实例介绍DES在android、ios、java平台的使用方法;
    DES加密是目前最常用的对称加密方式,性能优于非对称加密(RSA),是手机app请求数据加密的优先选择。
     

    DES简介:

         DES全称为Data Encryption Standard,即数据加密标准,是一种使用密钥加密的块算法, 算法的入口参数有三个:Key、Data、Mode。
         Key:为7个字节共56位,是DES算法的工作密钥;
         Data:为8个字节64位,是要被加密或被解密的数据;
         Mode:为DES的工作方式,有两种:加密或解密。
    3DES简介:
         3DES(或称为Triple DES)是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)块密码的通称。它相当于是对每个数据块应用三次DES加密算法。由于计算机运算能力的增强,原版DES密码的密钥长度变得容易被暴力破解;3DES即是设计用来提供一种相对简单的方法,即通过增加DES的密钥长度来避免类似的攻击,而不是设计一种全新的块密码算法。因此比起最初的DES,3DES更为安全。
     
    加密实例:
         java版
         
    package com.v1.linxun.portal.utils;
     
    import java.security.Key;
     
    import javax.crypto.Cipher;
    import javax.crypto.SecretKeyFactory;
    import javax.crypto.spec.DESedeKeySpec;
    import javax.crypto.spec.IvParameterSpec;
     
    /**
     * 3DES加密工具类
     */
    public class Des3Util {
           // 密钥 长度不得小于24
           private final static String secretKey = "123456789012345678901234" ;
           // 向量 可有可无 终端后台也要约定
           private final static String iv = "01234567";
           // 加解密统一使用的编码方式
           private final static String encoding = "utf-8";
     
           /**
           * 3DES加密
           *
           * @param plainText
           *            普通文本
           * @return
           * @throws Exception
           */
           public static String encode(String plainTextthrows Exception {
                Key deskey = null;
                DESedeKeySpec spec = new DESedeKeySpec(secretKey .getBytes());
                SecretKeyFactory keyfactory = SecretKeyFactory.getInstance( "desede");
                 deskey = keyfactory.generateSecret( spec);
     
                Cipher cipher = Cipher.getInstance( "desede/CBC/PKCS5Padding");
                IvParameterSpec ips = new IvParameterSpec( iv.getBytes());
                 cipher.init(Cipher. ENCRYPT_MODEdeskeyips);
                 byte[] encryptData = cipher.doFinal( plainText.getBytes( encoding));
                 return Base64. encode( encryptData);
          }
     
           /**
           * 3DES解密
           *
           * @param encryptText
           *            加密文本
           * @return
           * @throws Exception
           */
           public static String decode(String encryptTextthrows Exception {
                Key deskey = null;
                DESedeKeySpec spec = new DESedeKeySpec( secretKey.getBytes());
                SecretKeyFactory keyfactory = SecretKeyFactory.getInstance( "desede");
                 deskey = keyfactory. generateSecret( spec);
                Cipher cipher = Cipher.getInstance( "desede/CBC/PKCS5Padding" );
                IvParameterSpec ips = new IvParameterSpec( iv.getBytes());
                 cipher. init(Cipher. DECRYPT_MODEdeskeyips);
     
                 byte[] decryptData = cipher. doFinal(Base64. decode(encryptText ));
     
                 return new String( decryptDataencoding);
          }
          
           public static void main(String args[]) throws Exception{
                String str = "你好" ;
                System. out.println( "----加密前-----:" str );
                String encodeStr = Des3Util. encode( str);
                System. out.println( "----加密后-----:" encodeStr );
                System. out.println( "----解密后-----:" + Des3Util.decode( encodeStr));
          }
    }
     

    Android版:

     
    package com.inn.test;
     
    import java.security.Key;
     
    import javax.crypto.Cipher;
    import javax.crypto.SecretKeyFactory;
    import javax.crypto.spec.DESedeKeySpec;
    import javax.crypto.spec.IvParameterSpec;
     
    import android.util.Base64;
     
    /**
     * Android 3DES加密工具类
     */
    public class AndroidDes3Util {
          
           // 密钥 长度不得小于24
           private final static String secretKey = "123456789012345678901234" ;
           // 向量 可有可无 终端后台也要约定
           private final static String iv = "01234567" ;
           // 加解密统一使用的编码方式
           private final static String encoding = "utf-8" ;
     
           /**
           * 3DES加密
           *
           * @param plainText
           *            普通文本
           * @return
           * @throws Exception
           */
           public static String encode(String plainText) throws Exception {
                Key deskey = null ;
                DESedeKeySpec spec = new DESedeKeySpec(secretKey .getBytes());
                SecretKeyFactory keyfactory = SecretKeyFactory.getInstance( "desede");
                deskey = keyfactory.generateSecret(spec);
     
                Cipher cipher = Cipher.getInstance( "desede/CBC/PKCS5Padding");
                IvParameterSpec ips = new IvParameterSpec( iv.getBytes());
                cipher.init(Cipher. ENCRYPT_MODE , deskey, ips);
                 byte [] encryptData = cipher.doFinal(plainText.getBytes(encoding ));
                 return Base64.encodeToString(encryptData,Base64. DEFAULT );
          }
     
           /**
           * 3DES解密
           *
           * @param encryptText
           *            加密文本
           * @return
           * @throws Exception
           */
           public static String decode(String encryptText) throws Exception {
                Key deskey = null ;
                DESedeKeySpec spec = new DESedeKeySpec( secretKey.getBytes());
                SecretKeyFactory keyfactory = SecretKeyFactory.getInstance( "desede" );
                deskey = keyfactory. generateSecret(spec);
                Cipher cipher = Cipher.getInstance( "desede/CBC/PKCS5Padding" );
                IvParameterSpec ips = new IvParameterSpec( iv.getBytes());
                cipher. init(Cipher. DECRYPT_MODE, deskey, ips);
     
                 byte [] decryptData = cipher.doFinal(Base64. decode(encryptText, Base64. DEFAULT));
     
                 return new String (decryptData, encoding);
          }
    }
     
    IOS版:
     
    //
    //  DES3EncryptUtil.h
    //  DES3加解密工具
    //
    //  Created by xc on 15/12/18.
    //  Copyright © 2015年 xc. All rights reserved.
    //

    #import <Foundation/Foundation.h>

    @interface DES3EncryptUtil : NSObject

    // 加密方法
    + (NSString*)encrypt:(NSString*)plainText;

    // 解密方法
    + (NSString*)decrypt:(NSString*)encryptText;

    @end
     
    //
    //  DES3EncryptUtil.m
    //  DES3加解密工具
    //  Created by xc on 15/12/18.
    //  Copyright © 2015年 xc. All rights reserved.

    #import <Foundation/Foundation.h>
    #import <CommonCrypto/CommonCryptor.h>
    #import "MyBase64.h"

    //秘钥
    #define gkey            @"xiangchao@qq.comrnnchina"
    //向量
    #define gIv             @"01234567"

    @implementation DES3EncryptUtil : NSObject

    // 加密方法
    + (NSString*)encrypt:(NSString*)plainText {
        NSData* data = [plainText dataUsingEncoding:NSUTF8StringEncoding];
        size_t plainTextBufferSize = [data length];
        const void *vplainText = (const void *)[data bytes];
        
        CCCryptorStatus ccStatus;
        uint8_t *bufferPtr = NULL;
        size_t bufferPtrSize = 0;
        size_t movedBytes = 0;
        
        bufferPtrSize = (plainTextBufferSize + kCCBlockSize3DES) & ~(kCCBlockSize3DES - 1);
        bufferPtr = malloc( bufferPtrSize * sizeof(uint8_t));
        memset((void *)bufferPtr, 0x0, bufferPtrSize);
        
        const void *vkey = (const void *) [gkey UTF8String];
        const void *vinitVec = (const void *) [gIv UTF8String];
        
        ccStatus = CCCrypt(kCCEncrypt,
                           kCCAlgorithm3DES,
                           kCCOptionPKCS7Padding,
                           vkey,
                           kCCKeySize3DES,
                           vinitVec,
                           vplainText,
                           plainTextBufferSize,
                           (void *)bufferPtr,
                           bufferPtrSize,
                           &movedBytes);
        
        NSData *myData = [NSData dataWithBytes:(const void *)bufferPtr length:(NSUInteger)movedBytes];
        NSString *result = [MyBase64 base64EncodedStringFrom:myData];
        return result;
    }

    // 解密方法
    + (NSString*)decrypt:(NSString*)encryptText {
        NSData *encryptData = [MyBase64 dataWithBase64EncodedString:encryptText];
        size_t plainTextBufferSize = [encryptData length];
        const void *vplainText = [encryptData bytes];
        
        CCCryptorStatus ccStatus;
        uint8_t *bufferPtr = NULL;
        size_t bufferPtrSize = 0;
        size_t movedBytes = 0;
        
        bufferPtrSize = (plainTextBufferSize + kCCBlockSize3DES) & ~(kCCBlockSize3DES - 1);
        bufferPtr = malloc( bufferPtrSize * sizeof(uint8_t));
        memset((void *)bufferPtr, 0x0, bufferPtrSize);
        
        const void *vkey = (const void *) [gkey UTF8String];
        const void *vinitVec = (const void *) [gIv UTF8String];
        
        ccStatus = CCCrypt(kCCDecrypt,
                           kCCAlgorithm3DES,
                           kCCOptionPKCS7Padding,
                           vkey,
                           kCCKeySize3DES,
                           vinitVec,
                           vplainText,
                           plainTextBufferSize,
                           (void *)bufferPtr,
                           bufferPtrSize,
                           &movedBytes);
        
        NSString *result = [[NSString alloc] initWithData:[NSData dataWithBytes:(const void *)bufferPtr
                                                                         length:(NSUInteger)movedBytes] encoding:NSUTF8StringEncoding] ;
        return result;
    }

    @end
     
    IOS加密工具中会将加密后的密文 转化程Base64的字符串,用到了Base64编码工具,如下
     
    //
    //  CommonFunc.h
    //  PRJ_base64
    //
    //  Created by wangzhipeng on 12-11-29.
    //  Copyright (c) 2012年 com.comsoft. All rights reserved.
    //

    #import <Foundation/Foundation.h>

    #define __BASE64( text )        [CommonFunc base64StringFromText:text]
    #define __TEXT( base64 )        [CommonFunc textFromBase64String:base64]

    @interface MyBase64 : NSObject

    /******************************************************************************
    函数名称 : + (NSString *)base64StringFromText:(NSString *)text
    函数描述 : 将文本转换为base64格式字符串
    输入参数 : (NSString *)text    文本
    输出参数 : N/A
    返回参数 : (NSString *)    base64格式字符串
    备注信息 :
    ******************************************************************************/
    + (NSString *)base64StringFromText:(NSString *)text;

    /******************************************************************************
    函数名称 : + (NSString *)base64StringFromText:(NSString *)text
    函数描述 : 将文本转换为base64格式字符串
    输入参数 : (NSString *)text    文本
    输出参数 : N/A
    返回参数 : (NSString *)    base64格式字符串
    备注信息 :
    ******************************************************************************/
    + (NSString *)base64EncodedStringFrom:(NSData *)data;

    /******************************************************************************
    函数名称 : + (NSString *)textFromBase64String:(NSString *)base64
    函数描述 : 将base64格式字符串转换为文本
    输入参数 : (NSString *)base64  base64格式字符串
    输出参数 : N/A
    返回参数 : (NSString *)    文本
    备注信息 :
    ******************************************************************************/
    + (NSString *)textFromBase64String:(NSString *)base64;

    /******************************************************************************
    函数名称 : + (NSString *)textFromBase64String:(NSString *)base64
    函数描述 : 将base64格式字符串转换为文本
    输入参数 : (NSString *)base64  base64格式字符串
    输出参数 : N/A
    返回参数 : (NSString *)    文本
    备注信息 :
    ******************************************************************************/
    + (NSData *)dataWithBase64EncodedString:(NSString *)string;

    @end
     


    //
    //  CommonFunc.m
    //  PRJ_base64
    //
    //  Created by wangzhipeng on 12-11-29.
    //  Copyright (c) 2012年 com.comsoft. All rights reserved.
    //

    #import "MyBase64.h"

    //引入IOS自带密码库
    #import <CommonCrypto/CommonCryptor.h>

    //空字符串
    #define LocalStr_None   @""

    static const char encodingTable[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";

    @implementation MyBase64 : NSObject

    + (NSString *)base64StringFromText:(NSString *)text
    {
        if (text && ![text isEqualToString:LocalStr_None]) {
            //取项目的bundleIdentifier作为KEY  改动了此处
            //NSString *key = [[NSBundle mainBundle] bundleIdentifier];
            NSData *data = [text dataUsingEncoding:NSUTF8StringEncoding];
            //IOS 自带DES加密 Begin  改动了此处
            //data = [self DESEncrypt:data WithKey:key];
            //IOS 自带DES加密 End
            return [self base64EncodedStringFrom:data];
        }
        else {
            return LocalStr_None;
        }
    }

    + (NSString *)textFromBase64String:(NSString *)base64
    {
        if (base64 && ![base64 isEqualToString:LocalStr_None]) {
            //取项目的bundleIdentifier作为KEY   改动了此处
            //NSString *key = [[NSBundle mainBundle] bundleIdentifier];
            NSData *data = [self dataWithBase64EncodedString:base64];
            //IOS 自带DES解密 Begin    改动了此处
            //data = [self DESDecrypt:data WithKey:key];
            //IOS 自带DES加密 End
            return [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
        }
        else {
            return LocalStr_None;
        }
    }

    /******************************************************************************
    函数名称 : + (NSData *)DESEncrypt:(NSData *)data WithKey:(NSString *)key
    函数描述 : 文本数据进行DES加密
    输入参数 : (NSData *)data
    (NSString *)key
    输出参数 : N/A
    返回参数 : (NSData *)
    备注信息 : 此函数不可用于过长文本
    ******************************************************************************/
    + (NSData *)DESEncrypt:(NSData *)data WithKey:(NSString *)key
    {
        char keyPtr[kCCKeySizeAES256+1];
        bzero(keyPtr, sizeof(keyPtr));
        
        [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];
        
        NSUInteger dataLength = [data length];
        
        size_t bufferSize = dataLength + kCCBlockSizeAES128;
        void *buffer = malloc(bufferSize);
        
        size_t numBytesEncrypted = 0;
        CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmDES,
                                              kCCOptionPKCS7Padding | kCCOptionECBMode,
                                              keyPtr, kCCBlockSizeDES,
                                              NULL,
                                              [data bytes], dataLength,
                                              buffer, bufferSize,
                                              &numBytesEncrypted);
        if (cryptStatus == kCCSuccess) {
            return [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted];
        }
        
        free(buffer);
        return nil;
    }

    /******************************************************************************
    函数名称 : + (NSData *)DESEncrypt:(NSData *)data WithKey:(NSString *)key
    函数描述 : 文本数据进行DES解密
    输入参数 : (NSData *)data
    (NSString *)key
    输出参数 : N/A
    返回参数 : (NSData *)
    备注信息 : 此函数不可用于过长文本
    ******************************************************************************/
    + (NSData *)DESDecrypt:(NSData *)data WithKey:(NSString *)key
    {
        char keyPtr[kCCKeySizeAES256+1];
        bzero(keyPtr, sizeof(keyPtr));
        
        [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];
        
        NSUInteger dataLength = [data length];
        
        size_t bufferSize = dataLength + kCCBlockSizeAES128;
        void *buffer = malloc(bufferSize);
        
        size_t numBytesDecrypted = 0;
        CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt, kCCAlgorithmDES,
                                              kCCOptionPKCS7Padding | kCCOptionECBMode,
                                              keyPtr, kCCBlockSizeDES,
                                              NULL,
                                              [data bytes], dataLength,
                                              buffer, bufferSize,
                                              &numBytesDecrypted);
        
        if (cryptStatus == kCCSuccess) {
            return [NSData dataWithBytesNoCopy:buffer length:numBytesDecrypted];
        }
        
        free(buffer);
        return nil;
    }

    /******************************************************************************
    函数名称 : + (NSData *)dataWithBase64EncodedString:(NSString *)string
    函数描述 : base64格式字符串转换为文本数据
    输入参数 : (NSString *)string
    输出参数 : N/A
    返回参数 : (NSData *)
    备注信息 :
    ******************************************************************************/
    + (NSData *)dataWithBase64EncodedString:(NSString *)string
    {
        if (string == nil)
            [NSException raise:NSInvalidArgumentException format:nil];
        if ([string length] == 0)
            return [NSData data];
        
        static char *decodingTable = NULL;
        if (decodingTable == NULL)
        {
            decodingTable = malloc(256);
            if (decodingTable == NULL)
                return nil;
            memset(decodingTable, CHAR_MAX, 256);
            NSUInteger i;
            for (i = 0; i < 64; i++)
                decodingTable[(short)encodingTable[i]] = i;
        }
        
        const char *characters = [string cStringUsingEncoding:NSASCIIStringEncoding];
        if (characters == NULL)     //  Not an ASCII string!
            return nil;
        char *bytes = malloc((([string length] + 3) / 4) * 3);
        if (bytes == NULL)
            return nil;
        NSUInteger length = 0;
        
        NSUInteger i = 0;
        while (YES)
        {
            char buffer[4];
            short bufferLength;
            for (bufferLength = 0; bufferLength < 4; i++)
            {
                if (characters[i] == '\0')
                    break;
                if (isspace(characters[i]) || characters[i] == '=')
                    continue;
                buffer[bufferLength] = decodingTable[(short)characters[i]];
                if (buffer[bufferLength++] == CHAR_MAX)      //  Illegal character!
                {
                    free(bytes);
                    return nil;
                }
            }
            
            if (bufferLength == 0)
                break;
            if (bufferLength == 1)      //  At least two characters are needed to produce one byte!
            {
                free(bytes);
                return nil;
            }
            
            //  Decode the characters in the buffer to bytes.
            bytes[length++] = (buffer[0] << 2) | (buffer[1] >> 4);
            if (bufferLength > 2)
                bytes[length++] = (buffer[1] << 4) | (buffer[2] >> 2);
            if (bufferLength > 3)
                bytes[length++] = (buffer[2] << 6) | buffer[3];
        }
        
        bytes = realloc(bytes, length);
        return [NSData dataWithBytesNoCopy:bytes length:length];
    }

    /******************************************************************************
    函数名称 : + (NSString *)base64EncodedStringFrom:(NSData *)data
    函数描述 : 文本数据转换为base64格式字符串
    输入参数 : (NSData *)data
    输出参数 : N/A
    返回参数 : (NSString *)
    备注信息 :
    ******************************************************************************/
    + (NSString *)base64EncodedStringFrom:(NSData *)data
    {
        if ([data length] == 0)
            return @"";
        
        char *characters = malloc((([data length] + 2) / 3) * 4);
        if (characters == NULL)
            return nil;
        NSUInteger length = 0;
        
        NSUInteger i = 0;
        while (i < [data length])
        {
            char buffer[3] = {0,0,0};
            short bufferLength = 0;
            while (bufferLength < 3 && i < [data length])
                buffer[bufferLength++] = ((char *)[data bytes])[i++];
            
            //  Encode the bytes in the buffer to four characters, including padding "=" characters if necessary.
            characters[length++] = encodingTable[(buffer[0] & 0xFC) >> 2];
            characters[length++] = encodingTable[((buffer[0] & 0x03) << 4) | ((buffer[1] & 0xF0) >> 4)];
            if (bufferLength > 1)
                characters[length++] = encodingTable[((buffer[1] & 0x0F) << 2) | ((buffer[2] & 0xC0) >> 6)];
            else characters[length++] = '=';
            if (bufferLength > 2)
                characters[length++] = encodingTable[buffer[2] & 0x3F];
            else characters[length++] = '=';
        }
        
        return [[NSString alloc] initWithBytesNoCopy:characters length:length encoding:NSASCIIStringEncoding freeWhenDone:YES];
    }

    @end
     
    到此为止,三平台的加密已经全部结束,代码可以直接使用。

    展开全文
  • EncryptUtilfeiyangklDES一行代码完成DES加密,加密模式 DES + CBC JAVA OC 通用

    EncryptUtil

    一行代码完成DES加密,加密模式 DES + CBC

    githubDemo:https://github.com/feiyangkl/EncryptUtil

    DEMO GIF

    DEMO 简介

    • 最近项目中用到DES加密,在这里整理成篇,供大家参考阅读,在使用该demo过程中,你可能会遇到一些问题,首先你需要看一下下面的demo简介,看看该demo 是否适合你的项目。

    • 项目中的DES加解密主要用在网络请求过程中对上传的参数进行加密,对从后台服务器获取的数据进行解密。

    • 整体的加密流程为:

      • 加密的过程: 参数字典 –> json字符串 –> base64加密后的字符串 –> DES加密后base64再加密 –> 输出最终加密后的字符串;

      • 解密的过程 : 后台服务器获取加密的字符串 –>base64解密 –> DES解密后base64解密 –> json字符串 –> 数据字典;(与加密的过程相反)

    网上对DES的详细介绍已经有很多,在这里不做赘述,如果你需要了解这些知识,google.

    我们公司后台为JAVA,移动端有iOS与Android, 讨论后选择DES的加密模式为 DES + CBC (注意是否满足你的加密需求)。

    为什么选择这种加密模式:

    如果采用PKCS7Padding或者PKCS5Padding这种加密方式,末端添加的数据可能不固定,在解码后需要把末端多余的字符去掉,比较棘手。

    如果不管补齐多少位,末端都是’\0’,去掉的话比较容易操作。 最主要的是能使得

    iOS/Android/PHP相互通信,也是加密过程中最难搞的地方,尤其需要开发者注意。

    项目中用到了 google 的 base64 加解密库 GTMBase64,但是这个库已经有很多年没有更新 还是 MRC 开发模式,需要手动配置一下:

    1.选择项目中的Targets,选中你所要操作的Target,
    2.选Build Phases,在其中Complie Sources中选择需要ARC的文件双击,并在输入框中输入 -fno-objc-arc

    DEMO 使用示例

    //加密
    
    /// 加密
    NSMutableDictionary *dic=[NSMutableDictionary dictionary];
    [dic setValue:@"111111" forKey:@"password"];
    [dic setValue:@"admin" forKey:@"userName"];
    
    /*
    加密{"userName":"admin","password":"111111"}和
    {
    "userName" : "admin",
    "password" : "111111"
    }
    加密后结果是不一样的,一定要确定公司后台是怎么加密的,要不然有可能会错误
    */
    NSString *jsonstr = [dic JSONString];
    self.lb_show.text = [EncryptUtil encryptUseDES:jsonstr key:gkey];
    
    //加密结果 iMXucxT4Z6v0ZILRJtUX1W/8KfR1wvqqdDxHiOdfTvkdVQQnJ7p1DdMPQXM60BwNHBdjhTqbnXIN
    eEYVIHbb6w==
    
    //解密
    
    - (IBAction)clickDecodeBtn:(UIButton *)sender {
    
    //上面加密的结果
    NSString *AESString = @"iMXucxT4Z6v0ZILRJtUX1W/8KfR1wvqqdDxHiOdfTvkdVQQnJ7p1DdMPQXM60BwNHBdjhTqbnXIN
    eEYVIHbb6w==";
    
    ///解密
    self.lb_show.text = [EncryptUtil decryptUseDES:self.lb_show.text key:gkey];
    
    解密结果:{"userName":"admin","password":"111111"}
    
    }
    java 加密
    /**
    * <li>
    * 方法名称:encrypt</li> <li>
    * 加密方法
    * @param xmlStr
    *            需要加密的消息字符串
    * @return 加密后的字符串
    */
    public static String encrypt(String xmlStr) {
    byte[] encrypt = null;
    
    try {
    // 取需要加密内容的utf-8编码。
    encrypt = xmlStr.getBytes("utf-8");
    } catch (UnsupportedEncodingException e) {
    e.printStackTrace();
    }
    // 取MD5Hash码,并组合加密数组
    byte[] md5Hasn = null;
    try {
    
    //            md5Hash = EncryptUtil.MD5Hash(temp, 16, temp.length - 16);
    
    md5Hasn = EncryptUtil.MD5Hash(encrypt, 0, encrypt.length);
    } catch (Exception e) {
    e.printStackTrace();
    }
    // 组合消息体
    byte[] totalByte = EncryptUtil.addMD5(md5Hasn, encrypt);
    
    // 取密钥和偏转向量
    byte[] key = new byte[8];
    byte[] iv = new byte[8];
    getKeyIV(EncryptUtil.key, key, iv);
    
    SecretKeySpec deskey = new SecretKeySpec(key, "DES");
    
    IvParameterSpec ivParam = new IvParameterSpec(iv);
    
    // 使用DES算法使用加密消息体
    byte[] temp = null;
    try {
    temp = EncryptUtil.DES_CBC_Encrypt(totalByte, deskey, ivParam);
    } catch (Exception e) {
    e.printStackTrace();
    }
    
    // 使用Base64加密后返回
    return new BASE64Encoder().encode(temp);
    }
    
    ios加密
    /// 加密方法
    + (NSString *) encryptUseDES:(NSString *)plainText key:(NSString *)key
    {
    /// 转换成data
    NSData* plainTextdata = [plainText dataUsingEncoding:NSUTF8StringEncoding];
    NSUInteger plainTextdatLength = [plainTextdata length];
    /// 将data数据MD5加密
    unsigned char digest[16];
    CC_MD5([plainTextdata bytes],(CC_LONG) plainTextdatLength, digest);
    
    
    // 总长度 MD5 + plainText
    NSUInteger plainTextBufferTotalSize  = 16 +plainTextdatLength;
    
    
    // 将plainText 转换成bytes
    Byte *testByte = (Byte *)[plainTextdata bytes];
    
    // 定义totalByte
    Byte totalByte[plainTextBufferTotalSize];
    
    
    for (int i = 0; i < plainTextBufferTotalSize; ++i) {
    if (i<16) {
    totalByte[i] =digest[i];
    }else{
    totalByte[i] =testByte[i - 16];
    }
    }
    
    /// 将key base64 编码
    NSData *baseKey = [GTMBase64 decodeString:key];
    Byte *buf = (Byte *)[baseKey bytes];
    
    Byte key1[8];
    Byte iv2[8];
    for (int i = 0; i < 8; i++) {
    
    key1[i] = buf[i];
    }
    //    // 后8位为iv向量
    for (int i = 0; i < 8 ; i++) {
    iv2[i] = buf[i + 8];
    }
    
    NSString *ciphertext = nil;
    unsigned char buffer[1024];
    memset(buffer, 0, sizeof(char));
    size_t numBytesEncrypted = 0;
    CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt,
    kCCAlgorithmDES,
    kCCOptionPKCS7Padding,
    key1,
    kCCKeySizeDES,
    iv2,
    totalByte,
    plainTextBufferTotalSize,
    buffer,
    1024,
    &numBytesEncrypted);
    if (cryptStatus == kCCSuccess) {
    
    NSData *data = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesEncrypted];
    ciphertext = [[NSString alloc] initWithData:[GTMBase64 encodeData:data] encoding:NSUTF8StringEncoding];
    }
    return ciphertext;
    }
    
    
    java 解密
    /**
    * <li>
    * 方法名称:encrypt</li> <li>
    * 功能描述:
    *
    * <pre>
    * 解密方法
    * </pre>
    *
    * </li>
    *
    * @param xmlStr
    *            需要解密的消息字符串
    * @return 解密后的字符串
    * @throws Exception
    */
    public static String decrypt(String xmlStr) throws Exception {
    // base64解码
    BASE64Decoder decoder = new BASE64Decoder();
    byte[] encBuf = null;
    try {
    encBuf = decoder.decodeBuffer(xmlStr);
    } catch (IOException e) {
    e.printStackTrace();
    }
    
    // 取密钥和偏转向量
    byte[] key = new byte[8];
    byte[] iv = new byte[8];
    getKeyIV(EncryptUtil.key, key, iv);
    
    SecretKeySpec deskey = new SecretKeySpec(key, "DES");
    IvParameterSpec ivParam = new IvParameterSpec(iv);
    
    // 使用DES算法解密
    byte[] temp = null;
    try {
    temp = EncryptUtil.DES_CBC_Decrypt(encBuf, deskey, ivParam);
    } catch (Exception e) {
    e.printStackTrace();
    }
    
    // 进行解密后的md5Hash校验
    byte[] md5Hash = null;
    try {
    md5Hash = EncryptUtil.MD5Hash(temp, 16, temp.length - 16);
    } catch (Exception e) {
    e.printStackTrace();
    }
    
    // 进行解密校检
    for (int i = 0; i < md5Hash.length; i++) {
    if (md5Hash[i] != temp[i]) {
    // System.out.println(md5Hash[i] + "MD5校验错误。" + temp[i]);
    throw new Exception("MD5校验错误。");
    }
    }
    
    // 返回解密后的数组,其中前16位MD5Hash码要除去。
    return new String(temp, 16, temp.length - 16, "utf-8");
    }
    
    ios 解密
    
    /// 解密方法
    + (NSString *) decryptUseDES:(NSString *)plainText key:(NSString *)key {
    
    
    // plainTextData转换 base64
    NSData *BasePlainTextData = [GTMBase64 decodeString:plainText];
    // 将BasePlainTextDatabase64转换为byte数组
    Byte *BasePlainTextDataByte = (Byte *)[BasePlainTextData bytes];
    
    // 将key base64解码
    NSData *baseKey = [GTMBase64 decodeString:key];
    // 将key 转换成 byte数组
    Byte *buf = (Byte *)[baseKey bytes];
    
    // 定义key iv byte数组
    Byte keyByte[8];
    Byte ivByte[8];
    for (int i = 0; i < 8; i++) {
    keyByte[i] = buf[i];
    }
    //    // 后8位为iv向量
    for (int i = 0; i < 8 ; i++) {
    ivByte[i] = buf[i + 8];
    }
    
    /// 返回值长度
    size_t bufferSize = BasePlainTextData.length;
    
    // 字符串长度比较长 返回值给大点
    unsigned char buffer[1024];
    memset(buffer,0,sizeof(char));
    size_t numBytesEncrypted = 0;
    CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt,
    kCCAlgorithmDES,
    kCCOptionPKCS7Padding,
    keyByte,
    kCCKeySizeDES,
    ivByte,
    BasePlainTextDataByte,
    bufferSize,
    buffer,
    1024,
    &numBytesEncrypted);
    
    
    NSData *resultdata;
    if (cryptStatus == kCCSuccess) {
    
    resultdata = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesEncrypted];
    }
    
    
    Byte *resultByte = (Byte *)[resultdata bytes];
    
    
    // 返回数组长度 减去MD5加密的16
    size_t returnLength = resultdata.length - 16;
    /// 定义
    Byte decryptionByte[returnLength];
    
    for (int i = 0; i < returnLength; ++i) {
    decryptionByte[i] = resultByte[i+16];
    }
    
    /// md5 校验
    //    unsigned char digest[16];
    //    CC_MD5(decryptionByte,returnLength, digest);
    //    NSData *md5data = [NSData dataWithBytes:digest length:16];
    
    // 进行解密校检
    //    Byte *md5bte= (Byte *)[md5data bytes];
    
    //    for (int i = 0; i < 40; i++) {
    //
    //
    //        if (md5bte[i] !=decryptionByte[i] ) {
    //            // System.out.println(md5Hash[i] + "MD5校验错误。" + temp[i]);
    //            //            throw new Exception("MD5校验错误。");
    //
    //            NSLog(@"c1111uowu");
    //        }else{
    //            NSLog(@"cuowu");
    //        }
    //    }
    
    
    NSData *namedata = [[NSData alloc] initWithBytes:decryptionByte length:returnLength];
    
    NSString *str = [[NSString alloc] initWithData:namedata encoding:NSUTF8StringEncoding];
    NSLog(@"%@",str);
    
    return str;
    
    }
    

    项目中遇到的一些坑,在 DEMO 中都已经注释出来,写的比较清楚,如果该 DEMO 帮助了您,也希望能给个 star

    鼓励一下,如果在使用中您有任何问题,可以在 github issues,我会尽自己能力给您答复 。

    在这里感谢这些 blog 的作者,让我在开发过程中少走了很多弯路:

    [http://www.open-open.com/lib/view/open1452738808948.html)

    [https://my.oschina.net/jsan/blog/54385)

    [http://blog.csdn.net/j_akill/article/details/44079597]

    [http://blog.csdn.net/jbjwpzyl3611421/article/details/18256917)

    [https://github.com/IMCCP/CCPAESEncode/blob/master/CCPAESEncode)

    展开全文
  • ios des加密与解密
  • 移动开发中遇到的最让人纠结的要属Java、Android和iPhone三个平台加解密不一致的问题。因为手机端后台通常是用JAVA开发的Web Service,Android和iPhone客户端调用同样的Web Service接口,为了数据安全考虑,要对数据...
  • android ios java后台通用DES base64加密
  • 3DES加密java/OC

    2016-01-11 17:47:27
    移动开发中遇到的最让人纠结的要属Java、Android和iPhone三个平台加解密不一致的问题。因为手机端后台通常是用JAVA开发的Web Service,Android和iPhone客户端调用同样的Web Service接口,为了数据安全考虑,要对数据...
  • php、java、android、ios通用的3des方法 php class DES3 { var $key = "my.oschina.net/penngo?#@"; var $iv = "01234567"; function encrypt($input){ $size = mcrypt_get_block_siz
  • 引言  如今手机app五彩缤纷,...DES加密是目前最常用的对称加密方式,性能优于非对称加密(RSA),是手机app请求数据加密的优先选择。   伦理片 http://www.dotdy.com/ DES简介:  DES全称为Data Enc
  • 是用Java开发的,客户端要同时支持多平台(Android、iOS),在处理iOSDES加密的时候遇到了一些问题,起初 怎么调都调不成和Android端生成的密文相同。最终一个忽然的想法让我找到了问题的所在,现在将代码总结...
  • 我对应着Java上解密方法找到一些适合iOS的DES加解密算法,特总结一下1、使用DES加密://加密 +(NSString *) encryptUseDES2:(NSString *)plainText key:(NSString *)key{ NSString *ciphertext = nil; const char ...
  • 本文全部转载自:http://www.cnblogs.com/hjtdlx/p/3926141.htmlAndroid、iPhone和Java三个平台一致的加密工具先前一直在做安卓,最近要开发iPhone客户端,这其中遇到的最让人纠结的要属Java、Android和iPhone三个...
  • kCCAlgorithm3DES,// 加密根据哪个标准(des,3des,aes。。。。) kCCOptionPKCS7Padding,// 选项分组密码算法(des:对每块分组加一次密 3DES:对每块分组加三个不同的密) vkey, //密钥 加密和解密的密钥必须一致...
  • 最近做了一个移动项目,是有服务器和客户端类型的项目,客户端是要登录才行的,登录的密码要用DES加密,服务器是用Java开发的,客户端要同时支持多平台(Android、iOS),在处理iOSDES加密的时候遇到了一些问题,...
  • 先简单说一下什么是DES加密DES加密是一种对称加密方式,在一端对数据加密,
  • 一.HASH散列算法 1.MD5算法 不可逆 128位或者64位串,byte数字长度就是16和8,一般表示是使用16进制来表示的话,1个byte转换成2个16bit,分别表示高地位,所以生成的字符串是16位或者是32位的,16位其实是从32位...
  • 关于des加密的神坑

    2019-05-15 18:04:15
    今天,因为项目需求啊,一些接口是暴露出去的,这时候为了安全性,自然要对data流进行动态流加密,前端是iOS,因为看网上说iOSjava对接rsa有坑,所以就用了des加密,然而,des加密原来也有坑!!! 首先,des加密之后的字符串,...
1 2 3 4 5 ... 20
收藏数 933
精华内容 373
关键字:

des加密 ios java