interface面向?qū)ο缶幊痰囊粋€(gè)重要思想接口是一個(gè)類(lèi)的抽象 在接口中只定義方法卻不是先方法interface Ibook {function ready();function weite();} 累如果要實(shí)現(xiàn)接口就必須 寫(xiě)出接口中所有的方法class myBook implements Ibook{function ready(){echo "ready()";}function write(){echo "write()";}}接口在代碼中起規(guī)范代碼作用但是php中對(duì)接口的支持沒(méi)有java C#等完全面向?qū)ο笳Z(yǔ)言的強(qiáng)大
成都創(chuàng)新互聯(lián)專(zhuān)注于企業(yè)全網(wǎng)營(yíng)銷(xiāo)推廣、網(wǎng)站重做改版、上林網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5響應(yīng)式網(wǎng)站、商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)公司、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為上林等各大城市提供網(wǎng)站開(kāi)發(fā)制作服務(wù)。
PHP與大多數(shù)面向?qū)ο缶幊陶Z(yǔ)言一樣,不支持多重繼承.也就是說(shuō)每個(gè)類(lèi)只能繼承一個(gè)父類(lèi).為了解決這個(gè)問(wèn)題,PHP引入了接口,接口的思想是指定了一個(gè)實(shí)現(xiàn)了該接口的類(lèi)必須實(shí)現(xiàn)的一系列方法.接口是一種特殊的抽象類(lèi),抽象類(lèi)又是一種特殊的類(lèi),所以接口也是一種特殊的類(lèi),為什么說(shuō)接口是一種特殊的抽象類(lèi)呢?如果一個(gè)抽象類(lèi)里面的所有的方法都是抽象方法,那么我們就換一種聲明方法使用“接口“;也就是說(shuō)接口里面所有的方法必須都是聲明為抽象方法,另外接口里面不能聲明變量(但可聲明常量constant),而且接口里面所有的成員都是public權(quán)限的。所以子類(lèi)在實(shí)現(xiàn)的時(shí)候也一定要使用public權(quán)限實(shí)限。
聲明一個(gè)類(lèi)的時(shí)候我們使用的關(guān)鍵字是”class”,而接口一種特殊的類(lèi),使用的關(guān)鍵字是“interface”;
類(lèi)的定義: class 類(lèi)名{ … } ,接口的聲明:interface 接口名{ …}
代碼
代碼
?php
//定義一個(gè)接口使用interface關(guān)鍵字,“One”為接口名稱
interface One
{
//定義一個(gè)常量
const constant = 'constant value';
//定義了一個(gè)抽象方法”fun1”
public function fun1();
//定義了抽象方法”fun2”
public function fun2();
}
?
上例中定義了一個(gè)接口”one”,里面聲明了兩個(gè)抽象方法“fun1”和”fun2”,因?yàn)榻涌诶锩嫠械姆椒ǘ际浅橄蠓椒?,所以在聲明抽象方法的時(shí)候就不用像抽象類(lèi)那樣使用”abstract”這個(gè)關(guān)鍵字了,默認(rèn)的已經(jīng)加上這個(gè)關(guān)鍵字,另外在接口里邊的”public”這個(gè)訪問(wèn)權(quán)限也可以去掉,因?yàn)槟J(rèn)就是public的,因?yàn)榻涌诶锼谐蓡T都要是公有的,所在對(duì)于接口里面的成員我們就不能使用“private”的和”protected”的權(quán)限了,都要用public或是默認(rèn)的。另外在接口里面我們也聲明了一個(gè)常量“constant“, 因?yàn)樵诮涌诶锩娌荒苡米兞砍蓡T,所以我們要使用const這個(gè)關(guān)鍵字聲明。
因?yàn)榻涌谑且环N特殊的抽象類(lèi),里面所有的方法都是抽象方法,所以接口也不能產(chǎn)生實(shí)例對(duì)象; 它也做為一種規(guī)范,所有抽象方法需要子類(lèi)去實(shí)現(xiàn)。
我們可以使用”extends”關(guān)鍵字讓一個(gè)接口去繼承另一個(gè)接口:
?php
//使用”extends”繼承另外一個(gè)接口
interface Two extends One
{
function fun3();
function fun4();
}
?
而我們定義一接口的子類(lèi)去實(shí)現(xiàn)接口中全部抽象方法使用的關(guān)鍵字是”implements”,而不是我們前面所說(shuō)的”extends”;
代碼
?php
//使用“implements”這個(gè)關(guān)鍵字去實(shí)現(xiàn)接口中的抽象方法 接口和類(lèi)之間
class Three implements One
{
function fun1()
{
…
}
function fun2()
{
…
}
}
//實(shí)現(xiàn)了全部方法,我們?nèi)タ梢允褂米宇?lèi)去實(shí)例化對(duì)象了
$three=new Three();
?
我們也可以使用抽象類(lèi),去實(shí)現(xiàn)接口中的部分抽象方法,但要想實(shí)例化對(duì)象,這個(gè)抽象類(lèi)還要有子類(lèi)把它所有的抽象方法都實(shí)現(xiàn)才行;
在前面我們說(shuō)過(guò),PHP是單繼承的,一個(gè)類(lèi)只能有一父類(lèi),但是一個(gè)類(lèi)可以實(shí)現(xiàn)多個(gè)接口,就相當(dāng)于一個(gè)類(lèi)要遵守多個(gè)規(guī)范,就像我們不僅要遵守國(guó)家的法律,如果是在學(xué)校的話,還要遵守學(xué)校的校規(guī)一樣;
?php
//使用implements實(shí)現(xiàn)多個(gè)接口
class Four implemtns 接口一, 接口二, ….
{
//必須把所有接口中的方法都要實(shí)現(xiàn)才可以實(shí)例化對(duì)象。
}
?
PHP中不僅一個(gè)類(lèi)可以實(shí)現(xiàn)多個(gè)接口,也可以在繼承一個(gè)類(lèi)的同時(shí)實(shí)現(xiàn)多個(gè)接口, 一定要先繼承類(lèi)再去實(shí)現(xiàn)接口;
?php
//使用extends繼承一個(gè)類(lèi),使用implements實(shí)現(xiàn)多個(gè)接口
class Four extends 類(lèi)名一 implemtns 接口一, 接口二, ….
{
//所有接口中的方法都要實(shí)現(xiàn)才可以實(shí)例化對(duì)象
………
}
?
這個(gè)問(wèn)題很深
安全,不敢當(dāng),因?yàn)閣eb安全問(wèn)題很多,不僅僅是PHP編碼而已,有很多安全上的問(wèn)題需要做處理,像服務(wù)器漏洞、端口開(kāi)放都會(huì)導(dǎo)致被黑,這都是很正常的。
只能說(shuō) 比如在我做PHP開(kāi)發(fā)過(guò)程的一些安全保護(hù)和在網(wǎng)絡(luò)安全公司開(kāi)發(fā)時(shí)的工作要求:
1、最基礎(chǔ)的,提供的api接口 要配置https。
2、api返回響應(yīng)的信息,要盡可能使用消息加密返回,如高位數(shù)的 rsa加密內(nèi)容。
3、接收的回調(diào)開(kāi)放接口,盡可能做到使用回調(diào)黑、白名單,如加ip白名單放行,或ip黑名單禁止訪問(wèn)。
4、不要相信用戶輸入、輸入信息要進(jìn)行編碼轉(zhuǎn)換、轉(zhuǎn)義、過(guò)濾、使用框架和插件進(jìn)行處理,如MySQL查詢的要進(jìn)行參數(shù)綁定、如顯示問(wèn)題要避免xss攻擊會(huì)進(jìn)行過(guò)濾。
5、授權(quán)操作,錯(cuò)誤限制設(shè)置閥值、超過(guò)閥值限制訪問(wèn)、如最基礎(chǔ)的登錄功能。
6、常見(jiàn)額弱口令問(wèn)題導(dǎo)致漏銅,應(yīng)設(shè)置高強(qiáng)度口令,避免程序爆破。
7、文件上傳問(wèn)題、應(yīng)嚴(yán)格校驗(yàn)文件類(lèi)型、后綴、格式、及文件目錄權(quán)限設(shè)置,從而避免文件上傳漏洞導(dǎo)致惡意代碼或webshell攻擊。
8、開(kāi)發(fā)環(huán)境和生產(chǎn)環(huán)境隔開(kāi),不要再生產(chǎn)上面開(kāi)debug、及時(shí)更新使用框架漏洞補(bǔ)丁如PHP國(guó)內(nèi)常用 tp系列以前偶爾爆出漏洞(我用的較多就是tp5 ....),還有框架不要用最新要選擇最穩(wěn)定的。
最后注意不管是驗(yàn)證還是過(guò)濾,在客戶端執(zhí)行過(guò)一次也好,在服務(wù)端,都要再次執(zhí)行驗(yàn)證和校驗(yàn)。
和盛之文 ?我的文章保存網(wǎng)站,歡迎訪問(wèn)學(xué)習(xí)或參考