Server : Apache
System : Linux iZ2vcgyutqttsd1p850kl8Z 3.10.0-1160.92.1.el7.x86_64 #1 SMP Tue Jun 20 11:48:01 UTC 2023 x86_64
User : www ( 1000)
PHP Version : 5.6.40
Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
Directory :  /www/wwwroot/saimikebio.com/mobile/include/
Upload File :
Current Directory [ Writeable ] Root Directory [ Writeable ]


Current File : /www/wwwroot/saimikebio.com/mobile/include/lib_license.php
<?php



/**

 * ECSHOP LICENSE 相关函数库

 * ============================================================================

 * * 版权所有 2005-2012 上海商派网络科技有限公司,并保留所有权利。

 * 网站地址: http://www.ecshop.com;

 * ----------------------------------------------------------------------------

 * 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和

 * 使用;不允许对程序代码以任何形式任何目的的再发布。

 * ============================================================================

 * $Author: liubo $

 * $Id: lib_article.php 16336 2009-06-24 07:09:13Z liubo $

*/



if (!defined('IN_ECTOUCH'))

{

    die('Hacking attempt');

}



/**

 * 获得网店 license 信息

 *

 * @access  public

 * @param   integer     $size

 *

 * @return  array

 */

function get_shop_license()

{

    // 取出网店 license

    $sql = "SELECT code, value

            FROM " . $GLOBALS['ecs']->table('touch_shop_config') . "

            WHERE code IN ('certificate_id', 'token', 'certi')

            LIMIT 0,3";

    $license_info = $GLOBALS['db']->getAll($sql);

    $license_info = is_array($license_info) ? $license_info : array();

    $license = array();

    foreach ($license_info as $value)

    {

        $license[$value['code']] = $value['value'];

    }



    return $license;

}



/**

 * 功能:生成certi_ac验证字段

 * @param   string     POST传递参数

 * @param   string     证书token

 * @return  string

 */

function make_shopex_ac($post_params, $token)

{

    if (!is_array($post_params))

    {

        return;

    }



    // core

    ksort($post_params);

    $str = '';

    foreach($post_params as $key=>$value){

        if($key != 'certi_ac')

        {

            $str .= $value;

        }

    }



    return md5($str . $token);

}



/**

 * 功能:与 ECShop 交换数据

 *

 * @param   array     $certi    登录参数

 * @param   array     $license  网店license信息

 * @param   bool      $use_lib  使用哪一个json库,0为ec,1为shopex

 * @return  array

 */

function exchange_shop_license($certi, $license, $use_lib = 0)

{

    if (!is_array($certi))

    {

        return array();

    }



    include_once(ROOT_PATH . 'include/cls_transport.php');

    include_once(ROOT_PATH . 'include/cls_json.php');



    $params = '';

    foreach ($certi as $key => $value)

    {

        $params .= '&' . $key . '=' . $value;

    }

    $params = trim($params, '&');



    $transport = new transport;

    //$transport->connect_timeout = 1;

    $request = $transport->request($license['certi'], $params, 'POST');

    $request_str = json_str_iconv($request['body']);



    if (empty($use_lib))

    {

        $json = new JSON();

        $request_arr = $json->decode($request_str, 1);

    }

    else

    {

        include_once(ROOT_PATH . 'include/shopex_json.php');

        $request_arr = json_decode($request_str, 1);

    }



    return $request_arr;

}



/**

 * 功能:处理登录返回结果

 *

 * @param   array     $cert_auth    登录返回的用户信息

 * @return  array

 */

function process_login_license($cert_auth)

{

    if (!is_array($cert_auth))

    {

        return array();

    }



    $cert_auth['auth_str'] = trim($cert_auth['auth_str']);

    if (!empty($cert_auth['auth_str']))

    {

        $cert_auth['auth_str'] = $GLOBALS['_LANG']['license_' . $cert_auth['auth_str']];

    }



    $cert_auth['auth_type'] = trim($cert_auth['auth_type']);

    if (!empty($cert_auth['auth_type']))

    {

        $cert_auth['auth_type'] = $GLOBALS['_LANG']['license_' . $cert_auth['auth_type']];

    }



    return $cert_auth;

}



/**

 * 功能:license 登录

 *

 * @param   array     $certi_added    配置信息补充数组 array_key 登录信息的key;array_key => array_value;

 * @return  array     $return_array['flag'] = login_succ、login_fail、login_ping_fail、login_param_fail;

 *                    $return_array['request'];

 */

function license_login($certi_added = '')

