/** * 设置指定用户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']; } } }
/** * 设置指定用户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']; } } }
/** * 功能: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; }
/** * 功能: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; }
/** * 设置指定用户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; } } }