123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 |
- <?php
- /**
- *功能:支付宝接口公用函数
- *详细:该页面是请求、通知返回两个文件所调用的公用函数核心处理文件,不需要修改
- *版本:3.0
- *修改日期:2010-05-24
- '说明:
- '以下代码只是为了方便商户测试而提供的样例代码,商户可以根据自己网站的需要,按照技术文档编写,并非一定要使用该代码。
- '该代码仅供学习和研究支付宝接口使用,只是提供一个参考。
- */
-
- /**
- * 生成签名结果
- * @param $array要加密的数组
- * @param return 签名结果字符串
- */
- function build_mysign($sort_array,$security_code,$sign_type = "MD5") {
- $prestr = create_linkstring($sort_array); //把数组所有元素,按照“参数=参数值”的模式用“&”字符拼接成字符串
- $prestr = $prestr.$security_code; //把拼接后的字符串再与安全校验码直接连接起来
- $mysgin = sign($prestr,$sign_type); //把最终的字符串加密,获得签名结果
- return $mysgin;
- }
- /**
- * 把数组所有元素,按照“参数=参数值”的模式用“&”字符拼接成字符串
- * @param $array 需要拼接的数组
- * @param return 拼接完成以后的字符串
- */
- function create_linkstring($array) {
- $arg = "";
- while (list ($key, $val) = each ($array)) {
- $arg.=$key."=".$val."&";
- }
- $arg = substr($arg,0,count($arg)-2); //去掉最后一个&字符
- return $arg;
- }
- /********************************************************************************/
- /**除去数组中的空值和签名参数
- * @param $parameter 加密参数组
- * @param return 去掉空值与签名参数后的新加密参数组
- */
- function para_filter($parameter) {
- $para = array();
- while (list ($key, $val) = each ($parameter)) {
- if($key == "sign" || $key == "sign_type" || $val == "")continue;
- else $para[$key] = $parameter[$key];
- }
- return $para;
- }
- /********************************************************************************/
- /**对数组排序
- * @param $array 排序前的数组
- * @param return 排序后的数组
- */
- function arg_sort($array) {
- ksort($array);
- reset($array);
- return $array;
- }
- /********************************************************************************/
- /**加密字符串
- * @param $prestr 需要加密的字符串
- * @param return 加密结果
- */
- function sign($prestr,$sign_type) {
- $sign='';
- if($sign_type == 'MD5') {
- $sign = md5($prestr);
- }elseif($sign_type =='DSA') {
- //DSA 签名方法待后续开发
- die(L('dsa', 'pay'));
- }else {
- die(L('alipay_error','pay'));
- }
- return $sign;
- }
- // 日志消息,把支付宝返回的参数记录下来
- function log_result($word) {
- $fp = fopen("log.txt","a");
- flock($fp, LOCK_EX) ;
- fwrite($fp, L('execute_date', 'pay').":".strftime("%Y%m%d%H%M%S",time())."\n".$word."\n");
- flock($fp, LOCK_UN);
- fclose($fp);
- }
- /**实现多种字符编码方式
- * @param $input 需要编码的字符串
- * @param $_output_charset 输出的编码格式
- * @param $_input_charset 输入的编码格式
- * @param return 编码后的字符串
- */
- function charset_encode($input,$_output_charset ,$_input_charset) {
- $output = "";
- if(!isset($_output_charset) )$_output_charset = $_input_charset;
- if($_input_charset == $_output_charset || $input ==null ) {
- $output = $input;
- } elseif (function_exists("mb_convert_encoding")) {
- $output = mb_convert_encoding($input,$_output_charset,$_input_charset);
- } elseif(function_exists("iconv")) {
- $output = iconv($_input_charset,$_output_charset,$input);
- } else die("sorry, you have no libs support for charset change.");
- return $output;
- }
- /********************************************************************************/
- /**实现多种字符解码方式
- * @param $input 需要解码的字符串
- * @param $_output_charset 输出的解码格式
- * @param $_input_charset 输入的解码格式
- * @param return 解码后的字符串
- */
- function charset_decode($input,$_input_charset ,$_output_charset) {
- $output = "";
- if(!isset($_input_charset) )$_input_charset = $_input_charset ;
- if($_input_charset == $_output_charset || $input ==null ) {
- $output = $input;
- } elseif (function_exists("mb_convert_encoding")) {
- $output = mb_convert_encoding($input,$_output_charset,$_input_charset);
- } elseif(function_exists("iconv")) {
- $output = iconv($_input_charset,$_output_charset,$input);
- } else die("sorry, you have no libs support for charset changes.");
- return $output;
- }
- /*********************************************************************************/
- /**用于防钓鱼,调用接口query_timestamp来获取时间戳的处理函数
- 注意:由于低版本的PHP配置环境不支持远程XML解析,因此必须服务器、本地电脑中装有高版本的PHP配置环境。建议本地调试时使用PHP开发软件
- * @param $partner 合作身份者ID
- * @param return 时间戳字符串
- */
- function query_timestamp($partner) {
- $URL = "https://mapi.alipay.com/gateway.do?service=query_timestamp&partner=".$partner;
- $encrypt_key = "";
- return $encrypt_key;
- }
- ?>
|