<link href="/styles/hl.css" rel="stylesheet" type="text/css">前段时间由于工作需要编写了一个blowfish的php module,从
blowfish的主页上下载的加密解密实现代码,自己加密、自己解密都没啥问题,但到了和别人联调的时候,对方用java写的blowfish解密程序却死活解不出来我加密的串。
查看对方的java代码,没想到blowfish除了密钥,还有那么多可配参数,java代码里写的解密模式为"cfb/nopadding",这是什么?仔细查了手册,除了cfb,还有ecb,
cbc....我晕,blowfish主页上提供的代码都没有这些东西啊!
跑去问计算机安全方面的“伪专家”,他答道:
“这些只是加密模式,任何对称加密
算法都有这几种模式”
“那我应该用哪种模式才能让别人的java代码正确解密我的串?”
“不同模式跟加密
算法没关系,加密出来的串都一样,你就用blowfish主页上的那些代码就行了”
说了等于没说。
我改为自己找资料,最后有了结果:不同对称加密
算法(像DES、blowfish)确实都有那几种加密模式(ecb、
cbc、cfb等),但并不是跟加密
算法没关系,使用不同的加密模式,
加密出来的串都是不同的!
使用什么加密模式,解密时也必须使用相同的模式,这就是对方无法解密我的串的原因——我压根就没使用任何加密模式...直接用Bruce Schneier老兄写的blowfish代码没戏了,我只能转而使用
mcrypt,这个开源包不仅提供了各种对称加密
算法,还提供了不同的加密模式,好用多了。
下载、编译成动态链接库libmcrypt.so,和我的测试代码链接运行,发现当我加密字符串“hello”,得出来得还是“hello”,再次抓狂,仔细看了mcrypt的示例代码??唉,我怎么稀里糊涂的把被加密的字符串声明成const了....最后能顺利编译运行的代码是:
char text[1024];
char *m_crypt_iv = "0808008";
char *m_dest = "hello";
char *m_key = "abcdefg";
MCRYPT td;
td=mcrypt_module_open("blowfish",NULL,"cfb",NULL);
if(td==MCRYPT_FAILED)
printf("wrong!\n");
i=mcrypt_generic_init(td,m_key,strlen(m_key),m_crypt_iv);
if(i<0)
printf("wrong!\n");
memset(text,0,sizeof(text));
memmove(text,m_dest,strlen(m_dest));
mcrypt_generic(td,text,text_len);
mcrypt_generic_deinit(td);
mcrypt_module_close(td);
其中的m_crypt_iv是cfb加密模式使用的初始向量,这段代码之所以不对被加密串进行64bit的填充(即nopadding),是因为cfb模式不用填充。
加密
算法本身解决了,在编译PHP module时把libmcrypt.a加上,编出来的module就可以直接使用了。
相关推荐
源码中的"blowfish.inc"可能包含了Blowfish算法的实现,通常会包括上述步骤的函数定义,以及对S盒和P盒的初始化。而"blowfish"可能是示例程序或者库文件,用于演示如何使用这个算法进行加密和解密。 理解并掌握Blow...
blowfish算法,包括Blowfish-ECB,Blowfish-CBC,Blowfish-CTR,Blowfish-OFB,Blowfish-CFB,目前我的Demo只实现了ECB是如何运用的。[/b][/i]注意:嵌入式开发的小伙伴们,如果blowfish.h找不到头文件的时候,需要将...
Blowfish算法是一种著名的对称加密算法,由Bruce Schneier在1993年设计。它以其高效、安全和可变密钥长度(32到448位)而受到广泛欢迎。C#是一种通用的、面向对象的编程语言,广泛应用于Windows平台的软件开发,包括...
### C# Blowfish 加密算法知识点详解 #### 一、Blowfish算法简介 Blowfish是一种对称密钥块加密算法,由Bruce Schneier在1993年设计并发布。它支持可变长度的密钥(从32位到448位),并能处理64位数据块。Blowfish...
**Blowfish加密算法概述** Blowfish是一种对称加密算法,由Bruce Schneier于1993年设计。它的主要特点是速度快、安全性高,适用于软件和硬件实现。Blowfish采用了一种称为Feistel网络的结构,通过多次迭代变换来...
在Java编程环境中,我们可以创建`Blowfish.java`和`BlowfishTest.java`两个文件来实现Blowfish算法。`Blowfish.java`通常会包含Blowfish类,其中定义了加密和解密的函数,以及密钥的设置方法。`BlowfishTest.java`则...
在Visual Studio 2010(VS2010)中编写Blowfish加密程序,开发者通常会利用C或C++语言,因为这两种语言都支持底层操作,对于处理加密算法这样需要高性能的任务非常合适。在描述中提到参考了OpenSSL库,OpenSSL是一个...
### Blowfish算法详解 #### 一、Blowfish算法概述 Blowfish是一种对称密钥块加密算法,由安全专家Bruce Schneier在1993年设计,旨在为当时的加密领域提供一种免费且高效的替代方案。Blowfish算法支持可变长度的...
在VB中实现Blowfish算法,开发者通常会编写一系列函数和过程来完成加密和解密操作。 Blowfish算法的核心在于其S盒(Substitution Box)和P盒(Permutation Box),它们构成了Blowfish的密钥扩展和加密过程。在VB中...
Blowfish算法是一种著名的对称加密算法,由Bruce Schneier于1993年设计。它以其高效、快速和安全的特点,在加密领域被广泛应用。本篇将详细讲解Blowfish算法的基本原理、C#与Java实现的关键点,以及如何在两个环境中...
虽然Blowfish算法在当时被认为是非常安全的,但随着密码学的发展,一些更先进的加密算法如AES(高级加密标准)已经取代了Blowfish。尽管如此,对于许多旧系统和应用,Blowfish仍然是一个可靠的选择。然而,务必记住...
BlowFish类通常是在编程语言中实现BlowFish算法的一个封装,允许开发者通过简单的API调用来执行加密和解密操作。 BlowFish算法的核心在于它的S盒(Substitution Box)和P盒(Permutation Box)。S盒用于非线性变换...
1. **BFENG386.ASM**:这是一个用汇编语言编写的Blowfish引擎,专门针对386及以上的处理器进行了优化。汇编代码通常能提供比高级语言更高的执行效率,因此对于性能敏感的应用,这是理想的实现方式。 2. **ASM_DEMO....
Blowfish是一种对称加密算法,由Bruce Schneier在1993年设计,以其高效性和安全性而闻名。在本文中,我们将深入探讨Blowfish加密算法的原理、使用方式,以及如何通过代码实现加密和解密过程。 首先,让我们理解Blow...
Blowfish算法基于一系列称为S盒(Substitution Box)的查找表和一系列P盒(Permutation Box)的置换操作,通过这些复杂的计算步骤来实现数据的加密。 在C++中实现Blowfish算法,通常包括以下几个关键部分: 1. **...
Blowfish算法是一种对称密钥加密算法,因其高效、快速且安全性高而被广泛应用。本文将详细介绍Java中如何使用Blowfish算法进行加密和解密操作。 Blowfish算法由Bruce Schneier于1993年设计,它是一种分组密码,使用...
Blowfish算法是一种著名的对称加密算法,由Bruce Schneier于1993年设计。它以其高效、快速和安全的特点,在加密领域被广泛应用。C#是一种面向对象的编程语言,广泛用于开发Windows应用程序、Web应用和服务。将Blow...
BlowFish算法是一种著名的对称加密算法,由Bruce Schneier在1993年设计。它以其高效、安全和开源的特点,在信息安全领域被广泛应用。本文将深入探讨BlowFish算法的工作原理、源码实现以及如何在编程中调用。 Blow...
Blowfish算法是一种著名的对称加密算法,由Bruce Schneier在1993年设计。它以其高效、快速和安全的特点,在加密领域占据了一席之地。Blowfish的源码通常包括两个主要部分:算法定义(常在头文件如blowfish.h中)和...
这个“blowfish的vc2008工程.rar”文件很可能包含了一个使用Visual C++ 2008编译器实现的Blowfish加密算法的源代码工程。在Windows开发环境中,Visual C++ 2008(也称为VC++ 9.0)是一个流行的C++编程工具,用于创建...