简单有key的加密解密算法

 1 define(‘KEY‘, ‘123456‘);
 2 $data = ‘oehpetyFTdYwZ3frZi1KkgtizgQs‘;        // 被加密信息
 3 $encrypt = encrypt($data);
 4 $decrypt = decrypt($encrypt);
 5 echo $encrypt, "\n", $decrypt;
 6 function decrypt($data) {
 7     $key = md5(KEY);
 8     $x = 0;
 9     $data = base64_decode($data);
10     $len = strlen($data);
11     $l = strlen($key);
12     $char = $str = ‘‘;
13     for ($i = 0; $i < $len; $i++) {
14         if ($x == $l) {
15             $x = 0;
16         }
17         $char .= substr($key, $x, 1);
18         $x++;
19     }
20     for ($i = 0; $i < $len; $i++) {
21         if (ord(substr($data, $i, 1)) < ord(substr($char, $i, 1))) {
22             $str .= chr((ord(substr($data, $i, 1)) + 256) - ord(substr($char, $i, 1)));
23         } else {
24             $str .= chr(ord(substr($data, $i, 1)) - ord(substr($char, $i, 1)));
25         }
26     }
27     return $str;
28 }
29
30 function encrypt($data) {
31     $key = md5(KEY);
32     $x = 0;
33     $len = strlen($data);
34     $l = strlen($key);
35     $char = $str = ‘‘;
36     for ($i = 0; $i < $len; $i++) {
37         if ($x == $l) {
38             $x = 0;
39         }
40         $char .= $key{$x};
41         $x++;
42     }
43     for ($i = 0; $i < $len; $i++) {
44         $str .= chr(ord($data{$i}) + (ord($char{$i})) % 256);
45     }
46     return base64_encode($str);
47 }
时间: 2024-10-12 13:15:24

简单有key的加密解密算法的相关文章

数据的加密传输——单片机上实现TEA加密解密算法(转)

源:数据的加密传输——单片机上实现TEA加密解密算法 各位大侠在做数据传输时,有没有考虑过把数据加密起来进行传输,若在串口或者无线中把所要传的数据加密起来,岂不是增加了通信的安全性.常用的加密解密算法比如DES.RSA等,受限于单片机的内存和运算速度,实现起来比较困难,但一种叫TEA的加密算法特别适合单片机使用. TEA(Tiny Encryption Algorithm)是一种简单高效的加密算法,以加密解密速度快,实现简单著称.算法很简单,TEA算法每一次可以操作64-bit(8-byte),

基于新唐M0的XXTEA加密解密算法源码

源:基于新唐M0的XXTEA加密解密算法源码 /*--------------------------------------------------------------------------------------------------------- 在数据的加解密领域,算法分为对称密钥与非对称密钥两种.对称密钥与非对称密钥由于各自的特点,所应用的领域是不尽相 同的.对称密钥加密算法由于其速度快,一般用于整体数据的加密,而非对称密钥加密算法的安全性能佳,在数字签名领域得到广 泛的应用.

DES加密解密算法

DES加密解密算法 // 仿射变换加解密.cpp : 定义控制台应用程序的入口点. // #include <stdio.h> #include <conio.h> static char key[10], key_a[5], code[8], key_b[5], temp[10], key_aa[8], key_bb[8], l[4], r[4], l_a[4], r_a[4], V[8] = { 0, 1, 0, 1, 0, 1, 0, 1 }, b[8]; char Code

php与java通用AES加密解密算法

php与java通用AES加密解密算法 AES指高级加密标准(Advanced Encryption Standard),是当前最流行的一种密码算法,在web应用开发,特别是对外提供接口时经常会用到,下面是我整理的一套php与java通用的AES加密解密算法. php版代码如下: <?php class CryptAES { protected $cipher = MCRYPT_RIJNDAEL_128; protected $mode = MCRYPT_MODE_ECB; protected

java/php DES/CBC/PKCS5Padding加密解密算法实现过程

先看java代码 Java代码   public static String encrypt(String message, String key) throws Exception { Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding"); DESKeySpec desKeySpec = new DESKeySpec(key.getBytes("UTF-8")); SecretKeyFactory k

RC4加密解密算法

RC4相对是速度快.安全性高的加密算法.在实际应用中,我们可以对安全系数要求高的文本进行多重加密,这样破解就有一定困难了.如下测试给出了先用RC4加密,然后再次用BASE64编码,这样双重锁定,保证数据信息安全(个人见解,不周之处请谅解!). package com.bao.tools.encryption; import java.io.Console;import java.io.IOException;import java.util.Scanner; import org.junit.T

java 实现 DES加密 解密算法

DES算法的入口参数有三个:Key.Data.Mode.其中Key为8个字节共64位,是DES算法的工作密钥:Data也为8个字节64位,是要被加密或被解密的数据:Mode为DES的工作方式,有两种:加密或解密.  DES算法是这样工作的:如Mode为加密,则用Key 去把数据Data进行加密, 生成Data的密码形式(64位)作为DES的输出结果:如 Mode为解密,则用Key去把密码形式的数据Data解密,还原为Data的明码形式(64位)作为DES的输出结果.在通信网络的两端,双方约定一致

一次一密加密解密算法

static int MAX=100; static char[] key=new char[MAX]; //用于保存密钥 static int len; static char[] bitcode(char[] str) //一次一密加密算法 { int i; char[] wen; if((wen=new char[len+1])==null) { System.out.printf("申请内存失败!\n"); System.exit(1); } for(i=0;i<len;

用JAVA实现的DES加密解密算法

package Encrypt; import java.security.*; import javax.crypto.*; import sun.misc.*; /** * 使用DES加密与解密,可对byte[],String类型进行加密与解密 * 密文可使用String,byte[]存储. * 方法: * void getKey(String strKey)从strKey的字条生成一个Key * String getEncString(String strMing)对strMing进行加密