使用PHP内置的DES算法函数实现数据加密解密_PHP教程
由于项目的需要,要写一个能生成“授权码”的类(授权码主要包含项目使用的到期时间),生成的授权码将会写入到一个文件当中,每当项目运行的时候,会自动读取出文件中的密文,然后使用唯一的“密钥”来调用某个函数,对密文进行解密,从中解读出项目的使用到期时间。
之前,自己有先试着写了下,主要是base64+md5+反转字符串。算法太过简单,很容易被破解,而且也没有能过做到“密钥”在加解密中的重要性,故而舍之。
后来,查找了相关资料,发现,原来PHP中内置了一个功能强大的函数库,即Mcrypt。
其实,mcrypt本身就提供了强大的加密解密方法,并且支持很多流行的公开的加密算法,如DES, TripleDES, Blowfish (默认), 3-WAY, SAFER-SK64, SAFER-SK128, TWOFISH, TEA, RC2 and GOST in CBC, OFB, CFB and ECB。
这里简单的引用下百度百科关于“加密算法”的解释:
数据加密的基本过程就是对原来为明文的文件或数据按某种算法进行处理,使其成为不可读的一段代码,通常称为“密文”,使其只能在输入相应的密钥之后才能显示出本来内容,通过这样的途径来达到保护数据不被非法人窃取、阅读的目的。 该过程的逆过程为解密,即将该编码信息转化为其原来数据的过程。
加密技术通常分为两大类:“对称式”和“非对称式”。
对称式加密就是加密和解密使用同一个密钥,通常称之为“Session Key ”这种加密技术目前被广泛采用,如美国政府所采用的DES加密标准就是一种典型的“对称式”加密法,它的Session Key长度为56Bits。
非对称式加密就是加密和解密所使用的不是同一个密钥,通常有两个密钥,称为“公钥”和“私钥”,它们两个必需配对使用,否则不能打开加密文件。这里的“公钥”是指可以对外公布的,“私钥”则不能,只能由持有人一个人知道。它的优越性就在这里,因为对称式的加密方法如果是在网络上传输加密文件就很难把密钥告诉对方,不管用什么方法都有可能被别窃听到。而非对称式的加密方法有两个密钥,且其中的“公钥”是可以公开的,也就不怕别人知道,收件人解密时只要用自己的私钥即可以,这样就很好地避免了密钥的传输安全性问题。
前面提到过,mcrypt支持多种国际公开的算法,我在这次的项目中使用的是DES算法,DES(Data Encryption Standard),这是一个对称算法,速度较快,适用于加密大量数据的场合。
用到的几个加密函数介绍
接下来我简要的说明下加密类中会使用到的几个函数。
1. resource mcrypt_module_open ( string $algorithm , string $algorithm_directory , string $mode , string $mode_directory )
- 参数$algorithm:要使用的算法,可以通过函数mcrypt_list_algorithms()来查看所有支持的算法名称
- 参数$ mode:要使用哪种模式,同样,可以内置函数mcrypt_list_algorithms()来查看所有支持的模式
2. int mcrypt_enc_get_iv_size ( resource $td )
- 该函数将返回使用的算法的初始化向量(IV)的大小(看着有点抽象),如果IV在算法中被忽略的话讲返回0。
- 参数$td就是使用mcrypt_module_open函数的返回值。
3. string mcrypt_create_iv ( int $size [, int $source = MCRYPT_DEV_RANDOM ] )
该函数会创建一个初始化向量(IV)
参数:$source可以使MCRYPT_RAND,MCRYPT_DEV_RANDOM,MCRYPT_DEV_URANDOM
注意:PHP5.3.0以上的版本,只支持MCRYPT_RAND
返回值:成功,则返回一个字符串型的初始向量,失败,则返回False
4. int mcrypt_enc_get_key_size ( resource $td )
该函数能够取得当前算法所支持的最大的密钥长度(以字节计算)
int mcrypt_generic_init ( resource $td , string $key , string $iv )
调用mcrypt_generic() or mdecrypt_generic()之前,首先需要调用该函数,该函数能够帮我们初始化缓冲区,用以存放加密数据。
参数$key:密钥长度,记住,当前$key的值,要比函数mcrypt_enc_get_key_size()返回的值小
问题:$key的值,越大越好吗?有同学会的,帮忙解答下。
5. string mcrypt_generic ( resource $td , string $data )
完成了前面的工作之后,就可以调用该函数用以加密数据了。
- 参数$data:要加密的数据内容
- 返回值:返回加密后的密文
6. bool mcrypt_generic_deinit ( resource $td )
该函数能够帮我们卸载当前使用的加密模块。
返回值:成功时返回 TRUE, 或者在失败时返回 FALSE.
7. string mdecrypt_generic ( resource $td , string $data )
该函数能够用来解密数据。
注意:解密后的数据可能比实际上的更长,可能会有后续的\0,需去掉
8. bool mcrypt_module_close ( resource $td )
关闭指定的加密模块资源句柄
返回值:成功时返回 TRUE, 或者在失败时返回 FALSE.
参考代码
<?php class authCode { public $ttl;//到期时间 时间格式:20120101(年月日) public $key_1;//密钥1 public $key_2;//密钥2 public $td; public $ks;//密钥的长度 public $iv;//初始向量 public $salt;//盐值(某个特定的字符串) public $encode;//加密后的信息 public $return_array = array(); // 返回带有MAC地址的字串数组 public $mac_addr;//mac地址 public $filepath;//保存密文的文件路径 public function __construct(){ //获取物理地址 $this->mac_addr=$this->getmac(PHP_OS); $this->filepath="./licence.txt"; $this->ttl="20120619";//到期时间 $this->salt="~!@#$";//盐值,用以提高密文的安全性 // echo "<pre class="brush:php;toolbar:false">".print_r(mcrypt_list_algorithms ())."
".print_r(mcrypt_list_modes())."

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Bitlocker ialah teknologi penyulitan lalai untuk sistem pengendalian Windows. Ia digunakan secara meluas pada Windows, tetapi sesetengah pengguna lebih suka penyelesaian pihak ketiga seperti VeraCrypt. Apa yang ramai pengguna Bitlocker tidak tahu ialah ia lalai kepada penyulitan 128-bit, walaupun 256-bit tersedia. Tanpa terlalu terperinci tentang perbezaan, perbezaan teras antara penyulitan AES 128-bit dan 256-bit ialah panjang kunci keselamatan. Kekunci yang lebih panjang menjadikan serangan kekerasan lebih sukar. Walaupun lalai adalah 128-bit, malah Microsoft mengesyorkan 256-bit untuk keselamatan yang lebih baik. Masalahnya ialah, kebanyakan pengguna mungkin tidak tahu tentang lalai yang lebih lemah atau cara menukarnya. Pertama, anda mungkin ingin mengetahui W

Microsoft sebelum ini menyediakan perkhidmatan penyulitan dns untuk win11, tetapi ramai pengguna tidak tahu cara menggunakan dns yang disulitkan win11, sebenarnya, kami hanya perlu membuka tetapan dns di bawah tetapan rangkaian. Tutorial terperinci tentang win11 encrypted dns: 1. Mula-mula masukkan cakera dan cari folder yang anda ingin encrypt. 2. Kemudian buka "Ethernet" di sebelah kanan 3. Kemudian cari peruntukan pelayan DNS di bawah dan klik "Edit" 4. Selepas menukar "Auto (DHCP)" kepada "Manual", buka "IPv4" di bawah 5. Selepas menghidupkannya , masukkan "8.8.8.8" dalam DNS pilihan 6. Kemudian tukar penyulitan DNS pilihan kepada "Penyulitan sahaja (DNS melalui HTTPS)" 7. Selepas perubahan selesai, klik "Simpan" dan anda akan dapati

Penyulitan fail bertujuan untuk melaksanakan penyulitan data peringkat profesional untuk memastikan keselamatan data dengan lebih berkesan! Hanya dengan menguasai kunci penyulitan yang betul, operasi penyahsulitan boleh dilakukan, memastikan keselamatan aset maklumat. Walau bagaimanapun, fungsi penyulitan fail Win10 Home Edition belum lagi mempunyai ciri ini. Bolehkah Win10 Home Edition menyulitkan folder Jawapan: Win10 Home Edition tidak boleh menyulitkan folder. Tutorial menyulitkan fail dalam sistem Windows 1. Klik kanan pada fail atau folder yang ingin anda sulitkan (atau tekan dan tahan seketika), dan kemudian pilih fungsi "Properties". 2. Dalam antara muka yang diperluaskan baharu, cari pilihan "Lanjutan" Selepas mengklik untuk masuk, ingat untuk menyemak pilihan "Sulitkan kandungan untuk melindungi data" yang terdapat di bawah. 3. Selepas tetapan selesai, klik "OK" untuk

Dalam telefon bimbit Apple, pengguna boleh menyulitkan album foto mengikut keperluan mereka sendiri. Sesetengah pengguna tidak tahu cara menyediakannya. Anda boleh menambah gambar yang perlu disulitkan ke memo, dan kemudian mengunci memo Seterusnya, editor akan memperkenalkan kaedah menyediakan penyulitan album foto mudah alih untuk pengguna yang berminat, datang dan lihat. Tutorial telefon bimbit Apple Bagaimana untuk menyediakan penyulitan album foto pada telefon bimbit Apple Jawapan: Selepas menambah gambar yang perlu disulitkan pada memo, pergi ke kunci memo untuk pengenalan terperinci: 1. Masukkan album foto, pilih gambar yang perlu disulitkan, dan kemudian klik [Tambah ke] di bawah. 2. Pilih [Tambah pada Nota]. 3. Masukkan memo, cari memo yang baru anda buat, masukkannya dan klik ikon [Hantar] di penjuru kanan sebelah atas. 4. Klik [Kunci Peranti] di bawah

Penyulitan folder ialah kaedah perlindungan data biasa yang menyulitkan kandungan folder supaya hanya mereka yang mempunyai kata laluan penyahsulitan boleh mengakses fail. Apabila menyulitkan folder, terdapat beberapa cara biasa untuk menetapkan kata laluan tanpa memampatkan fail. Pertama, kita boleh menggunakan fungsi penyulitan yang disertakan dengan sistem pengendalian untuk menetapkan kata laluan folder. Untuk pengguna Windows, anda boleh menyediakannya dengan mengikuti langkah berikut: Pilih folder untuk disulitkan, klik kanan folder dan pilih "Properties"

Masalah dan penyelesaian komunikasi rangkaian dan keselamatan biasa dalam C# Dalam era Internet hari ini, komunikasi rangkaian telah menjadi bahagian yang sangat diperlukan dalam pembangunan perisian. Dalam C#, kami biasanya menghadapi beberapa masalah komunikasi rangkaian, seperti keselamatan penghantaran data, kestabilan sambungan rangkaian, dsb. Artikel ini akan membincangkan secara terperinci komunikasi rangkaian biasa dan isu keselamatan dalam C# dan menyediakan penyelesaian yang sepadan serta contoh kod. 1. Masalah komunikasi rangkaian Gangguan sambungan rangkaian: Semasa proses komunikasi rangkaian, sambungan rangkaian mungkin terganggu, yang boleh menyebabkan

Sesetengah rakan ingin melindungi fail mereka, tetapi tidak tahu cara menyulitkan dokumen win11 Malah, kami boleh terus menggunakan penyulitan folder atau menggunakan perisian pihak ketiga untuk menyulitkan fail. Tutorial terperinci mengenai penyulitan dokumen win11: 1. Mula-mula cari fail yang ingin anda enkripsi, klik kanan dan pilihnya, buka "Properties" 2. Kemudian klik "Advanced" dalam lajur sifat 3. Pilih "Encrypt content to protect data" dalam Advanced dan klik " OK" 4. Kemudian klik "OK" untuk menyimpan. 5. Akhir sekali, pilih mod penyulitan yang dikehendaki dan "OK" untuk menyimpan dokumen untuk menyulitkan dokumen.

Senarai lengkap fungsi penyulitan dan penyahsulitan PHP: kaedah aplikasi selamat md5, sha1, base64_encode dan fungsi lain, yang memerlukan contoh kod khusus Dalam pembangunan aplikasi rangkaian, penyulitan data dan penyahsulitan adalah sangat penting. Sebagai bahasa skrip sebelah pelayan yang popular, PHP menyediakan pelbagai fungsi penyulitan dan penyahsulitan Artikel ini akan memperkenalkan fungsi yang biasa digunakan dan kaedah aplikasi selamatnya, dan menyediakan contoh kod khusus. Fungsi md5 Fungsi md5 ialah fungsi penyulitan yang paling biasa yang boleh menukar rentetan sebarang panjang kepada 32 bit
