天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

解析php框架codeigniter中如何使用框架的session

里面有兩種session的使用方法:
1是php的原始的session使用方法,這個(gè)很簡單,$_SESSION['name']="name",然后在需要的地方顯示:echo $_SESSION['name'];
2是codeigniter這個(gè)框架的一個(gè)方法:
下面就詳細(xì)講解如何使用這個(gè)有點(diǎn)點(diǎn)復(fù)雜的方法:
首先,在/ci/application/config下面的config.php文件中找到:$config['encryption_key'] = '';這個(gè)里面隨便填什么值都可以,但是不能為空。一般是英文啊,不要鉆牛角尖。
接著在/ci/application/config下面的auto.php文件中找到:$autoload['libraries'] = array('');里面要填寫:$autoload['libraries'] = array('session');或者在適當(dāng)?shù)牡胤饺鏲ontrol文件夾里面的相應(yīng)文件中(一般是在構(gòu)造方法中)寫:$this->load->library('session');這樣也行。
現(xiàn)在環(huán)境配置好了,現(xiàn)在就是寫代碼了:
在需要放入session的地方寫:
$this->session->set_userdata('name','yang');
這樣session里面就有了值了。
顯示值:
echo $this->session->userdata('name');
如果是array,則:
$newdata = array(
                   'username'  => 'johndoe',
                   'email'     => 'johndoe@some-site.com',
                   'logged_in' => TRUE
               );
$this->session->set_userdata($newdata);
以下是轉(zhuǎn)載的別人的詳細(xì)的有點(diǎn)廢話的相關(guān)知識:
Sessions會在每個(gè)頁面載入后開始運(yùn)行,所以session類必須首先被初始化。

1、您可以在控制器中初始化,也可以在系統(tǒng)中自動(dòng)加載(譯者注:在autoload.php設(shè)定)$autoload['libraries'] = array('session');

2、要在您的控制器構(gòu)造函數(shù)中初始化session類,您可以使用 $this->load->library 函數(shù):$this->load->library('session');一旦被載入, session就可以這樣使用: $this->session。
session類的絕大部分都會在后臺運(yùn)行,所以初始化session時(shí),它session數(shù)據(jù)會被自動(dòng)讀取、創(chuàng)建和更新。

Sessions 是怎樣工作的?
需要知道的非常重要的一點(diǎn)就是,session類一旦被初始化,它就會自動(dòng)運(yùn)行。對于后面的事情,您可以完全不作理會。正如您將會在下面看到的一樣,您可以正常使用session來工作,甚至還可以添加自己的session數(shù)據(jù),而在這一切的過程中,讀、寫和更新的操作都是自動(dòng)完成的。

當(dāng)頁面載入后,session類就會檢查用戶的cookie中是否存在有效的session數(shù)據(jù)。如果session數(shù)據(jù)不存在(或者已經(jīng)過期),那么就會創(chuàng)建一個(gè)新的session并把他保存在cookie中。如果session數(shù)據(jù)存在,那么他的信息就會被更新,同時(shí)cookie也會被同時(shí)更新。每次更新都會重新生成session_id的值。

默認(rèn)情況下, Session Cookie 每隔 5 分鐘才會更新一次,這樣會減少對處理器的負(fù)荷。如果你重復(fù)的裝載頁面, 你會發(fā)現(xiàn)"上次活動(dòng)"的時(shí)間在五分鐘,或多余五分鐘的時(shí)候才會變化,也就是 cookie上次被寫入的時(shí)間。 這個(gè)時(shí)間可以通過設(shè)置 application/config/config.php 文件里的 $config['sess_time_to_update'] 行來改變。

