| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291 | <?phpdefined('IN_PHPCMS') or exit('No permission resources.');pc_base::load_app_class('foreground','member');//加载foreground 应用类. 自动判断是否登陆.pc_base::load_sys_class('format', '', 0);pc_base::load_sys_class('form', '', 0);class index extends foreground {	function __construct() {		parent::__construct();		$this->message_db = pc_base::load_model('message_model');		$this->message_group_db = pc_base::load_model('message_group_model');		$this->message_data_db = pc_base::load_model('message_data_model');		$this->_username = param::get_cookie('_username');		$this->_userid = param::get_cookie('_userid');		$this->_groupid = get_memberinfo($this->_userid,'groupid');		pc_base::load_app_func('global');		//定义站点ID常量,选择模版使用		$siteid = isset($_GET['siteid']) ? intval($_GET['siteid']) : get_siteid();  		define("SITEID",$siteid);  	}	public function init() {		$page = isset($_GET['page']) ? intval($_GET['page']) : 1;		$where = array('send_to_id'=>$this->_username,'replyid'=>'0'); 		$infos = $this->message_db->listinfo($where,$order = 'messageid DESC',$page, 10); 		$infos = new_html_special_chars($infos); 		$pages = $this->message_db->pages;		include template('message', 'inbox');	}			/**	 * 发送消息 	 */	public function send() {		//判断当前会员,是否可发,短消息.		$this->message_db->messagecheck($this->_userid);		if(isset($_POST['dosubmit'])) {			$username = $this->_username;			$tousername = safe_replace($_POST['info']['send_to_id']);			$r = $this->db->get_one(array('username'=>$tousername));			if(!$r) showmessage(L('user_not_exist','','member'));			if($tousername==$username){				showmessage(L('not_myself','','message'));			}			$subject = new_html_special_chars($_POST['info']['subject']);			$content = new_html_special_chars($_POST['info']['content']);			$this->message_db->add_message($tousername,$username,$subject,$content,true);			showmessage(L('operation_success'),HTTP_REFERER);		} else {			$show_validator = $show_scroll = $show_header = true;			include template('message', 'send');		}	}		/*	 *判断收件人是否存在 	 */	public function public_name() {		$username = isset($_GET['username']) && trim($_GET['username']) ? (pc_base::load_config('system', 'charset') == 'gbk' ? iconv('utf-8', 'gbk', trim($_GET['username'])) : trim($_GET['username'])) : exit('0');		$member_interface = pc_base::load_app_class('member_interface', 'member');		if ($username) {			$username = safe_replace($username);			//判断收件人不能为自己			if($username == $this->_username){				exit('0');			}			$data = $member_interface->get_member_info($username, 2);			if ($data!='-1') {				exit('1');			} else {				exit('0');			}		} else {			exit('0');		}			}		/**	 * 发件箱	 */	public function outbox() { 		$where = array('send_from_id'=>$this->_username,'del_type'=>'0');		$page = isset($_GET['page']) && intval($_GET['page']) ? intval($_GET['page']) : 1;		$infos = $this->message_db->listinfo($where,$order = 'messageid DESC',$page, $pages = '8');		$infos = new_html_special_chars($infos);		$pages = $this->message_db->pages;		include template('message', 'outbox');	}		/**	 * 收件箱	 */	public function inbox() { 		$where = array('send_to_id'=>$this->_username,'folder'=>'inbox');		$page = isset($_GET['page']) && intval($_GET['page']) ? intval($_GET['page']) : 1;		$infos = $this->message_db->listinfo($where,$order = 'messageid DESC',$page, $pages = '8'); 		$infos = new_html_special_chars($infos);		if (is_array($infos) && !empty($infos)) {			foreach ($infos as $infoid=>$info){ 				$reply_num = $this->message_db->count(array("replyid"=>$info['messageid']));				$infos[$infoid]['reply_num'] = $reply_num;	 		}		}		$pages = $this->message_db->pages;		include template('message', 'inbox');	}		/**	 * 群发邮件	 */	public function group() {		//查询自己有权限看的消息  		$where = array('typeid'=>1,'groupid'=>$this->_groupid,'status'=>1);		$page = isset($_GET['page']) && intval($_GET['page']) ? intval($_GET['page']) : 1;		$infos = $this->message_group_db->listinfo($where,$order = 'id DESC',$page, $pages = '8');		$infos = new_html_special_chars($infos);		$status = array();		if (is_array($infos) && !empty($infos)) {			foreach ($infos as $info){				$d = $this->message_data_db->select(array('userid'=>$this->_userid,'group_message_id'=>$info['id']));	 			if(!$d){	 				$status[$info['id']] = 0;//未读 红色	 			}else {	 				$status[$info['id']] = 1;	 			}			}		} 		$pages = $this->message_group_db->pages;		include template('message', 'group');	}		/**	 * 删除收件箱-短消息 	 * @param	intval	$sid	短消息ID,递归删除(修改状态为outbox)	 */	public function delete() {		if((!isset($_GET['messageid']) || empty($_GET['messageid'])) && (!isset($_POST['messageid']) || empty($_POST['messageid']))) {			showmessage(L('illegal_parameters'), HTTP_REFERER);		} else {			if(is_array($_POST['messageid'])){				foreach($_POST['messageid'] as $messageid_arr) {					$messageid_arr = intval($messageid_arr);					$this->message_db->update(array('folder'=>'outbox'),array('messageid'=>$messageid_arr,'send_to_id'=>$this->_username));				}				showmessage(L('operation_success'), HTTP_REFERER);			} 		}	}		/**	 * 删除发件箱 - 短消息 	 * @param	intval	$sid	短消息ID,递归删除( 修改状态为del_type =1 )	 */	public function del_type() {		if((!isset($_POST['messageid']) || empty($_POST['messageid']))) {			showmessage(L('illegal_parameters'), HTTP_REFERER);		} else {				if(is_array($_POST['messageid'])){					foreach($_POST['messageid'] as $messageid_arr) {						$messageid_arr = intval($messageid_arr); 						$this->message_db->update(array('del_type'=>'1'),array('messageid'=>$messageid_arr,'send_from_id'=>$this->_username));					}					showmessage(L('operation_success'), HTTP_REFERER);				} 		}	}		/**	 * 查看短消息 - 对当前用户是否有权限查看	 */	public function check_user($messageid,$where){		$username = $this->_username;		$messageid = intval($messageid);		if($where=="to"){			$result = $this->message_db->get_one(array("send_to_id"=>$username,"messageid"=>$messageid));		}else{			$result = $this->message_db->get_one(array("send_from_id"=>$username,"messageid"=>$messageid));		} 		if(!$result){//不是当前用户的消息,不能查看			showmessage('请勿非法访问!', HTTP_REFERER);echo '0'; 		} 	}			/**	 * 查看短消息	 */	public function read() { 		if((!isset($_GET['messageid']) || empty($_GET['messageid'])) && (!isset($_POST['messageid']) || empty($_POST['messageid']))) return false;		$messageid = $_GET['messageid'] ? $_GET['messageid'] : $_POST['messageid'];		$messageid = intval($messageid);		//判断是否属于当前用户		$check_user = $this->check_user($messageid,'to'); 		 		//查看过修改状态 为 0 		$this->message_db->update(array('status'=>'0'),array('messageid'=>$messageid));		//查询消息详情		$infos = $this->message_db->get_one(array('messageid'=>$messageid));		if($infos['send_from_id']!='SYSTEM') $infos = new_html_special_chars($infos);		//过滤一下		$info['send_from_id'] = safe_replace($infos['send_from_id']);		$info['send_to_id'] = safe_replace($infos['send_to_id']);		//查询回复消息		$where = array('replyid'=>$infos['messageid']);		$reply_infos = $this->message_db->listinfo($where,$order = 'messageid ASC',$page, $pages = '10');		$show_validator = $show_scroll = $show_header = true;		include template('message', 'read');	}		/**	 * 查看自己发的短消息	 */	public function read_only() { 		$messageid = $_GET['messageid'] ? $_GET['messageid'] : $_POST['messageid'];		$messageid = intval($messageid);		if(!$messageid || empty($messageid)){			showmessage('请勿非法访问!', HTTP_REFERER);		}		//判断是否属于当前用户		$check_user = $this->check_user($messageid,'from'); 				//查询消息详情		$infos = $this->message_db->get_one(array('messageid'=>$messageid));		$infos = new_html_special_chars($infos);		//查询回复消息		$where = array('replyid'=>$infos['messageid']);		$reply_infos = $this->message_db->listinfo($where,$order = 'messageid ASC',$page, $pages = '10');		$show_validator = $show_scroll = $show_header = true;		include template('message', 'read_only');	}		/**	 * 查看系统短消息	 */	public function read_group(){		if((!isset($_GET['group_id']) || empty($_GET['group_id'])) && (!isset($_POST['group_id']) || empty($_POST['group_id']))) return false;		//查询消息详情		$infos = $this->message_group_db->get_one(array('id'=>$_GET['group_id']));		$infos = new_html_special_chars($infos);		if(!is_array($infos))showmessage(L('message_not_exist'),'blank');		//检查查看表是否有记录,无则向message_data 插入浏览记录  		$check = $this->message_data_db->select(array('userid'=>$this->_userid,'group_message_id'=>$_GET['group_id']));		if(!$check){			$this->message_data_db->insert(array('userid'=>$this->_userid,'group_message_id'=>$_GET['group_id']));		} 		include template('message', 'read_group');	}		/**	 * 回复短消息 	 */	public function reply() {		if(isset($_POST['dosubmit'])) {			$messageid = intval($_POST['info']['replyid']);			//判断当前会员,是否可发,短消息.			$this->message_db->messagecheck($this->_userid);			//检查此消息是否有权限回复 			$this->check_user($messageid,'to');			$info = array();			 			$info['send_from_id'] = $this->_username;			$info['message_time'] = SYS_TIME;			$info['status'] = '1';			$info['folder'] = 'inbox';			$info['content'] = safe_replace($_POST['info']['content']);			$info['subject'] = safe_replace($_POST['info']['subject']);			$info['replyid'] = intval($_POST['info']['replyid']);						//回复人ID进行安全处理			$send_to_id = safe_replace($_POST['info']['send_to_id']);			if(empty($send_to_id)) {				showmessage(L('user_noempty'),HTTP_REFERER);			} else {				$info['send_to_id'] = $send_to_id;			}			$messageid = $this->message_db->insert($info,true);			if(!$messageid) return FALSE; 			showmessage(L('operation_success'),HTTP_REFERER);					} else {			$show_validator = $show_scroll = $show_header = true; 			include template('message', 'send');		}	}	 	}	?>	
 |