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