JavaScript 防篡改對(duì)象的用法示例
javascript防篡改對(duì)象
這個(gè)東西吧,用到的很少,個(gè)人感覺(jué)用處不大,但是,可以作為裝逼的利器,哈哈,開(kāi)搞。。
1、不可擴(kuò)展對(duì)象
默認(rèn)情況下對(duì)象都是可以擴(kuò)展的,也就是說(shuō),任何時(shí)候都可以向?qū)ο笾刑砑訉傩院头椒ā,F(xiàn)在使用Object.preventExtensions(object)方法可以改變這個(gè)行為,讓你不能再給對(duì)象添加屬性和方法。例如:
var person={name : 'jack'}; Object.preventExtensions(person); person.age=13; console.log(person.age);///undefine
雖然不能給對(duì)象添加新成員,但是已有的成員則絲毫不受影響,你仍然可以修改和刪除自己的已有的成員。另外使用isExtensible()方法還可以確定對(duì)象是否可以擴(kuò)展。例如:
var person={name : 'jack'}; alert(Object.isExtensible(person));//true Object.preventExtensions(person); alert(Object.istExtensible(person));//false
2、密封的對(duì)象
ECMAScript 5 為對(duì)象定義的第二個(gè)保護(hù)級(jí)別是密封對(duì)象。使用Object.seal(object)方法可以將對(duì)象改為密封對(duì)象。密封對(duì)象不可擴(kuò)展,而且已有成員的[[configurable]]特性將被設(shè)置為false。這就意味著不能刪除屬性和方法,因?yàn)椴荒苁褂肙bject.defineProperty()把數(shù)據(jù)修改為訪問(wèn)其屬性,或者相反。但是屬性值是可以修改的。
var person = {name:'tom'}; Object.seal(person); person.age=12; console.log(person.age);//undefine delete person.name; console.log(person.name);//tom person.name="jack"; alert(person.name);//jack
使用Object.isSealed()方法可以確定對(duì)象是否被密封了,因?yàn)楸幻芊獾膶?duì)象也是不可擴(kuò)展的,所以使用Object.istExtensible()檢測(cè)密封對(duì)象也會(huì)返回false(即不可擴(kuò)展)
var person = {name:'tom'}; alert(Object.isExtensible(person));///true,可擴(kuò)展 alert(Object.isSealed(person));////false,未加密 Object.seal(person); alert(Object.isExtensible(person));///false,不可擴(kuò)展 alert(Object.isSealed(person));////true,已經(jīng)加密
3、凍結(jié)的對(duì)象
最嚴(yán)格的的防止篡改級(jí)別的是凍結(jié)對(duì)象,凍結(jié)的對(duì)象既不可擴(kuò)展,又是密封的,而且對(duì)象的數(shù)據(jù)屬性的[[Writable]]特性會(huì)被設(shè)置為false,如果定義set函數(shù),訪問(wèn)器屬性仍然是可寫的,現(xiàn)在使用Object.freeze(object)方法可以將對(duì)象改為凍結(jié)的對(duì)象。
var person={name : 'tony'}; Object.freeze(person); person.age=12; alert(person.age);//undefine delete person.name; alert(person.name);//tony person.name = 'jack'; alert(person.name);//tony
使用Object.isFrozen()方法可以檢測(cè)對(duì)象是否是凍結(jié)對(duì)象,因?yàn)閮鼋Y(jié)對(duì)象既是不可擴(kuò)展對(duì)象,又是密封的對(duì)象,所以用isExtensible()
和Object.istExtensible()檢測(cè)凍結(jié)對(duì)象將分別返回false和true,
var person = {name:'tom'}; alert(Object.isExtensible(person));///true,可擴(kuò)展 alert(Object.isSealed(person));////false,未加密 alert(Object.isFrozen(person));////false,未加密 Object.seal(person); alert(Object.isExtensible(person));///false,不可擴(kuò)展 alert(Object.isSealed(person));////true,已經(jīng)加密 alert(Object.isFrozen(person));////true,已經(jīng)凍結(jié)
以上就是JavaScript 防篡改對(duì)象的用法示例的詳細(xì)內(nèi)容,更多關(guān)于JavaScript 防篡改對(duì)象的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
利用Three.js實(shí)現(xiàn)3D三棱錐立體特效
Three.js是基于原生WebGL封裝運(yùn)行的三維引擎,在所有WebGL引擎中,Three.js是國(guó)內(nèi)文資料最多、使用最廣泛的三維引擎。本文將用Three.js實(shí)現(xiàn)3D三棱錐立體特效,感興趣的可以了解一下2022-06-06javascript實(shí)現(xiàn)切換td中的值
這篇文章主要介紹了javascript實(shí)現(xiàn)切換td中的值的方法,需要的朋友可以參考下2014-12-12css樣式標(biāo)簽和js語(yǔ)法屬性區(qū)別
css樣式標(biāo)簽和js語(yǔ)法屬性區(qū)別。需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-11-11JavaScript計(jì)算出現(xiàn)精度丟失問(wèn)題的解決方法
Javascript作為一門大型編程語(yǔ)言,在日常開(kāi)發(fā)中難免會(huì)涉及到大量的數(shù)學(xué)計(jì)算,然而,浮點(diǎn)數(shù)在計(jì)算過(guò)程中可能出現(xiàn)精度的問(wèn)題,下面我們就來(lái)學(xué)習(xí)一下Javascript中高精度計(jì)算及其相關(guān)知識(shí)吧2023-11-11深入解析ECMAScript?2023?中的新數(shù)組方法
ECMAScript?是一種標(biāo)準(zhǔn)化的腳本語(yǔ)言,它是?JavaScript?的規(guī)范。ECMAScript?2023?是?JavaScript?編程語(yǔ)言的更新,旨在帶來(lái)改進(jìn)并使?JavaScript?程序可預(yù)測(cè)和可維護(hù),這篇文章主要介紹了探索?ECMAScript?2023?中的新數(shù)組方法,需要的朋友可以參考下2023-12-12