Сыртқы файлдардан кіру кодының сеанс мәндері

Код-дизайн жобасында мен KCK табушысын қостым.

кодының контроллері арқылы бақыланатын кейбір сеанстардың мәндері қажет. CI сессиясының мәндерін сыртқы файлдардан қалай алуға болады?

4

6 жауаптар

<?php
    ob_start();
    include('index.php');
    ob_end_clean();
    $CI =& get_instance();
    $CI->load->library('session'); //if it's not autoloaded in your CI setup
    echo $CI->session->userdata('name');
?>
4
қосылды
Бұл мен үшін де жұмыс істемейді. Бұл құрамына ('index.php'); файлын қосыңыз, оны сыртқы_codeigniter қалтасынан қосқанмын. Бұған көмектесесіз бе?
қосылды автор Ashutosh Singh, көзі
Бұл мен үшін жұмыс істемейді: Жүйе қалтасының жолы дұрыс орнатылмаған сияқты. Келесі файлды ашып, оны түзетіңіз: index.php
қосылды автор Jorge Olivares, көзі

Егер сіз сеанстарға (және олар файл негізделген) кіруге тырыссаңыз, CI файлын жүктегіңіз келмесе, сіз мұны істей аласыз:

define('ENVIRONMENT', 'development');

$ds = DIRECTORY_SEPARATOR;
define('BASEPATH', dirname(dirname(dirname(__FILE__))));
define('APPPATH', BASEPATH . $ds . 'application' . $ds);
define('LIBBATH', BASEPATH . "{$ds}system{$ds}libraries{$ds}Session{$ds}");

require_once LIBBATH . 'Session_driver.php';
require_once LIBBATH . "drivers{$ds}Session_files_driver.php";
require_once BASEPATH . "{$ds}system{$ds}core{$ds}Common.php";

$config = get_config();

if (empty($config['sess_save_path'])) {
    $config['sess_save_path'] = rtrim(ini_get('session.save_path'), '/\\');
}

$config = array(
    'cookie_lifetime'   => $config['sess_expiration'],
    'cookie_name'       => $config['sess_cookie_name'],
    'cookie_path'       => $config['cookie_path'],
    'cookie_domain'     => $config['cookie_domain'],
    'cookie_secure'     => $config['cookie_secure'],
    'expiration'        => $config['sess_expiration'],
    'match_ip'          => $config['sess_match_ip'],
    'save_path'         => $config['sess_save_path'],
    '_sid_regexp'       => '[0-9a-v]{32}',
);


$class = new CI_Session_files_driver($config);

if (is_php('5.4')) {
    session_set_save_handler($class, TRUE);
} else {
    session_set_save_handler(
        array($class, 'open'),
        array($class, 'close'),
        array($class, 'read'),
        array($class, 'write'),
        array($class, 'destroy'),
        array($class, 'gc')
    );
    register_shutdown_function('session_write_close');
}
session_name($config['cookie_name']);
session_start();
var_dump($_SESSION);
1
қосылды

Екі шешімді есте ұстау керек (бұл CI cookie файлдарын декодтауды қамтымайды)

1) CI ішіне тағайындаған кезде оларды PHP сеанстарына көшіруге болады:

$_SESSION['name'] = $this->session->userdata('name');

Сондықтан сіздің серверіңіздегі әрбір PHP файлына қол жетімді боласыз; Менің ойымша, бұл - ең жылдам шешім.

2) сеансты деректер базасына сақтаңыз және мәндерді алу үшін оған қосылыңыз.

0
қосылды
Мен осы сайттан шешім алдым renownedmedia.com/ blog/& hellip; оның туындылары, бірақ оның кейбір модификациялары қажет.
қосылды автор balaphp, көзі

Сыртқы кіру қолданбасын пайдаланып, CI сессияларынан деректерді пайдаланғым келеді. Мен осы ақпаратты http://codeigniter.com/forums/viewthread/86380/ сайтында қалай тапқандығын білдім. бұл CI шеңберінен ештеңе істемей-ақ істеу. Мен үшін бұл өте ыңғайлы, себебі кез келген сәйкессіздіктерді тудырады.

Сілтемеден ақпаратты алу мәселесі туындаған жағдайда:

  1. Егер 2-ші сесси кукилерін қолдансаңыз, тек сеанс cookie файлын алыңыз.
  2. Егер сеансты сеансты дерекқормен қолданатын болсаңыз, сеансты тексеру үшін сеанс cookie файлын және дерекқордағы сәйкестікке сұрауды ci_session кестесінен алыңыз.
  3. Деректерді қолданыңыз және деректерді cookie файлында (және дерекқор сеансын пайдаланғанда дерекқорда) қажетінше қосыңыз.
0
қосылды
Codeigniter Link жұмыс істемейді
қосылды автор Mr. ED, көзі

Привет, мен осы коды алдымен googling алды.

     //path to your database.php file   
     require_once("../frontend/config/database.php");

     $cisess_cookie = $_COOKIE['ci_session'];
     $cisess_cookie = stripslashes($cisess_cookie);
     $cisess_cookie = unserialize($cisess_cookie);
     $cisess_session_id = $cisess_cookie['session_id'];

     $cisess_connect = mysql_connect($db['default']['hostname'], $db['default']      ['username'], $db['default']['password']);
     if (!$cisess_connect) {
       die("<div class=\"error\">" . mysql_error() . "</div>");
     }
     $cisess_query = "SELECT user_data FROM ci_sessions WHERE session_id =        '$cisess_session_id'";

     mysql_select_db($db['default']['database'], $cisess_connect);
     $cisess_result = mysql_query($cisess_query, $cisess_connect);
     if (!$cisess_result) {
       die("Invalid Query");
     }
     $cisess_row = mysql_fetch_assoc($cisess_result);
     $cisess_data = unserialize($cisess_row['user_data']);

    //print all session values 
     print_r($cisess_data);
0
қосылды

Менімен бірге жауаптар ('index.php') және CI данасын алу жаман емес, бірақ менің жағдайда бұл әрекеттер тым баяу.

Менде кодиинизаторлар файлдарды пайдалану үшін орнатылғандықтан, мен бұл шешімді сәл жылдам жасадым:

function CIsession()
{
    $pathToSessionFiles = 'path/to/files/set/in/codeigniter/config/';

    $h = md5($_SERVER['REMOTE_ADDR']);//$config['sess_match_ip'] = TRUE;
    foreach( glob($pathToSessionFiles . '*' ) as $f )
    {   
        if( strpos($f, $h) ) { $s[ $f ] = filemtime($f); }
    }
    arsort($s);
    $s = array_keys($s);
    $s = reset($s);
    $s = file($s);
    $s = reset($s);
    $s = explode(';', $s);
    foreach($s as $k => $v)
    {
        $s[$k] = str_getcsv($v, ":", '"');
        $s[$k][0] = substr(reset($s[$k]), 0, strpos(reset($s[$k]), '|'));

        $s[reset($s[$k])] = end($s[$k]);
        unset($s[$k]);
    }

    return $s;
}

Біреуге көмектеседі деген үміттемін!

0
қосылды