Esempio n. 1
0
 /**
  * 设置指定用户SESSION
  *
  * @access public
  * @param            
  *
  * @return void
  */
 function set_session($username = '')
 {
     if (empty($username)) {
         ECTouch::sess()->destroy_session();
     } else {
         $sql = "SELECT user_id, password, email FROM " . $this->db->pre . 'users ' . " WHERE user_name='{$username}' LIMIT 1";
         $row = $this->db->getRow($sql);
         if ($row) {
             $_SESSION['user_id'] = $row['user_id'];
             $_SESSION['user_name'] = $username;
             $_SESSION['email'] = $row['email'];
         }
     }
 }
Esempio n. 2
0
 /**
  * 设置指定用户SESSION
  *
  * @access public
  * @param            
  *
  *
  *
  * @return void
  */
 function set_session($username = '')
 {
     if (empty($username)) {
         ECTouch::sess()->destroy_session();
     } else {
         $sql = "SELECT user_id, password, email FROM " . model('Base')->model->pre . "users WHERE user_name='{$username}' LIMIT 1";
         $row = model('Base')->model->query($sql);
         $row = reset($row);
         if ($row) {
             $_SESSION['user_id'] = $row['user_id'];
             $_SESSION['user_name'] = $username;
             $_SESSION['email'] = $row['email'];
         }
     }
 }
Esempio n. 3
0
/**
 * 功能: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'] = 'ectouch_free'; // 说明客户端来源
    $certi['app_instance_id'] = ''; // 应用服务ID
    $certi['version'] = LICENSE_VERSION; // license接口版本号
    $certi['shop_version'] = VERSION . '#' . RELEASE; // 网店软件版本号
    $certi['certi_url'] = sprintf(__URL__); // 网店URL
    $certi['certi_session'] = ECTouch::sess()->get_session_id(); // 网店SESSION标识
    $certi['certi_validate_url'] = sprintf(__URL__ . url('api/certi')); // 网店提供于官方反查接口
    $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 = model('LicenseBase')->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;
}
Esempio n. 4
0
 /**
  * 功能: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'] = 'ectouch_free';
     // 说明客户端来源
     $certi['app_instance_id'] = '';
     // 应用服务ID
     $certi['version'] = LICENSE_VERSION;
     // license接口版本号
     $certi['shop_version'] = VERSION . '#' . RELEASE;
     // 网店软件版本号
     $certi['certi_url'] = sprintf(__URL__);
     // 网店URL
     $certi['certi_session'] = ECTouch::sess()->get_session_id();
     // 网店SESSION标识
     $certi['certi_validate_url'] = sprintf(__URL__ . url('api/certi'));
     // 网店提供于官方反查接口
     $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 = model('LicenseBase')->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']) {
         // 注册信息入库
         $data['value'] = $request_arr['info']['certificate_id'];
         $condition['code'] = 'certificate_id';
         model('Base')->table('touch_shop_config')->data($data)->where($condition)->update();
         $data['value'] = $request_arr['info']['token'];
         $condition['code'] = 'certificate_id';
         model('Base')->table('touch_shop_config')->data($data)->where($condition)->update();
         $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;
 }
Esempio n. 5
0
 /**
  * 设置指定用户SESSION
  *
  * @access public
  * @param            
  *
  * @return void
  */
 function set_session($username = '')
 {
     if (empty($username)) {
         ECTouch::sess()->destroy_session();
     } else {
         $sql = "SELECT user_id, password, email FROM " . $this->db->pre . 'users ' . " WHERE user_name='{$username}' LIMIT 1";
         $row = $this->db->getRow($sql);
         if ($row) {
             $_SESSION['user_id'] = $row['user_id'];
             $_SESSION['user_name'] = $username;
             $_SESSION['email'] = $row['email'];
         } else {
             //如果验证码正确,并且用户不存在,注册新用户
             $fields = array($this->field_name, $this->field_mobile, $this->field_reg_date);
             $regtime = time();
             $values = array($username, $username, $regtime);
             $sql = "INSERT INTO " . $this->table($this->user_table) . " (" . implode(',', $fields) . ")" . " VALUES ('" . implode("', '", $values) . "')";
             $user_id = $this->db->query($sql);
             $_SESSION['user_id'] = $user_id;
             $_SESSION['user_name'] = $username;
         }
     }
 }