博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
XOR算法的原理和实现
阅读量:7054 次
发布时间:2019-06-28

本文共 825 字,大约阅读时间需要 2 分钟。

XOR算法的原理和实现

XOR算法这种方法的原理

当一个数A和另一个数B进行异或运算会生成另一个数C,如果再将C和B进行异或运算则C又会还原为A。

相对于其他的简易加密算法,XOR算法的优点如下。

(1)算法简单,对于高级语言很容易能实现。

(2)速度快,可以在任何时候、任何地方使用。

(3)对任何字符都是有效的,不像有些简易加密算法,只对西文字符有效,对中文加密后再解密无法还原为原来的字符。

XOR算法实现

上一部分介绍了如何使用XOR运算进行加密/解密的原理,本节将使用其加密用户的登录信息。根据上一小节介绍的XOR加密算法的原理,不难写出以下的加密解密函数。首先列出加密算法。

第4行定义了加密函数myEncrypt(),输入参数$string为明文,而$key为密钥;输出为使用$key作为密钥并使用XOR加密算法产生的密文。

第6~12行的外层for循环对明文字符串的每一个字符进行循环,而内层的for循环(第8~11行)对明文的每一字符循环与密钥的每一位做异或运算。其原理已经在上一小节中介绍,不再重述。

同样,与加密函数类似,可以写出下面的解密函数。

第4行定义了解密函数myDecrypt(),输入参数$string为密文,而$key为密钥;输出为使用$key作为密钥并使用XOR解密算法产生的明文。

下面,通过一个应用示例来进一步说明加密函数的功能。

第3行首先定义了一个明文$my_password,然后在第4行定义密钥$my_key。

第5、6行分别调用加密函数生成密文并输出;反过来,又在第7、8行将密文解密。

上面示例的运行结果如下。

my_password=chair

my_password_en=RYPXC

my_password_de=chair

在用户注册时,用户需要添写用户密码表单。

除用户本人之外,其他任何人都无法获取其密码信息,包括系统设计者和数据库管理员。

系统能根据用户输入的密码验证用户的合法性。

转载地址:http://esmol.baihongyu.com/

你可能感兴趣的文章
ubuntu解压rar
查看>>
C++中数组定义及初始化
查看>>
STL顺序容器之vector类型
查看>>
逻辑卷管理器
查看>>
精选6个超实用的Word技巧,每一个大有用处!
查看>>
JDBC中注册驱动为什么使用Class.forName
查看>>
Spring知识复习之三
查看>>
这些职场办公神器,你会喜欢的!
查看>>
js操作节点,ID,name,calssname,tag,style
查看>>
yii2项目实战-用户管理之user组件的配置
查看>>
【Web】Web内容可访问性指南 1.0
查看>>
文字转语音怎么做?看完你就明白了
查看>>
设置lab样式
查看>>
ES6中class类的extend的prototype和_proto_
查看>>
如何解决90%的报表设计难题?300张报表模板任君挑选
查看>>
EL函数库(由JSTL提供的)
查看>>
vagrant学习笔记 - provision
查看>>
PowerDesigner中pdm物理模型中 Name和Comment相互转换
查看>>
ActiveMQ 消息中间件
查看>>
融合式基础架构--《VMware网络技术原理与实践》笔记
查看>>