mirror of
https://github.com/phpseclib/phpseclib.git
synced 2025-01-04 22:55:25 +00:00
Merge branch '3.0'
This commit is contained in:
commit
92b0261c0c
@ -39,7 +39,7 @@ use phpseclib3\Exception\BadConfigurationException;
|
|||||||
* @author Jim Wigginton <terrafrost@php.net>
|
* @author Jim Wigginton <terrafrost@php.net>
|
||||||
* @access public
|
* @access public
|
||||||
*/
|
*/
|
||||||
class BigInteger implements \Serializable
|
class BigInteger
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Main Engine
|
* Main Engine
|
||||||
@ -69,6 +69,24 @@ class BigInteger implements \Serializable
|
|||||||
*/
|
*/
|
||||||
private $value;
|
private $value;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Mode independent value used for serialization.
|
||||||
|
*
|
||||||
|
* @see self::__sleep()
|
||||||
|
* @see self::__wakeup()
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
private $hex;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Precision (used only for serialization)
|
||||||
|
*
|
||||||
|
* @see self::__sleep()
|
||||||
|
* @see self::__wakeup()
|
||||||
|
* @var int
|
||||||
|
*/
|
||||||
|
private $precision;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets engine type.
|
* Sets engine type.
|
||||||
*
|
*
|
||||||
@ -390,39 +408,38 @@ class BigInteger implements \Serializable
|
|||||||
*
|
*
|
||||||
* Will be called, automatically, when serialize() is called on a BigInteger object.
|
* Will be called, automatically, when serialize() is called on a BigInteger object.
|
||||||
*
|
*
|
||||||
* phpseclib 1.0 serialized strings look like this:
|
* __sleep() / __wakeup() have been around since PHP 4.0
|
||||||
* O:15:"Math_BigInteger":1:{s:3:"hex";s:18:"00ab54a98ceb1f0ad2";}
|
|
||||||
*
|
*
|
||||||
* phpseclib 3.0 serialized strings look like this:
|
* \Serializable was introduced in PHP 5.1 and deprecated in PHP 8.1:
|
||||||
* C:25:"phpseclib\Math\BigInteger":42:{a:1:{s:3:"hex";s:18:"00ab54a98ceb1f0ad2";}}
|
* https://wiki.php.net/rfc/phase_out_serializable
|
||||||
|
*
|
||||||
|
* __serialize() / __unserialize() were introduced in PHP 7.4:
|
||||||
|
* https://wiki.php.net/rfc/custom_object_serialization
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public function serialize()
|
public function __sleep()
|
||||||
{
|
{
|
||||||
$val = ['hex' => $this->toHex(true)];
|
$this->hex = $this->toHex(true);
|
||||||
$precision = $this->value->getPrecision();
|
$vars = ['hex'];
|
||||||
if ($precision > 0) {
|
if ($this->getPrecision() > 0) {
|
||||||
$val['precision'] = $precision;
|
$vars[] = 'precision';
|
||||||
}
|
}
|
||||||
return serialize($val);
|
return $vars;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Serialize
|
* Serialize
|
||||||
*
|
*
|
||||||
* Will be called, automatically, when unserialize() is called on a BigInteger object.
|
* Will be called, automatically, when unserialize() is called on a BigInteger object.
|
||||||
*
|
|
||||||
* @param string $serialized
|
|
||||||
*/
|
*/
|
||||||
public function unserialize($serialized)
|
public function __wakeup()
|
||||||
{
|
{
|
||||||
$r = unserialize($serialized);
|
$temp = new static($this->hex, -16);
|
||||||
$temp = new static($r['hex'], -16);
|
|
||||||
$this->value = $temp->value;
|
$this->value = $temp->value;
|
||||||
if (isset($r['precision'])) {
|
if ($this->precision > 0) {
|
||||||
// recalculate $this->bitmask
|
// recalculate $this->bitmask
|
||||||
$this->setPrecision($r['precision']);
|
$this->setPrecision($this->precision);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -28,7 +28,7 @@ use phpseclib3\Common\Functions\Strings;
|
|||||||
* @author Jim Wigginton <terrafrost@php.net>
|
* @author Jim Wigginton <terrafrost@php.net>
|
||||||
* @access public
|
* @access public
|
||||||
*/
|
*/
|
||||||
abstract class Engine implements \Serializable
|
abstract class Engine
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Holds the BigInteger's value
|
* Holds the BigInteger's value
|
||||||
@ -65,6 +65,15 @@ abstract class Engine implements \Serializable
|
|||||||
*/
|
*/
|
||||||
protected $reduce;
|
protected $reduce;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Mode independent value used for serialization.
|
||||||
|
*
|
||||||
|
* @see self::__sleep()
|
||||||
|
* @see self::__wakeup()
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $hex;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Default constructor
|
* Default constructor
|
||||||
*
|
*
|
||||||
@ -295,31 +304,29 @@ abstract class Engine implements \Serializable
|
|||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public function serialize()
|
public function __sleep()
|
||||||
{
|
{
|
||||||
$val = ['hex' => $this->toHex(true)];
|
$this->hex = $this->toHex(true);
|
||||||
|
$vars = ['hex'];
|
||||||
if ($this->precision > 0) {
|
if ($this->precision > 0) {
|
||||||
$val['precision'] = $this->precision;
|
$vars[] = 'precision';
|
||||||
}
|
}
|
||||||
return serialize($val);
|
return $vars;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Serialize
|
* Serialize
|
||||||
*
|
*
|
||||||
* Will be called, automatically, when unserialize() is called on a BigInteger object.
|
* Will be called, automatically, when unserialize() is called on a BigInteger object.
|
||||||
*
|
|
||||||
* @param string $serialized
|
|
||||||
*/
|
*/
|
||||||
public function unserialize($serialized)
|
public function __wakeup()
|
||||||
{
|
{
|
||||||
$r = unserialize($serialized);
|
$temp = new static($this->hex, -16);
|
||||||
$temp = new static($r['hex'], -16);
|
|
||||||
$this->value = $temp->value;
|
$this->value = $temp->value;
|
||||||
$this->is_negative = $temp->is_negative;
|
$this->is_negative = $temp->is_negative;
|
||||||
if (isset($r['precision'])) {
|
if ($this->precision > 0) {
|
||||||
// recalculate $this->bitmask
|
// recalculate $this->bitmask
|
||||||
$this->setPrecision($r['precision']);
|
$this->setPrecision($this->precision);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user