foreground.class.php 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <?php
  2. class foreground {
  3. public $db, $memberinfo;
  4. private $_member_modelinfo;
  5. public function __construct() {
  6. self::check_ip();
  7. $this->db = pc_base::load_model('member_model');
  8. //ajax验证信息不需要登录
  9. if(substr(ROUTE_A, 0, 7) != 'public_') {
  10. self::check_member();
  11. }
  12. }
  13. /**
  14. * 判断用户是否已经登陆
  15. */
  16. final public function check_member() {
  17. $phpcms_auth = param::get_cookie('auth');
  18. if(ROUTE_M =='member' && ROUTE_C =='index' && in_array(ROUTE_A, array('login', 'register', 'mini','send_newmail'))) {
  19. if ($phpcms_auth && ROUTE_A != 'mini') {
  20. showmessage(L('login_success', '', 'member'), 'index.php?m=member&c=index');
  21. } else {
  22. return true;
  23. }
  24. } else {
  25. //判断是否存在auth cookie
  26. if ($phpcms_auth) {
  27. $auth_key = $auth_key = get_auth_key('login');
  28. list($userid, $password) = explode("\t", sys_auth($phpcms_auth, 'DECODE', $auth_key));
  29. //验证用户,获取用户信息
  30. $this->memberinfo = $this->db->get_one(array('userid'=>$userid));
  31. if($this->memberinfo['islock']) exit('<h1>Bad Request!</h1>');
  32. //获取用户模型信息
  33. $this->db->set_model($this->memberinfo['modelid']);
  34. $this->_member_modelinfo = $this->db->get_one(array('userid'=>$userid));
  35. $this->_member_modelinfo = $this->_member_modelinfo ? $this->_member_modelinfo : array();
  36. $this->db->set_model();
  37. if(is_array($this->memberinfo)) {
  38. $this->memberinfo = array_merge($this->memberinfo, $this->_member_modelinfo);
  39. }
  40. if($this->memberinfo && $this->memberinfo['password'] === $password) {
  41. if (!defined('SITEID')) {
  42. define('SITEID', $this->memberinfo['siteid']);
  43. }
  44. if($this->memberinfo['groupid'] == 1) {
  45. param::set_cookie('auth', '');
  46. param::set_cookie('_userid', '');
  47. param::set_cookie('_username', '');
  48. param::set_cookie('_groupid', '');
  49. showmessage(L('userid_banned_by_administrator', '', 'member'), 'index.php?m=member&c=index&a=login');
  50. } elseif($this->memberinfo['groupid'] == 7) {
  51. param::set_cookie('auth', '');
  52. param::set_cookie('_userid', '');
  53. param::set_cookie('_groupid', '');
  54. //设置当前登录待验证账号COOKIE,为重发邮件所用
  55. param::set_cookie('_regusername', $this->memberinfo['username']);
  56. param::set_cookie('_reguserid', $this->memberinfo['userid']);
  57. param::set_cookie('_reguseruid', $this->memberinfo['phpssouid']);
  58. param::set_cookie('email', $this->memberinfo['email']);
  59. showmessage(L('need_emial_authentication', '', 'member'), 'index.php?m=member&c=index&a=register&t=2');
  60. }
  61. } else {
  62. param::set_cookie('auth', '');
  63. param::set_cookie('_userid', '');
  64. param::set_cookie('_username', '');
  65. param::set_cookie('_groupid', '');
  66. }
  67. unset($userid, $password, $phpcms_auth, $auth_key);
  68. } else {
  69. $forward= isset($_GET['forward']) ? urlencode($_GET['forward']) : urlencode(get_url());
  70. showmessage(L('please_login', '', 'member'), 'index.php?m=member&c=index&a=login&forward='.$forward);
  71. }
  72. }
  73. }
  74. /**
  75. *
  76. * IP禁止判断 ...
  77. */
  78. final private function check_ip(){
  79. $this->ipbanned = pc_base::load_model('ipbanned_model');
  80. $this->ipbanned->check_ip();
  81. }
  82. }