php语法简单,应用也非常好,而且类库强大,确实能写出很强大的服务器端。对于我这种只需要小功能服务器的人来说,再好不过了。
单纯的说学习php,我觉得还是看手册的好。花了几天时间看了看语法,因为有编程基础,所以现在看起来就比较快了。刚用php写完一个简单的服务器,当然是有目的,准备用来支持一个订票系统的客户端。下面是我学习过程的笔记。以后也好有个回顾。
当不存在某个类的对象时,可以通过作用域分辨符(::)来调用某个类中的方法;
访问基类中的方法时可以写成 parent::method();
serialize() 返回一个字符串,包含着可以储存于 PHP 的任何值的字节流表示。
unserialize() 可以用此字符串来重建原始的变量值。
用序列化来保存对象可以保存对象中的所有变量。对象中的函数不会被保存,只有类的名称。
序列化与反序列化同一个对象时,可以采用包含同一对象的定义文件方法来实现。
这是因为“new”默认并不返回引用,而返回一个拷贝。
php5
类与对象的特点:
visibility:可见性
属性的访问限度:public:任何地方都可以访问到此属性,
protect派生类或者父类可以访问到这个属性,或者任何定义了这个属性的类内的某个项)
private:只有类内部才能访问
A member declared as static can not be accessed with
an instantiated class object (though a static method can).
Static members and methods cannot be re-defined in subclasses.
(如果一个成员被定义为静态的,那么该成员不能被实例化对象访问,
静态成员不能在子类中被重新定义)。
静态定义必须在访问属性之后,如:protect static
静态方法可以不实例化调用,所以使用静态方法时不能带有$this参数。
静态成员不能用->来访问。
constant:常量关键字, const 用于定义 不可改变的常量,定义时不需要使用$符号。
定义方法一般为:const aconstant = 'constant';
php中gloabl定义的变量是在整个页面中使用的,包括require包含的页面和include包含的页面。
抽象类:
抽象类不能实例化,任何带有抽象方法的类必须定义为抽象类。
继承抽象类的话,任何在抽象类中的抽象方法都必须重写实现。这些方法的访问限度只能
和抽象父类的方法的访问限度相同或更低。
抽象类和抽象方法都使用 abstract作为关键字。
对象接口(object interface)
对象接口允许你规定哪些方法必须实现,而不是让你定义哪些方法怎么被捕捉。
对象接口使用 interface 关键字来定义。它是一个标准的类,但是它的任何方法都没有被实现。
任何在接口对象中的方法都必须是公有的,这是接口对象必须遵循的。
实现一个接口必须使用implements标示,所以接口方法实现必须在一个类里面。一个类可以实现多个接口。
重载:
迭代器:
迭代器可以访问类里面所有的公有对象成员。
实现PHP5里面的迭代器接口,这样可以允许你定义,对象怎么被迭代访问。
设计模式:
设计模式提供了一个良好的框架来实现一些功能组织。
工厂模式:在运行过程中实例化一个要求的对象。
单利模式:最明显的一个例子就是:数据库连接对象。下面是一个最好的单例模式范例:
Singleton Function
class Example
{
// Hold an instance of the class
private static $instance;
// A private constructor; prevents direct creation of object
private function __construct()
{
echo 'I am constructed';
}
// The singleton method
public static function singleton()
{
if (!isset(self::$instance)) {
$c = __CLASS__;
self::$instance = new $c;
}
return self::$instance;
}
// Example method
public function bark()
{
echo 'Woof!';
}
// Prevent users to clone the instance
public function __clone()
{
trigger_error('Clone is not allowed.', E_USER_ERROR);
}
}
你还可以实现php5里面的iteratoraggregate接口对象来定义自己的迭代方法。
魔术函数:
The function names __construct, __destruct (see Constructors and Destructors),
__call, __get, __set, __isset, __unset (see Overloading), __sleep, __wakeup,
__toString, __clone and __autoload are magical in PHP classes.
这些函数在存在于每一个php类中。你不要随意使用__来定义函数,除非你真的想这个函数具有魔术功能。
__tostring()函数,这个函数将决定一个对象转换为字符的时候将发生的事。
final关键字:
final关键字用来阻止应用final关键字声明的类或者方法被继承,被覆盖。
参数类型强制:
可以在参数前面加上类名类控制传入的参数类型。
require() 和 include() 除了怎样处理失败之外在各方面都完全一样。
include() 产生一个警告而 require() 则导致一个致命错误。
换句话说,如果想在丢失文件时停止处理页面,那就别犹豫了,用 require() 吧。
require_once() 语句在脚本执行期间包含并运行指定文件。
此行为和 require() 语句类似,
唯一区别是如果该文件中的代码已经被包含了,
则不会再次包含。有关此语句怎样工作参见 require() 的文档。
PHP 有一个类型运算符:instanceof。instanceof 用来测定一个给定的对象是否来自指定的对象类。
代码范例:
class A { }
class B { }
$thing = new A;
if ($thing instanceof A) {
echo 'A';
}
if ($thing instanceof B) {
echo 'B';
}
?>
的 PHP 代码段结束标记可以不要,有些情况下当使用输出缓冲和
include() 或者 require() 时省略掉会更好些。
include() 就不是这样,脚本会继续运行。同时也要确认设置了合适的include_path。
__CLASS__ :指的是当前类。
异常处理,根据需要扩展异常处理类exception
require()语句包含并运行指定文件;