{

    // 登录信息配置

    $certi['certi_app'] = ''; // 证书方法

    $certi['app_id'] = 'ecshop_b2c'; // 说明客户端来源

    $certi['app_instance_id'] = ''; // 应用服务ID

    $certi['version'] = LICENSE_VERSION; // license接口版本号

    $certi['shop_version'] = VERSION . '#' .  RELEASE; // 网店软件版本号

    $certi['certi_url'] = sprintf($GLOBALS['ecs']->url()); // 网店URL

    $certi['certi_session'] = $GLOBALS['sess']->get_session_id(); // 网店SESSION标识

    $certi['certi_validate_url'] = sprintf($GLOBALS['ecs']->url() . 'certi.php'); // 网店提供于官方反查接口

    $certi['format'] = 'json'; // 官方返回数据格式

    $certi['certificate_id'] = ''; // 网店证书ID

    // 标识

    $certi_back['succ']   = 'succ';

    $certi_back['fail']   = 'fail';

    // return 返回数组

    $return_array = array();



    if (is_array($certi_added))

    {

        foreach ($certi_added as $key => $value)

        {

            $certi[$key] = $value;

        }

    }



    // 取出网店 license

    $license = get_shop_license();



    // 检测网店 license

    if (!empty($license['certificate_id']) && !empty($license['token']) && !empty($license['certi']))

    {

        // 登录

        $certi['certi_app'] = 'certi.login'; // 证书方法

        $certi['app_instance_id'] = 'cert_auth'; // 应用服务ID

        $certi['certificate_id'] = $license['certificate_id']; // 网店证书ID

        $certi['certi_ac'] = make_shopex_ac($certi, $license['token']); // 网店验证字符串



        $request_arr = exchange_shop_license($certi, $license);

        if (is_array($request_arr) && $request_arr['res'] == $certi_back['succ'])

        {

            $return_array['flag'] = 'login_succ';

            $return_array['request'] = $request_arr;

        }

        elseif (is_array($request_arr) && $request_arr['res'] == $certi_back['fail'])

        {

            $return_array['flag'] = 'login_fail';

            $return_array['request'] = $request_arr;

        }

        else

        {

            $return_array['flag'] = 'login_ping_fail';

            $return_array['request'] = array('res' => 'fail');

        }

    }

    else

    {

        $return_array['flag'] = 'login_param_fail';

        $return_array['request'] = array('res' => 'fail');

    }



    return $return_array;

}



/**

 * 功能:license 注册

 *

 * @param   array     $certi_added    配置信息补充数组 array_key 登录信息的key;array_key => array_value;

 * @return  array     $return_array['flag'] = reg_succ、reg_fail、reg_ping_fail;

 *                    $return_array['request'];

 */

function license_reg($certi_added = '')

{

    // 登录信息配置

    $certi['certi_app'] = ''; // 证书方法

    $certi['app_id'] = 'ecshop_b2c'; // 说明客户端来源

    $certi['app_instance_id'] = ''; // 应用服务ID

    $certi['version'] = LICENSE_VERSION; // license接口版本号

    $certi['shop_version'] = VERSION . '#' .  RELEASE; // 网店软件版本号

    $certi['certi_url'] = sprintf($GLOBALS['ecs']->url()); // 网店URL

    $certi['certi_session'] = $GLOBALS['sess']->get_session_id(); // 网店SESSION标识

    $certi['certi_validate_url'] = sprintf($GLOBALS['ecs']->url() . 'certi.php'); // 网店提供于官方反查接口

    $certi['format'] = 'json'; // 官方返回数据格式

    $certi['certificate_id'] = ''; // 网店证书ID

    // 标识

    $certi_back['succ']   = 'succ';

    $certi_back['fail']   = 'fail';

    // return 返回数组

    $return_array = array();



    if (is_array($certi_added))

    {

        foreach ($certi_added as $key => $value)

        {

            $certi[$key] = $value;

        }

    }



    // 取出网店 license

    $license = get_shop_license();



    // 注册

    $certi['certi_app'] = 'certi.reg'; // 证书方法

    $certi['certi_ac'] = make_shopex_ac($certi, ''); // 网店验证字符串

    unset($certi['certificate_id']);



    $request_arr = exchange_shop_license($certi, $license);

    if (is_array($request_arr) && $request_arr['res'] == $certi_back['succ'])

    {

        // 注册信息入库

        $sql = "UPDATE " . $GLOBALS['ecs']->table('touch_shop_config') . "

                SET value = '" . $request_arr['info']['certificate_id'] . "' WHERE code = 'certificate_id'";

        $GLOBALS['db']->query($sql);

        $sql = "UPDATE " . $GLOBALS['ecs']->table('touch_shop_config') . "

                SET value = '" . $request_arr['info']['token'] . "' WHERE code = 'token'";

        $GLOBALS['db']->query($sql);



        $return_array['flag'] = 'reg_succ';

        $return_array['request'] = $request_arr;

        clear_cache_files();

    }

    elseif (is_array($request_arr) && $request_arr['res'] == $certi_back['fail'])

    {

        $return_array['flag'] = 'reg_fail';

        $return_array['request'] = $request_arr;

    }

    else

    {

        $return_array['flag'] = 'reg_ping_fail';

        $return_array['request'] = array('res' => 'fail');

    }



    return $return_array;

}

?>