Rumah pembangunan bahagian belakang tutorial php discuz session机制_PHP教程

discuz session机制_PHP教程

Jul 13, 2016 pm 05:45 PM
discuz php session kod wujud mekanisme daripada terangkan

Php代码 
Discuz! X 中 SESSION 机制讲解 
 
  在Discuz! X中一如继往的,SESSION 并没有使用 PHP 自带的 SESSION 机制,而是系统的一套自带的机制。 
 
  在数据库中可以看到有两个 SESSION 表: 
    一个是pre_common_adminsession,是管理员登录后台的 SESSION 表; 
    另一个是 pre_common_session 表,是所有用户在前台浏览页面时的 SESSION 表。 
  这两个表都是内存表(内存表的读写速度远高于 MYISAM 表及文本文件)。 
 
  在 Discuz! X 中 SESSION 与 COOKIE 是分不开的,因为 SESSION 就是从客户端读取的 COOKIE , 
  然后由浏览页面时触发相关的函数执行,再写入数据库 SESSION 表。 
 
  我以登录流程为例来讲解程序具体是如何执行的。 
  在前台首页,点击登录后,弹出一个登录窗口,填写好数据后,提交。form表单提交的 URL 是: 
 
1   http://ux.com/member.php?mod=logging&action=login&loginsubmit=yes&floatlogin=yes&inajax=1 
 
数据提交到了 member.php 文件中,在程序中可看到下面的代码: 
01  $mod = !in_array($discuz->var['mod'], $modarray) ? 'logging' : $discuz->var['mod'];   //mod的值即是接下来加载的php页面 
02  define('CURMODULE', $mod); 
03  $modcachelist = array('register' => array('modreasons', 'stamptypeid', 'fields_required', 'fields_optional', 'ipctrl')); 
04  $cachelist = array(); 
05  if(isset($modcachelist[CURMODULE])) { 
06      $cachelist = $modcachelist[CURMODULE]; 
07  } 
08  $discuz->cachelist = $cachelist; 
09  $discuz->init(); 
10  runhooks(); 
11  require DISCUZ_ROOT.'./source/module/member/member_'.$mod.'.php';  //完成程序的包含操作 
 
打开source/module/member/member_logging.php文件,是一个类,在类的前面可看到下面三句代码: 
 
 
$ctl_obj = new logging_ctl(); 
$method = 'on_'.$_G['gp_action'];  // $_G['gp_action'] 等于action的值即 login 
$ctl_obj->$method();   //$ctl_obj->on_login(); 
 