要保护应用免受与会话相关的XSS攻击,需采取以下措施:1.设置HttpOnly和Secure标志保护会话cookie。2.对所有用户输入进行输出编码。3.实施内容安全策略(CSP)限制脚本来源。通过这些策略,可以有效防护会话相关的XSS攻击,确保用户数据安全。

优化PHP会话性能的方法包括:1.延迟会话启动,2.使用数据库存储会话,3.压缩会话数据,4.管理会话生命周期,5.实现会话共享。这些策略能显着提升应用在高并发环境下的效率。

thesession.gc_maxlifetimesettinginphpdeterminesthelifespanofsessiondata,setInSeconds.1)它'sconfiguredinphp.iniorviaini_set().2)abalanceIsiseededeedeedeedeedeedeedto to to avoidperformance andununununununexpectedLogOgouts.3)

在PHP中,可以使用session_name()函数配置会话名称。具体步骤如下:1.使用session_name()函数设置会话名称,例如session_name("my_session")。2.在设置会话名称后,调用session_start()启动会话。配置会话名称可以避免多应用间的会话数据冲突,并增强安全性,但需注意会话名称的唯一性、安全性、长度和设置时机。

会话ID应在登录时、敏感操作前和每30分钟定期重新生成。1.登录时重新生成会话ID可防会话固定攻击。2.敏感操作前重新生成提高安全性。3.定期重新生成降低长期利用风险,但需权衡用户体验。

在PHP中设置会话cookie参数可以通过session_set_cookie_params()函数实现。1)使用该函数设置参数,如过期时间、路径、域名、安全标志等;2)调用session_start()使参数生效;3)根据需求动态调整参数,如用户登录状态;4)注意设置secure和httponly标志以提升安全性。

在PHP中使用会话的主要目的是维护用户在不同页面之间的状态。1)会话通过session_start()函数启动,创建唯一会话ID并存储在用户cookie中。2)会话数据保存在服务器上,允许在不同请求间传递数据,如登录状态和购物车内容。

如何在子域名间共享会话?通过设置通用域名的会话cookie实现。1.在服务器端设置会话cookie的域为.example.com。2.选择合适的会话存储方式,如内存、数据库或分布式缓存。3.通过cookie传递会话ID,服务器根据ID检索和更新会话数据。


热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

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

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

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

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

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),