一個(gè) session 是由一個(gè)包括下列信息的數(shù)組組成的:
唯一的用戶Session ID (這是一個(gè)平均信息量統(tǒng)計(jì)出來的非常堅(jiān)固的隨機(jī)字符串,使用MD5加密,默認(rèn)是每五分鐘就重新生成一次。
用戶的 IP 地址
用戶瀏覽器信息(取前50個(gè)字符)
最新的一個(gè)活躍時(shí)間戳.
以上數(shù)據(jù)將會用以下數(shù)組格式序列化并存到cookie里:
復(fù)制代碼 代碼如下:
[array]
(
     'session_id'    => random hash,
     'ip_address'    => 'string - user IP address',
     'user_agent'    => 'string - user agent data',
     'last_activity' => timestamp
)

1、取得 Session 數(shù)據(jù):
可以通過如下的函數(shù)來得到 session 數(shù)組的任何信息:
$this->session->userdata('item');
item 是數(shù)組里的相對應(yīng)數(shù)據(jù)的索引。例如,想要獲得 session ID, 你要使用如下的代碼:
$session_id = $this->session->userdata('session_id');
注意: 如果你的目標(biāo)數(shù)據(jù)不存在的話,這個(gè)函數(shù)會返回 FALSE (布爾值boolean)。

2、添加自定義的 Session 數(shù)據(jù):
假設(shè),有個(gè)特定用戶登陸到你的網(wǎng)站, 當(dāng)他通過檢測后 你可以添加他的用戶名和電子郵件到 session cookie 中,這些信息可以在不去訪問數(shù)據(jù)庫的情況下,當(dāng)成全局量來使用。
通過以下函數(shù),你可以傳遞一個(gè)新的用戶數(shù)組到 session 數(shù)組中:
$this->session->set_userdata($array);
$array 是一個(gè)結(jié)合數(shù)組,用來存儲你的新數(shù)據(jù)。例如 :
復(fù)制代碼 代碼如下:
$newdata = array(
                   'username'  => 'johndoe',
                   'email'     => 'johndoe@some-site.com',
                   'logged_in' => TRUE
               );
$this->session->set_userdata($newdata);

如果使用下面 set_userdata()函數(shù)的寫法,可以每次只添加一個(gè)用戶數(shù)據(jù)。
$this->session->set_userdata('some_name', 'some_value');
注意: Cookies 只能存儲 4KB 的數(shù)據(jù), 使用時(shí)要小心超出它的容量。特別指出的是,加密會產(chǎn)生比原數(shù)據(jù)更長的數(shù)據(jù)字符串,所以一定要當(dāng)心你要存放數(shù)據(jù)的大小。

3、刪除 Session 數(shù)據(jù):正如使用 set_userdata() 是用來添加信息到 session 中,而通過向unset_userdata() 函數(shù)中傳遞 session key 可以用來刪除這些信息。例如, 你想要從 session 信息里去掉 'some_name':
$this->session->unset_userdata('some_name');
也可以給這個(gè)函數(shù)傳一個(gè)要?jiǎng)h除項(xiàng)的關(guān)聯(lián)數(shù)組。
$array_items = array('username' => '', 'email' => '');
$this->session->unset_userdata($array_items);

4、將 Session 數(shù)據(jù)存入數(shù)據(jù)庫:
當(dāng)session 數(shù)據(jù)在數(shù)據(jù)庫中可用時(shí),每當(dāng)從用戶cookie中發(fā)現(xiàn)一個(gè)有效的session,一個(gè)數(shù)據(jù)庫查詢就會被執(zhí)行以匹配它。如果 session ID 不相配,session 就會被銷毀。Session ID永遠(yuǎn)不會更新,它們只會在一個(gè)新的會話創(chuàng)建時(shí)生成。
為了存儲session,你必須先創(chuàng)建一個(gè)數(shù)據(jù)表。這是 session 類所需的基本結(jié)構(gòu)(用于MySQL的):
復(fù)制代碼 代碼如下:
CREATE TABLE IF NOT EXISTS `ci_sessions` (
session_id varchar(40) DEFAULT '0' NOT NULL,
ip_address varchar(16) DEFAULT '0' NOT NULL,
user_agent varchar(50) NOT NULL,
last_activity int(10) unsigned DEFAULT 0 NOT NULL,
user_data text DEFAULT '' NOT NULL,
PRIMARY KEY (session_id) );

一旦啟用了,Session類就會在數(shù)據(jù)庫中存儲session數(shù)據(jù)。
同時(shí)確保你已經(jīng)在配置文件中指定了數(shù)據(jù)表名:$config['sess_table_name'] = 'ci_sessions';
注意: 默認(rèn)情況下這個(gè)表叫做 ci_sessions, 但是你可以給它指定任意名字,只要你更新了 application/config/config.php 文件以確保它包含了你所起的名字。一旦你創(chuàng)建了數(shù)據(jù)表,你就可以像下面這樣在config.php文件中啟用數(shù)據(jù)庫選項(xiàng):
$config['sess_use_database'] = TRUE;
注意: Session類已經(jīng)內(nèi)置了清除過期session的垃圾回收機(jī)制,因此你不需要編寫你自己的事務(wù)來做這個(gè)。