在类中可找到login方法,在方法中,大约 56 行有下面一个判断语句: 
 
 
if(!submitcheck('loginsubmit', 1, $seccodecheck)) { 
 
判断语句是当游客浏览时,submitcheck 函数的返回值是假,取反,为真。 
当用户登录时,程序走的是else部分,在里面可看到下面五句代码: 
 
 
} else { 
            $_G['uid'] = $_G['member']['uid'] = 0; 
            $_G['username'] = $_G['member']['username'] = $_G['member']['password'] = '';    //变量赋值 
            $result = userlogin($_G['gp_username'], $_G['gp_password'], $_G['gp_questionid'], $_G['gp_answer'], $_G['setting']['autoidselect'] ? 'auto' : $_G['gp_loginfield']);  //从数据库查询用户数据,并返回相应的信息 
    
            if($result['status'] > 0) {  //状态值大于 0 ,说明有此用户,可以登录 
                setloginstatus($result['member'], $_G['gp_cookietime'] ? 2592000 : 0);  //设置登录状态,即是写 COOKIE 操作,COOKIE 中的数据即是 SESSION 中相应的数据,但此函数并不负责写 SESSION 的操作 
 
我们来看一下 source/function/function_login.php中的 setloginstatus 函数,是普通的写 COOKIE 操作,不再具体讲解: 
 
 
function setloginstatus($member, $cookietime) { 
    global $_G; 
    $_G['uid'] = $member['uid']; 
    $_G['username'] = $member['username']; 
    $_G['adminid'] = $member['adminid']; 
    $_G['groupid'] = $member['groupid']; 
    $_G['formhash'] = formhash(); 
    $_G['session']['invisible'] = getuserprofile('invisible'); 
    $_G['member'] = $member; 
    $_G['core']->session->isnew = 1; 
    
    dsetcookie('auth', authcode("{$member['password']}\t{$member['uid']}", 'ENCODE'), $cookietime, 1, true);   //authcode加密 
    dsetcookie('loginuser'); 
    dsetcookie('activationauth'); 
    dsetcookie('pmnum'); 

 
到这里可以说是登录流程大部分已经走完,但是 COOKIE 不清除时,会一直存在于客户端,如果超时,程序中会在判断弃用此 COOKIE,并重新写入。 
 
下面我们来看一下 DZX 中 SESSION 操作的类,在 source/class/calss_core.php 文件中: 
程序中每次请求都会加载 SESSION ,这是由核心类 discuz_core 中的 _init_session 方法来执行的,此方法被置于 类的 init方法中,说明每次加载类,会自动将 SESSION 写入。 
 
 
function _init_session() { 
  
    $this->session = new discuz_session();   //创建 SESSION 类 
  
    if($this->init_session) { 
        //从 COOKIE 中读取数据 
        $this->session->init($this->var['cookie']['sid'], $this->var['clientip'], $this->var['uid']); 
        $this->var['sid'] = $this->session->sid; 
        $this->var['session'] = $this->session->var; 
        //判断 SID 是否相等,不等,说明是多个用户在同一主机上登录网站,需要重新写 COOKIE 
        if($this->var['sid'] != $this->var['cookie']['sid']) { 
            dsetcookie('sid', $this->var['sid'], 86400); 
        } 
  
        if($this->session->isnew) { 
            if(ipbanned($this->var['clientip'])) { 
                $this->session->set('groupid', 6); 
            } 
        } 
  
        if($this->session->get('groupid') == 6) { 
            $this->var['member']['groupid'] = 6; 
            sysmessage('user_banned'); 
        } 
        //UID 不为空,且需要更新 SESSION 或是 SESSION 超时,更改用户状态,需要用户重新登录 
        if($this->var['uid'] && ($this->session->isnew || ($this->session->get('lastactivity') + 600)   
            $this->session->set('lastactivity', TIMESTAMP); 
  
            $update = array('lastip' => $this->var['clientip'], 'lastactivity' => TIMESTAMP); 
            if($this->session->isnew) { 
                $update['lastvisit'] = TIMESTAMP; 
            } 
            DB::update('common_member_status', $update, "uid='".$this->var['uid']."'"); 
        } 
  
    } 

 
操作 SESSION 的类是 discuz_session ,我们看这个类里面的两个方法: 
 
 
//此函数负责产生新的 SESSION,但并不负责写入数据库 
    function create($ip, $uid) { 
//创建SESSION,执行插入数据,由随机函数产生一个六位随机数即是session的唯一值时间为当前时间,sid为cookie中的sid 
        $this->isnew = true; 
        $this->var = $this->newguest; 
        $this->set('sid', random(6)); 
        $this->set('uid', $uid); 
        $this->set('ip', $ip); 
        $this->set('lastactivity', time()); 
        $this->sid = $this->var['sid']; 
    
        return $this->var; 
    } 
//此函数负责更新 SESSION 
    function update() { 
        if($this->sid !== null) { 
    
            $data = daddslashes($this->var); 
    
            if($this->isnew) { 
                $this->delete(); 
                DB::insert('common_session', $data, false, false, true); 
            } else { 
                DB::update('common_session', $data, "sid='$data[sid]'"); 
            } 
            dsetcookie('sid', $this->sid, 86400); 
        } 
    } 
 
至此我们知道了 SESSION 插入数据库的具体函数,与 COOKIE 的联系,但还不清楚是如何触发此操作的。 
打开 source/function/function_core.php 文件,找到函数,updatesession ,此函数负责更新 SESSION : 
 
 
function updatesession($force = false) { 
    
    global $_G; 
    static $updated = false; 
    if(!$updated) { 
        $discuz = & discuz_core::instance(); 
        foreach($discuz->session->var as $k => $v) { 
            if(isset($_G['member'][$k]) && $k != 'lastactivity') { 
                $discuz->session->set($k, $_G['member'][$k]); 
            } 
        } 
    
        foreach($_G['action'] as $k => $v) { 
            $discuz->session->set($k, $v); 
        } 
    
        $discuz->session->update(); 
    
        $updated = true; 
    } 
    return $updated; 

 
我们在程序源码中搜索此函数,可以看到在很多的模板中都有下面一句代码: 
 
 
{eval updatesession();} 
 
浏览页面时将触发此函数,并将 SESSION 写入数据库。 
 
整理一下思绪: 
第一步:用户登录,程序将 COOKIE 写入客户端,这些 COOKIE 即是 SESSION 的部分数据,如SID、IP、TIME,不包含用户名、密码等关键信息。 
第二步,登录成功后,程序会自动刷新页面,向服务器再次发送请求,服务器加载 discuz_core 核心类,并从 COOKIE 中读取到 SESSION 的相关信息,但还没有写入数据库。 
第三步,核心类加载完成,程序继续执行,最后加载模板,触发 updatesession 函数,SESSION 被写入数据库。 

作者“pz9042”
 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/478664.htmlTechArticlePhp代码 Discuz! X 中 SESSION 机制讲解 在Discuz! X中一如继往的,SESSION 并没有使用 PHP 自带的 SESSION 机制,而是系统的一套自带的机制。 在数据...
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 membawa beberapa ciri baharu, peningkatan keselamatan dan peningkatan prestasi dengan jumlah penamatan dan penyingkiran ciri yang sihat. Panduan ini menerangkan cara memasang PHP 8.4 atau naik taraf kepada PHP 8.4 pada Ubuntu, Debian, atau terbitan mereka

7 Fungsi PHP Saya Menyesal Saya Tidak Tahu Sebelum ini 7 Fungsi PHP Saya Menyesal Saya Tidak Tahu Sebelum ini Nov 13, 2024 am 09:42 AM

Jika anda seorang pembangun PHP yang berpengalaman, anda mungkin merasakan bahawa anda telah berada di sana dan telah melakukannya. Anda telah membangunkan sejumlah besar aplikasi, menyahpenyahpepijat berjuta-juta baris kod dan mengubah suai sekumpulan skrip untuk mencapai op

Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Dec 20, 2024 am 11:31 AM

Kod Visual Studio, juga dikenali sebagai Kod VS, ialah editor kod sumber percuma — atau persekitaran pembangunan bersepadu (IDE) — tersedia untuk semua sistem pengendalian utama. Dengan koleksi sambungan yang besar untuk banyak bahasa pengaturcaraan, Kod VS boleh menjadi c

Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Apr 05, 2025 am 12:04 AM

JWT adalah standard terbuka berdasarkan JSON, yang digunakan untuk menghantar maklumat secara selamat antara pihak, terutamanya untuk pengesahan identiti dan pertukaran maklumat. 1. JWT terdiri daripada tiga bahagian: header, muatan dan tandatangan. 2. Prinsip kerja JWT termasuk tiga langkah: menjana JWT, mengesahkan JWT dan muatan parsing. 3. Apabila menggunakan JWT untuk pengesahan di PHP, JWT boleh dijana dan disahkan, dan peranan pengguna dan maklumat kebenaran boleh dimasukkan dalam penggunaan lanjutan. 4. Kesilapan umum termasuk kegagalan pengesahan tandatangan, tamat tempoh, dan muatan besar. Kemahiran penyahpepijatan termasuk menggunakan alat debugging dan pembalakan. 5. Pengoptimuman prestasi dan amalan terbaik termasuk menggunakan algoritma tandatangan yang sesuai, menetapkan tempoh kesahihan dengan munasabah,

Bagaimana anda menghuraikan dan memproses HTML/XML dalam PHP? Bagaimana anda menghuraikan dan memproses HTML/XML dalam PHP? Feb 07, 2025 am 11:57 AM

Tutorial ini menunjukkan cara memproses dokumen XML dengan cekap menggunakan PHP. XML (bahasa markup extensible) adalah bahasa markup berasaskan teks yang serba boleh yang direka untuk pembacaan manusia dan parsing mesin. Ia biasanya digunakan untuk penyimpanan data

Program PHP untuk mengira vokal dalam rentetan Program PHP untuk mengira vokal dalam rentetan Feb 07, 2025 pm 12:12 PM

Rentetan adalah urutan aksara, termasuk huruf, nombor, dan simbol. Tutorial ini akan mempelajari cara mengira bilangan vokal dalam rentetan yang diberikan dalam PHP menggunakan kaedah yang berbeza. Vokal dalam bahasa Inggeris adalah a, e, i, o, u, dan mereka boleh menjadi huruf besar atau huruf kecil. Apa itu vokal? Vokal adalah watak abjad yang mewakili sebutan tertentu. Terdapat lima vokal dalam bahasa Inggeris, termasuk huruf besar dan huruf kecil: a, e, i, o, u Contoh 1 Input: String = "TutorialSpoint" Output: 6 menjelaskan Vokal dalam rentetan "TutorialSpoint" adalah u, o, i, a, o, i. Terdapat 6 yuan sebanyak 6

Terangkan pengikatan statik lewat dalam php (statik: :). Terangkan pengikatan statik lewat dalam php (statik: :). Apr 03, 2025 am 12:04 AM

Mengikat statik (statik: :) Melaksanakan pengikatan statik lewat (LSB) dalam PHP, yang membolehkan kelas panggilan dirujuk dalam konteks statik dan bukannya menentukan kelas. 1) Proses parsing dilakukan pada masa runtime, 2) Cari kelas panggilan dalam hubungan warisan, 3) ia boleh membawa overhead prestasi.

Apakah kaedah Magic PHP (__construct, __destruct, __call, __get, __set, dll) dan menyediakan kes penggunaan? Apakah kaedah Magic PHP (__construct, __destruct, __call, __get, __set, dll) dan menyediakan kes penggunaan? Apr 03, 2025 am 12:03 AM

Apakah kaedah sihir PHP? Kaedah sihir PHP termasuk: 1. \ _ \ _ Membina, digunakan untuk memulakan objek; 2. \ _ \ _ Destruct, digunakan untuk membersihkan sumber; 3. \ _ \ _ Call, mengendalikan panggilan kaedah yang tidak wujud; 4. \ _ \ _ Mendapatkan, melaksanakan akses atribut dinamik; 5. \ _ \ _ Set, melaksanakan tetapan atribut dinamik. Kaedah ini secara automatik dipanggil dalam situasi tertentu, meningkatkan fleksibiliti dan kecekapan kod.

See all articles