单例模式属于创建型模式,它是设计模式中最简单的一种模式,当然它的使用也是无处不在的。
单例模式保证一个类仅有一个实例,并提供一个访问它的全局访问点。
当需要控制一个类的实例数量,且调用者可以从一个公共的众所周知的访问点访问时,我们就可以考虑使用单例模式了。
我们用 UML 来设计单例模式,当然在以后的设计模式的设计部分,我们都将采用 UML 来描述我们的设计,这样就更为形象化了。

从 UML 设计图中我们可以看出,为了让一个类只有一个实例,它必须创建一个静态变量,然后我们用一个公共静态的 Instance() 的方法来创建它,但是为了避免这个类自身的构造函数可以创建对象,我们将构造函数设置成 protected 或者 private,这样外部就只能通过 Instance() 的方法来创建一个静态的 Singleton 类。看来这样我们达到了我们的目的,接下来我们看代码:
public class Singleton { private static Singleton instance; protected Singleton() public static Singleton Instance() { if(instance != null) instance = new Singleton(); return instance; } }
由此看来,实现单例模式我们可以做下列几步:
- 在类中创建一个静态变量,变量类型为当前类;
- 在类中创建一个公共的静态方法,让用户可以通过此方法创建此类的静态对象;
- 最后将构造函数设置为 protected 或者 private。
Program List:最简单的单例类
<?php class Fruit { static private $_color; private function __construct() { } static public function singleton() { return isset(self::$_color) ? self::$_color : self::$_color = new self(); } } ?>
Program List:可扩展的单例类
一个可扩展的单例类看似不可能,但下面的程序很接近这种效果。
<?php class Test extends Fruit { public static function getInstance() { return Fruit::getSingleton(get_class()); } } ?> <?php class Fruit { /*********************** * HOW TO USE * * Inherit(extend) from Singleton and add getter: * * //public getter for singleton instance * public static function getInstance(){ * return Singleton::getSingleton(get_class()); * } * */ private static $instanceMap = array(); //protected getter for singleton instances protected static function getSingleton($className) { if(!isset(self::$instanceMap[$className])) { $object = new $className; //Make sure this object inherit from Singleton if($object instanceof Fruit) { self::$instanceMap[$className] = $object; } else { throw SingletonException("Class '$className' do not inherit from Singleton!"); } } return self::$instanceMap[$className]; } //protected constructor to prevent outside instantiation protected function __construct(){ } //denie cloning of singleton objects public final function __clone(){ trigger_error('It is impossible to clone singleton', E_USER_ERROR); } } ?> <?php class Apple extends Fruit { protected $rndId; protected function __construct(){ $this->rndId = rand(); } public function whatAmI(){ echo 'I am a Apple('.$this->rndId.')<br />'; } public static function getInstance(){ return Fruit::getSingleton(get_class()); } } class GreenApple extends Apple { public function whatAmI(){ echo 'I am a GreenApple('.$this->rndId.')<br />'; } public static function getInstance(){ return Fruit::getSingleton(get_class()); } } $apple1 = Apple::getInstance(); $apple2 = GreenApple::getInstance(); $apple1->whatAmI();// should echo 'I am a A(some number) $apple2->whatAmI();// should echo 'I am a B(some number) $apple1 = Apple::getInstance(); $apple2 = GreenApple::getInstance(); $apple1->whatAmI();// should echo 'I am a A(same number as above) $apple2->whatAmI();// should echo 'I am a B(same number as above) // $a = new A();// this should fail // $b = new B();// this should fail ?>
程序运行结果:
I am a Apple(4462) I am a GreenApple(8207) I am a Apple(4462) I am a GreenApple(8207)
Program List:单例类与其派生类
<?php class Fruit { // Hold an instance of the class private static $instance; // A private constructor; prevents direct creation of object protected function __construct() { echo 'I am constructed'; } // The singleton method public static function singleton($classname = __CLASS__) { if (!isset(self::$instance)) { self::$instance = new $classname; } return self::$instance; } } class Apple extends Fruit { public static function singleton() { return parent::singleton(__CLASS__); // NOTE The singleton method MUST return an instance. } public function showColor() { echo 'My Color is Red.'; } } $subclassInstance = Apple::singleton(); $subclassInstance->showColor(); ?>
程序运行结果:
I am constructed My Color is Red.

tostartaphpsession,usesesses_start()attheScript'Sbeginning.1)placeitbeforeanyOutputtosetThesessionCookie.2)useSessionsforuserDatalikeloginstatusorshoppingcarts.3)regenerateSessiveIdStopreventFentfixationAttacks.s.4)考虑使用AttActAcks.s.s.4)

会话再生是指在用户进行敏感操作时生成新会话ID并使旧ID失效,以防会话固定攻击。实现步骤包括:1.检测敏感操作,2.生成新会话ID,3.销毁旧会话ID,4.更新用户端会话信息。

PHP会话对应用性能有显着影响。优化方法包括:1.使用数据库存储会话数据,提升响应速度;2.减少会话数据使用,只存储必要信息;3.采用非阻塞会话处理器,提高并发能力;4.调整会话过期时间,平衡用户体验和服务器负担;5.使用持久会话,减少数据读写次数。

PHPsessionsareserver-side,whilecookiesareclient-side.1)Sessionsstoredataontheserver,aremoresecure,andhandlelargerdata.2)Cookiesstoredataontheclient,arelesssecure,andlimitedinsize.Usesessionsforsensitivedataandcookiesfornon-sensitive,client-sidedata.

phpientifiesauser'ssessionusessessionSessionCookiesAndSessionIds.1)whiwSession_start()被称为,phpgeneratesainiquesesesessionIdStoredInacookInAcookInamedInAcienamedphpsessidontheuser'sbrowser'sbrowser.2)thisIdAllowSphptptpptpptpptpptortoreTessessionDataAfromtheserverMtheserver。

PHP会话的安全可以通过以下措施实现:1.使用session_regenerate_id()在用户登录或重要操作时重新生成会话ID。2.通过HTTPS协议加密传输会话ID。3.使用session_save_path()指定安全目录存储会话数据,并正确设置权限。

phpsessionFilesArestoredIntheDirectorySpecifiedBysession.save_path,通常是/tmponunix-likesystemsorc:\ windows \ windows \ temponwindows.tocustomizethis:tocustomizEthis:1)useession_save_save_save_path_path()


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

Atom编辑器mac版下载
最流行的的开源编辑器

SublimeText3汉化版
中文版,非常好用