`
逆风的香1314
  • 浏览: 1416709 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

编写blowfish的PHP module (续)

阅读更多
<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的加密,而php又没有现成的blowfish加密算法(好像是有一个,但需要重新编译PHP,太麻烦了,公司几十台机器,没空一台台的编译),于是在blowfish的网站上下了源代码,再根据PHP Module的框架,写了一个简单的Module。
        遇到的第一个麻烦是:blowfish是对64bit数据进行加密的,长的待加密串必须切分成8个字节一组进行加密,但如果要加密三个字符串,那该怎么办?在网上找了好一阵才知道:后面补零。
        但不久又遇到一个麻烦:对一段字符加密后再解密发现还原不了,更糟糕的是有的字符串是这样,有的字符串却又能还原。晕。问了苏宁,他也觉得匪夷所思。最后才想到原因:PHP Module里二进制串直接赋值是不可靠的,必须先base64进行encode!也就是说blowfish加密后面必须紧跟base64的encode,不然得出的二进制串是难以直接使用的。
        写PHP Module还挺长见识,对了,我可以为FlatDB也写一个PHP Module来方便调用。  
分享到:
评论

相关推荐

    blowfish 加密解密

    源码中的"blowfish.inc"可能包含了Blowfish算法的实现,通常会包括上述步骤的函数定义,以及对S盒和P盒的初始化。而"blowfish"可能是示例程序或者库文件,用于演示如何使用这个算法进行加密和解密。 理解并掌握Blow...

    关于openssl中blowfish算法的运用

    blowfish算法,包括Blowfish-ECB,Blowfish-CBC,Blowfish-CTR,Blowfish-OFB,Blowfish-CFB,目前我的Demo只实现了ECB是如何运用的。[/b][/i]注意:嵌入式开发的小伙伴们,如果blowfish.h找不到头文件的时候,需要将...

    blowfish算法的C#实现

    Blowfish算法是一种著名的对称加密算法,由Bruce Schneier在1993年设计。它以其高效、安全和可变密钥长度(32到448位)而受到广泛欢迎。C#是一种通用的、面向对象的编程语言,广泛应用于Windows平台的软件开发,包括...

    C#Blowfish加密算法

    ### C# Blowfish 加密算法知识点详解 #### 一、Blowfish算法简介 Blowfish是一种对称密钥块加密算法,由Bruce Schneier在1993年设计并发布。它支持可变长度的密钥(从32位到448位),并能处理64位数据块。Blowfish...

    BLOWFISH加密程序

    **Blowfish加密算法概述** Blowfish是一种对称加密算法,由Bruce Schneier于1993年设计。它的主要特点是速度快、安全性高,适用于软件和硬件实现。Blowfish采用了一种称为Feistel网络的结构,通过多次迭代变换来...

    Blowfish加密算法

    在Java编程环境中,我们可以创建`Blowfish.java`和`BlowfishTest.java`两个文件来实现Blowfish算法。`Blowfish.java`通常会包含Blowfish类,其中定义了加密和解密的函数,以及密钥的设置方法。`BlowfishTest.java`则...

    blowfish加密算法

    在Visual Studio 2010(VS2010)中编写Blowfish加密程序,开发者通常会利用C或C++语言,因为这两种语言都支持底层操作,对于处理加密算法这样需要高性能的任务非常合适。在描述中提到参考了OpenSSL库,OpenSSL是一个...

    Blowfish算法(英文)

    ### Blowfish算法详解 #### 一、Blowfish算法概述 Blowfish是一种对称密钥块加密算法,由安全专家Bruce Schneier在1993年设计,旨在为当时的加密领域提供一种免费且高效的替代方案。Blowfish算法支持可变长度的...

    用VB实现Blowfish算法

    在VB中实现Blowfish算法,开发者通常会编写一系列函数和过程来完成加密和解密操作。 Blowfish算法的核心在于其S盒(Substitution Box)和P盒(Permutation Box),它们构成了Blowfish的密钥扩展和加密过程。在VB中...

    Blowfish算法(包含C#,java)

    Blowfish算法是一种著名的对称加密算法,由Bruce Schneier于1993年设计。它以其高效、快速和安全的特点,在加密领域被广泛应用。本篇将详细讲解Blowfish算法的基本原理、C#与Java实现的关键点,以及如何在两个环境中...

    Blowfish_java_javablowfish_

    虽然Blowfish算法在当时被认为是非常安全的,但随着密码学的发展,一些更先进的加密算法如AES(高级加密标准)已经取代了Blowfish。尽管如此,对于许多旧系统和应用,Blowfish仍然是一个可靠的选择。然而,务必记住...

    BlowFish类,高强度加密

    BlowFish类通常是在编程语言中实现BlowFish算法的一个封装,允许开发者通过简单的API调用来执行加密和解密操作。 BlowFish算法的核心在于它的S盒(Substitution Box)和P盒(Permutation Box)。S盒用于非线性变换...

    blowfish加密算法开发工具包

    1. **BFENG386.ASM**:这是一个用汇编语言编写的Blowfish引擎,专门针对386及以上的处理器进行了优化。汇编代码通常能提供比高级语言更高的执行效率,因此对于性能敏感的应用,这是理想的实现方式。 2. **ASM_DEMO....

    Blowfish 加密解密代码和示例

    Blowfish是一种对称加密算法,由Bruce Schneier在1993年设计,以其高效性和安全性而闻名。在本文中,我们将深入探讨Blowfish加密算法的原理、使用方式,以及如何通过代码实现加密和解密过程。 首先,让我们理解Blow...

    blowfish的C++加密算法代码.zip,

    Blowfish算法基于一系列称为S盒(Substitution Box)的查找表和一系列P盒(Permutation Box)的置换操作,通过这些复杂的计算步骤来实现数据的加密。 在C++中实现Blowfish算法,通常包括以下几个关键部分: 1. **...

    Java中的Blowfish对称密钥加密算法类和实例

    Blowfish算法是一种对称密钥加密算法,因其高效、快速且安全性高而被广泛应用。本文将详细介绍Java中如何使用Blowfish算法进行加密和解密操作。 Blowfish算法由Bruce Schneier于1993年设计,它是一种分组密码,使用...

    blowfish算法源码(c#)

    Blowfish算法是一种著名的对称加密算法,由Bruce Schneier于1993年设计。它以其高效、快速和安全的特点,在加密领域被广泛应用。C#是一种面向对象的编程语言,广泛用于开发Windows应用程序、Web应用和服务。将Blow...

    BlowFish算法完整源码与调用方法

    BlowFish算法是一种著名的对称加密算法,由Bruce Schneier在1993年设计。它以其高效、安全和开源的特点,在信息安全领域被广泛应用。本文将深入探讨BlowFish算法的工作原理、源码实现以及如何在编程中调用。 Blow...

    blowfish算法 c源码

    Blowfish算法是一种著名的对称加密算法,由Bruce Schneier在1993年设计。它以其高效、快速和安全的特点,在加密领域占据了一席之地。Blowfish的源码通常包括两个主要部分:算法定义(常在头文件如blowfish.h中)和...

    blowfish的vc2008工程.rar

    这个“blowfish的vc2008工程.rar”文件很可能包含了一个使用Visual C++ 2008编译器实现的Blowfish加密算法的源代码工程。在Windows开发环境中,Visual C++ 2008(也称为VC++ 9.0)是一个流行的C++编程工具,用于创建...

Global site tag (gtag.js) - Google Analytics