5、銷毀 Session
要清除當(dāng)前 session:$this->session->sess_destroy();
Session 的參數(shù)

6、你可以在application/config/config.php 文件中找到以下的 Session 相關(guān)的參數(shù):
參數(shù)     默認(rèn)     選項(xiàng)     描述
sess_cookie_name     ci_session     無     你想要保存 Session Cookie 的名字。
sess_expiration     7200     無     session 持續(xù)的秒數(shù)。默認(rèn)是2個(gè)小時(shí)(7200秒)。如果將這個(gè)數(shù)值設(shè)為: 0,就可以得到 永久 session。
sess_expire_on_close     FALSE     TRUE/FALSE (boolean)     這個(gè)選項(xiàng)決定當(dāng)瀏覽器窗口關(guān)閉時(shí)是否自動(dòng)使session過期。
sess_encrypt_cookie     FALSE     TRUE/FALSE (布爾值boolean)     是否對 session 數(shù)據(jù)加密.
sess_use_database     FALSE     TRUE/FALSE (布爾值boolean)     是否將 session 數(shù)據(jù)存放入數(shù)據(jù)庫中。在開啟這個(gè)選項(xiàng)前,你要先創(chuàng)建一個(gè)數(shù)據(jù)庫表。
sess_table_name     ci_sessions     任何有效的 SQL 表名     session 數(shù)據(jù)庫表的名字。
sess_time_to_update     300     時(shí)間以秒計(jì)算     這個(gè)選項(xiàng)控制 session 類多久會產(chǎn)生一個(gè)新的session 和 session id。
sess_match_ip     FALSE     TRUE/FALSE (布爾值boolean)     是否通過用戶的IP地址來讀取 session 的數(shù)據(jù)。 注意 ,有些網(wǎng)絡(luò)運(yùn)行商 ISPs 會動(dòng)態(tài)的改變IP, 所以將這個(gè)選項(xiàng)設(shè)為 FALSE, 才有可能得到永久的 session。
sess_match_useragent     TRUE     TRUE/FALSE (布爾值boolean)     是否要按照對應(yīng)的 User Agent 來讀取 session 數(shù)據(jù)。

php技術(shù)解析php框架codeigniter中如何使用框架的session,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 少妇高潮久久久久7777 | 日韩做A爰片久久毛片A片毛茸茸 | 午夜办公室在线观看高清电影 | 神马电影dy888午夜我不卡 | 男女交性视频无遮挡全过程 | 驯服有夫之妇HD中字日本 | 成人国内精品久久久久影院 | 美女靠逼漫画 | 亚洲精品视频免费在线观看 | 国产一区二区三区乱码在线观看 | 高清毛片一区二区三区 | 极品少妇小泬50PTHEPON | 亲爱的妈妈6韩国电影免费观看 | 学生精品国产在线视频 | 老熟风间由美AV在线一区二区 | 99re热精品视频国产免费 | 国产精品xxxav免费视频 | 国产免费阿v精品视频网址 国产免费69成人精品视频 | 扒开粉嫩的小缝末成年小美女 | 亚洲成AV人电影在线观看 | 无码国产色欲XXXX视频 | 国产露脸A片国语露对白 | 成人毛片免费在线观看 | 香艳69xxxxx有声小说 | 亚洲AV电影天堂男人的天堂 | 免费乱理伦片在线观看八戒 | 久久66热在线视频精品 | 国产成人精品视频播放 | 91桃色污无限免费看 | 欧美一级久久久久久久大 | 亚洲野狼综合网站 | 精子pk美女 | 在线观看国产亚洲 | 色婷婷欧美在线播放内射 | 国产精品免费观看视频 | 亚洲伊人久久综合影院2021 | 果冻传媒AV精品一区 | 国产一区二区在线免费观看 | 91国偷自产一区二区三区 | 三级aa久久| 在线观看亚洲免费人成网址 |