<?php
/**
* Basisklasse für die Titelseite
*/
class WebLoginBase erweitert WebBase{
public $type;
öffentliche $groupId;
öffentlich $gespielt;
öffentlich $NEIN;
public $gameFanDian;
function __construct($dsn, $user='', $password=''){
session_start();
if(!$_SESSION[$this-> memberSessionName]){
header('location: /user/logout');
exit('您没有登录');
}
try{
parent::__construct($dsn, $user , $password);
//$this->gameFanDian=$this->getValue("wählen Sie fanDian aus {$this->prename}Mitgliedern aus, wobei uid=?", $GLOBALS['SUPER-ADMIN- UID']);
// 限制同一个用户只能在一个地方登录
if(!$this->getValue("select isOnLine from ssc_member_session where uid={$this->user['uid' ]} und session_key=? order by id desc limit 1", session_id())){
session_unset();
session_destroy();
header('location: /user/logout');
exit( '您已经退出登录,请重新登录');
}
/*$session_key=$this->getValue("select session_key from ssc_member_session where uid={$this->user['uid']} and isOnLine=1 order by id desc limit 1");
if($session_key != session_id()){
header('location: /user/logout');
exit('您已经退出登录,请重新登录');
}*/
}catch(Exception $e){
}
}
öffentliche Funktion freshSession(){
if(!$this->user ) return false;
$sessionId=$this->user['sessionId'];
if($this->user['testFlag']==1){
$sql="select * from {$this->prename}guestmembers where uid=?";
}else{
$sql="select * from {$this->prename}members where uid=?";
}
$ user=$this->getRow($sql, $this->user['uid']);
$user['sessionId']=$sessionId;
$user['_gameFanDian']=$this ->getGameFanDian();
$_SESSION[$this->memberSessionName]=serialize($user);
$this->user=$user;
return true;
}
öffentliche Funktion getGameFanDian(){
if($this->gameFanDian) return $this->gameFanDian;
$this->getSystemSettings();
return $this->gameFanDian=$this-> ;settings['fanDianMax'];
}
öffentliche Funktion getSystemSettings($expire=null){
if($expire===null) $expire=$this->expire;
$file =$this->cacheDir . 'systemSettings';
if($expire && is_file($file) && filemtime($file)+$expire>$this->time){
return $this->settings=unserialize(file_get_contents($file ));
}
$sql="select * from {$this->prename}params";
$this->settings=array();
if($data=$this->getRows ($sql)){
foreach($data as $var){
$this->settings[$var['name']]=$var['value'];
}
}
file_put_contents($file, serialize($this->settings));
return $this->settings;
}
öffentliche Funktion getSystemCache($cacheFile,$getvalue='' ,$expire=null){
if($expire < 30) $expire=$this->expire;
$abbl=$cacheFile=='staticdata/gamedatas.php';
$file=$ abbl?$this->cacheDir.'/partNameList.dump':($this->cacheDir. '/systemplayed'.$getvalue.'_'.md5($cacheFile));
/ / Wenn die zwischengespeicherte Datei vorhanden ist und die Zeit 10 Stunden nicht überschreitet, wird die zwischengespeicherte Ergebnismenge direkt ohne MySQL-Abfrage verwendet
if($expire && is_file($file) && time()-filemtime($file) < $expire) {
//Ergebnisse im Cache verwenden
if($abbl){
$parts=file_get_contents($this->cacheDir.'/partNameList.dump');
$cached= '';
foreach(json_decode($parts,1) as $part){
$cached.=file_get_contents($part).';';
}
echo $cached;
}else {
echo file_get_contents($file);
}
}else{
//Ergebnismenge zwischenspeichern
ob_start();
$this->display($cacheFile);
$ob = ob_get_contents(); $partNameList= array();
foreach($obs as $cached){
$part=explode('=',str_replace('var','',$cached));
$ partNameList[] =$this->cacheDir.'/'.trim($part[0]);
file_put_contents(end($partNameList),$cached);
}
file_put_contents($ this-> ;cacheDir.'/partNameList.dump',json_encode($partNameList));
}else{
file_put_contents($file,$ob);
}
ob_end_flush();
}
}
/* öffentliche Funktion delete_file($str){
$dir=$this->cacheDir;
$list = scandir($dir); // Alle Dateien und Ordner unter dieser Datei abrufen
foreach ($list as $file){//Traverse
$file_location=$dir."/".$file;//Pfad generieren
if(is_dir($file_location) && $file!="." &&$ file !=".."){ //Bestimmen Sie, ob es sich um einen Ordner handelt
//echo "------------------------Anmelden $ file_location- ------------------";
//delete_file($file_location); //Durchlauf fortsetzen
}else if($file!="."&&$file!=".."){
if(substr_count($file,$str)>0){//如果文件名包含该字符串
unlink($dir."/".$file);
}
}
}
}
öffentliche Funktion setcachefile($cacheFile, $getvalue){
$file=$this->cacheDir . '/'.md5($getvalue.$cacheFile);
$actionTime=$this->getGameCachetime($getvalue);
$cachefiletime=strtotime($actionTime);
$file=$file.'_ '.$cachefiletime;
if(is_file($file)) {
echo file_get_contents($file);
}else{
//删除过期缓存
$this->delete_file(md5($getvalue.$cacheFile)) ;
//将结果集缓存
ob_start();
$this->display($cacheFile);
file_put_contents($file,ob_get_contents());
ob_end_flush();
}
}*/
/**&*/
öffentliche Funktion addCoin($log){
if(!isset($log['uid '])) $log['uid']=$this->user['uid'];
if(!isset($log['info'])) $log['info']='' ;
if(!isset($log['coin'])) $log['coin']=0;
if(!isset($log['type'])) $log['type'] =0;
if(!isset($log['fcoin'])) $log['fcoin']=0;
if(!isset($log['extfield0'])) $log['extfield0 ']=0;
if(!isset($log['extfield1'])) $log['extfield1']='';
if(!isset($log['extfield2'])) $log ['extfield2']='';
$sql="call setCoin({$log['coin']}, {$log['fcoin']}, {$log['uid']}, {$log['liqType']}, {$log['type']}, '{$log['info']}', {$log['extfield0']}, '{$log['extfield1' ]}', '{$log['extfield2']}')";
//echo $sql;exit;
$this->insert($sql);
}
öffentliche Funktion guestaddCoin($log){
if(!isset($log['uid'])) $log['uid']=$this->user['uid'];
if(!isset ($log['info'])) $log['info']='';
if(!isset($log['coin'])) $log['coin']=0;
if (!isset($log['type'])) $log['type']=0;
if(!isset($log['fcoin'])) $log['fcoin']=0;
if(!isset($log['extfield0'])) $log['extfield0']=0;
if(!isset($log['extfield1'])) $log['extfield1']=' ';
if(!isset($log['extfield2'])) $log['extfield2']='';
$sql="call GuestsetCoin({$log['coin']}, {$log['fcoin']}, {$log['uid']}, {$log['liqType']}, {$ log['type']}, '{$log['info']}', {$log['extfield0']}, '{$log['extfield1']}', '{$log['extfield2' ]}')";
//echo $sql;exit;
$this->insert($sql);
}
/**
* Verfügbare Rabatte lesen
*/
öffentliche Funktion getFanDian( $uid=null){
if($uid===null){
if(!$uid=$this->user['parentId']){
return $this->params[' basePl'];
}
}
return $this->getValue("select fanDian from {$this->prename}members where parentId=?", intval($uid));
}
}
不登陆直接访问,会不安全。
你是想做所有人进入等不需要登陆,还是做只对你个人进行不登陆。
给你个思路:
1、所有人不登陆,直接去掉用户判断就可以了。
2、对你个人进行不登陆有2种:
一、如果你的ip地址是固定的,可以判断ip地址 是你的地址,直接进入。
二、可以专门做个页面,自己使用的,进入这个页面,自动登陆进入。