| 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;
 
- }
 
- ?>
 
 
  |