首页 后端开发 php教程 深入研究 UCenter API 之 PHP加密与解密

深入研究 UCenter API 之 PHP加密与解密

Jun 20, 2016 pm 01:02 PM
api接口

深入研究 UCenter API 之 PHP加密与解密

UCenter API 中的加密解密函数,被称为 php 领域的经典之作,也是康盛公司为 php 做的一大贡献

这个函数,可以通过一个 KEY ,生成动态的密文,并可以再通过这个 KEY 来解

 

  
// $string: 明文 或 密文   
// $operation:DECODE表示解密,其它表示加密   
// $key: 密匙   
// $expiry:密文有效期   
//字符串解密加密   
function authcode($string, $operation = 'DECODE', $key = '', $expiry = 0) {   
     // 动态密匙长度,相同的明文会生成不同密文就是依靠动态密匙   
    $ckey_length = 4;   // 随机密钥长度 取值 0-32;   
                // 加入随机密钥,可以令密文无任何规律,即便是原文和密钥完全相同,加密结果也会每次不同,增大破解难度。   
                // 取值越大,密文变动规律越大,密文变化 = 16 的 $ckey_length 次方   
                // 当此值为 0 时,则不产生随机密钥   
    // 密匙   
    $key = md5($key ? $key : UC_KEY);   
    // 密匙a会参与加解密   
    $keya = md5(substr($key, 0, 16));   
    // 密匙b会用来做数据完整性验证   
    $keyb = md5(substr($key, 16, 16));   
    // 密匙c用于变化生成的密文   
    $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length): substr(md5('1303808563'), -$ckey_length)) : '';   
    // 参与运算的密匙   
    $cryptkey = $keya.md5($keya.$keyc);   
 
    $key_length = strlen($cryptkey);   
 
    // 明文,前10位用来保存时间戳,解密时验证数据有效性,10到26位用来保存$keyb(密匙b),解密时会通过这个密匙验证数据完整性   
    // 如果是解码的话,会从第$ckey_length位开始,因为密文前$ckey_length位保存 动态密匙,以保证解密正确   
    $string = $operation == 'DECODE' ? base64_decode(substr($string, $ckey_length)) : sprintf('%010d', $expiry ? $expiry + time() : 0).substr(md5($string.$keyb), 0, 16).$string;   
    $string_length = strlen($string);   
    $result = '';   
    $box = range(0, 255);   
    $rndkey = array();   
    // 产生密匙簿   
    for($i = 0; $i <= 255; $i++) {   
        $rndkey[$i] = ord($cryptkey[$i % $key_length]);   
     }   
     // 用固定的算法,打乱密匙簿,增加随机性,好像很复杂,实际上对并不会增加密文的强度   
    for($j = $i = 0; $i < 256; $i++) {   
        $j = ($j + $box[$i] + $rndkey[$i]) % 256;   
        $tmp = $box[$i];   
        $box[$i] = $box[$j];   
        $box[$j] = $tmp;   
     }   
    // 核心加解密部分   
    for($a = $j = $i = 0; $i < $string_length; $i++) {   
        $a = ($a + 1) % 256;   
        $j = ($j + $box[$a]) % 256;   
        $tmp = $box[$a];   
        $box[$a] = $box[$j];   
        $box[$j] = $tmp;   
        // 从密匙簿得出密匙进行异或,再转成字符   
        $result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256]));   
     }   
    if($operation == &#39;DECODE&#39;) {   
        // 验证数据有效性,请看未加密明文的格式   
        if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16)) {   
            return substr($result, 26);   
         } else {   
            return &#39;&#39;;   
         }   
     } else {   
         // 把动态密匙保存在密文里,这也是为什么同样的明文,生产不同密文后能解密的原因   
         // 因为加密后的密文可能是一些特殊字符,复制过程可能会丢失,所以用base64编码   
        return $keyc.str_replace(&#39;=&#39;, &#39;&#39;, base64_encode($result));   
     }   
}  
echo authcode(&#39;123456&#39;, &#39;INCODE&#39;, &#39;scutephp&#39;, 0);  
echo "";  
echo authcode(&#39;3575ijqlNCR+R3s7Aakwy1HlvDzHw5g4oKp82qhE7q5FS88&#39;, &#39;DECODE&#39;, &#39;scutephp&#39;, 0);  

登录后复制

 


本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP中的邮件发送API接口指南 PHP中的邮件发送API接口指南 May 21, 2023 pm 12:12 PM

随着电子邮件在我们日常生活中的普及,邮件发送成为了许多应用程序中必不可少的功能。PHP作为一种流行的Web开发语言,也提供了相应的邮件发送API接口。本文将为初学者和开发者介绍PHP中的邮件发送API接口,包括如何配置邮件服务器、如何使用PHP内置的邮件函数以及如何使用第三方邮件发送库。一、配置邮件服务器在使用PHP发送邮件之前,你需要首先配置一个SMTP服

免费的api接口网站有哪些 免费的api接口网站有哪些 Jan 05, 2024 am 11:33 AM

免费的api接口网站:1、UomgAPI:提供稳定、快速免费API服务的平台,拥有超百个API接口;2、free-api:提供多个免费API接口;3、JSON API:提供免费的数据API接口;4、高德开放平台:提供地图相关的API接口;5、人脸识别Face++:提供人脸识别相关的API接口;6、极速数据:提供超百个免费API接口,适用于需要多种数据源的场合;7、聚合数据等等。

api接口是干嘛的 api接口是干嘛的 Apr 23, 2024 pm 01:51 PM

API接口是软件组件之间交互的规范,用于实现不同应用程序或系统之间的通信和数据交换。API接口充当“翻译器”,将开发人员的指令转换为计算机语言,让应用程序协同工作。其优势包括便捷的数据共享、简化开发、提高性能、增强安全性、提升生产效率和互操作性。

api接口类型主要有哪些 api接口类型主要有哪些 Apr 23, 2024 pm 01:57 PM

API接口类型丰富多样,主要包括RESTful API、SOAP API、GraphQL API等。RESTful API通过HTTP协议进行通信,设计简洁高效,是当下主流的Web API设计风格。SOAP API基于XML,注重跨语言和平台的互操作性,多应用于大型企业和政府机构。GraphQL API是一种新型查询语言和运行时环境,支持灵活的数据查询和响应。

开发API文档:PHP API接口的步骤指南 开发API文档:PHP API接口的步骤指南 Jan 22, 2024 am 11:20 AM

随着Web应用程序的日益普及,API(应用程序接口)越来越重要,在Web开发中扮演着越来越重要的角色。WebAPI是一种允许用户通过Internet来访问应用程序的技术,是将不同的应用程序组合在一起的基础工具。PHP是一种被广泛使用的编程语言,特别是在Web开发领域。开发人员可以通过开发PHPAPI接口来允许其他应用程序使用他们的应用程序功能。为了实现这

如何使用Go语言和Redis构建API接口 如何使用Go语言和Redis构建API接口 Oct 27, 2023 pm 01:23 PM

如何使用Go语言和Redis构建API接口概述:Go语言(Golang)是一种简洁、高效、强大的编程语言,而Redis是一个开源的内存数据库,它提供了丰富的数据结构和强大的查询功能。本文将介绍如何使用Go语言和Redis构建API接口,并提供具体的代码示例。步骤1:安装和配置Go语言环境首先,需要在计算机上安装Go语言,并设置好相关环境变量。在完成这一步之后

如何使用PHP调用API接口并实现数据交互? 如何使用PHP调用API接口并实现数据交互? Sep 05, 2023 am 09:30 AM

如何使用PHP调用API接口并实现数据交互?随着Web应用程序的发展,许多开发人员需要使用API(ApplicationProgrammingInterface)接口来实现与第三方服务的数据交互。PHP作为一种常用的后端开发语言,提供了强大的功能来调用API接口进行数据传输和处理。本文将介绍如何使用PHP调用API接口,并提供一些代码示例来帮助读者更好地

用PHP构建一个微信公众号API接口 用PHP构建一个微信公众号API接口 May 13, 2023 pm 12:01 PM

在当今互联网时代,微信公众号成为了越来越多企业的重要营销渠道。想要自己的微信公众号实现更多的功能,常常需要编写相应的接口。本文将以PHP语言为例,介绍如何构建一个微信公众号API接口。一、前置准备在编写微信公众号API接口之前,需要开发者拥有一个微信公众号的账号,并且在微信公众平台中申请开发者接口权限。申请成功后,可以获取到相关的开发者AppID和AppSe

See all articles