mirror of
https://github.com/Lastorder-DC/rhymix.git
synced 2026-01-09 03:32:00 +09:00
merge changes of luminous to maserati (~r12676)
git-svn-id: http://xe-core.googlecode.com/svn/branches/maserati@12680 201d5d3c-b55e-5fd7-737f-ddc643e51545
This commit is contained in:
commit
0f04bd3f92
50 changed files with 784 additions and 265 deletions
|
|
@ -118,6 +118,20 @@ class Context
|
|||
* @var bool true if attached file exists
|
||||
*/
|
||||
var $is_uploaded = false;
|
||||
/**
|
||||
* Pattern for request vars check
|
||||
* @var array
|
||||
*/
|
||||
var $patterns = array(
|
||||
'/<\?/iUsm',
|
||||
'/<\%/iUsm',
|
||||
'/<script\s*?language\s*?=\s*?("|\')?\s*?php\s*("|\')?/iUsm'
|
||||
);
|
||||
/**
|
||||
* Check init
|
||||
* @var bool false if init fail
|
||||
*/
|
||||
var $isSuccessInit = true;
|
||||
|
||||
/**
|
||||
* returns static context object (Singleton). It's to use Context without declaration of an object
|
||||
|
|
@ -798,56 +812,63 @@ class Context
|
|||
|
||||
$obj = clone($source_obj);
|
||||
|
||||
foreach($charset_list as $charset)
|
||||
foreach($charset_list as $charset)
|
||||
{
|
||||
$flag = true;
|
||||
foreach($obj as $key=>$val)
|
||||
{
|
||||
if(!$val) continue;
|
||||
if(!is_array($val) && iconv($charset,$charset,$val)!=$val) $flag = false;
|
||||
else if(is_array($val))
|
||||
{
|
||||
$userdata = array('charset1'=>$charset,'charset2'=>$charset,'useFlag'=>true);
|
||||
Context::arrayConvWalkCallback($val,null,$userdata);
|
||||
if($userdata['returnFlag'] === false) $flag = false;
|
||||
}
|
||||
}
|
||||
array_walk($obj,'Context::checkConvertFlag',$charset);
|
||||
$flag = Context::checkConvertFlag($flag = true);
|
||||
if($flag)
|
||||
{
|
||||
if($charset == 'UTF-8') return $obj;
|
||||
foreach($obj as $key => $val)
|
||||
{
|
||||
if(!is_array($val)) $obj->{$key} = iconv($charset,'UTF-8',$val);
|
||||
else Context::arrayConvWalkCallback($val,null,array($charset,'UTF-8'));
|
||||
}
|
||||
|
||||
array_walk($obj,'Context::doConvertEncoding',$charset);
|
||||
return $obj;
|
||||
}
|
||||
}
|
||||
|
||||
return $obj;
|
||||
}
|
||||
|
||||
/**
|
||||
* Check flag
|
||||
*
|
||||
* @param mixed $val
|
||||
* @param string $key
|
||||
* @param mixed $charset charset
|
||||
* @see arrayConvWalkCallback will replaced array_walk_recursive in >=PHP5
|
||||
* @return void
|
||||
*/
|
||||
function checkConvertFlag(&$val, $key = null, $charset = null)
|
||||
{
|
||||
static $flag = true;
|
||||
if($charset)
|
||||
{
|
||||
if(is_array($val))
|
||||
array_walk($val,'Context::checkConvertFlag',$charset);
|
||||
else if($val && iconv($charset,$charset,$val)!=$val) $flag = false;
|
||||
else $flag = false;
|
||||
}
|
||||
else
|
||||
{
|
||||
$return = $flag;
|
||||
$flag = true;
|
||||
return $return;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Convert array type variables into UTF-8
|
||||
*
|
||||
* @param mixed $val
|
||||
* @param string $key
|
||||
* @param mixed $userdata charset1 charset2 useFlag retrunFlag
|
||||
* @param string $charset character set
|
||||
* @see arrayConvWalkCallback will replaced array_walk_recursive in >=PHP5
|
||||
* @return object converted object
|
||||
*/
|
||||
function arrayConvWalkCallback(&$val, $key = null, &$userdata)
|
||||
function doConvertEncoding(&$val, $key = null, $charset)
|
||||
{
|
||||
if (is_array($val)) array_walk($val,'Context::arrayConvWalkCallback', $userdata);
|
||||
else
|
||||
if (is_array($val))
|
||||
{
|
||||
if(!$userdata['useFlag']) $val = iconv($userdata['charset1'],$userdata['charset2'],$val);
|
||||
else
|
||||
{
|
||||
if(iconv($charset,$charset,$val)!=$val) $userdata['returnFlag'] = (bool)false;
|
||||
}
|
||||
array_walk($val,'Context::doConvertEncoding',$charset);
|
||||
}
|
||||
else $val = iconv($charset,'UTF-8',$val);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -934,15 +955,36 @@ class Context
|
|||
|
||||
if($set_to_vars)
|
||||
{
|
||||
$val = preg_replace('/<\?/i', '', $val);
|
||||
$val = preg_replace('/<\%/i', '', $val);
|
||||
$val = preg_replace('/<script\s+language\s*=\s*("|\')php("|\')\s*>/ism', '', $val);
|
||||
$this->_recursiveCheckVar($val);
|
||||
}
|
||||
|
||||
$this->set($key, $val, $set_to_vars);
|
||||
}
|
||||
}
|
||||
|
||||
function _recursiveCheckVar($val)
|
||||
{
|
||||
if(is_string($val))
|
||||
{
|
||||
foreach($this->patterns as $pattern)
|
||||
{
|
||||
$result = preg_match($pattern, $val);
|
||||
if($result)
|
||||
{
|
||||
$this->isSuccessInit = FALSE;
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
else if(is_array($val))
|
||||
{
|
||||
foreach($val as $val2)
|
||||
{
|
||||
$this->_recursiveCheckVar($val2);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Handle request arguments for JSON
|
||||
*
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue