JavaScript 防篡改對象的用法示例
javascript防篡改對象
這個東西吧,用到的很少,個人感覺用處不大,但是,可以作為裝逼的利器,哈哈,開搞。。
1、不可擴展對象
默認情況下對象都是可以擴展的,也就是說,任何時候都可以向對象中添加屬性和方法。現在使用Object.preventExtensions(object)方法可以改變這個行為,讓你不能再給對象添加屬性和方法。例如:
var person={name : 'jack'}; Object.preventExtensions(person); person.age=13; console.log(person.age);///undefine
雖然不能給對象添加新成員,但是已有的成員則絲毫不受影響,你仍然可以修改和刪除自己的已有的成員。另外使用isExtensible()方法還可以確定對象是否可以擴展。例如:
var person={name : 'jack'}; alert(Object.isExtensible(person));//true Object.preventExtensions(person); alert(Object.istExtensible(person));//false
2、密封的對象
ECMAScript 5 為對象定義的第二個保護級別是密封對象。使用Object.seal(object)方法可以將對象改為密封對象。密封對象不可擴展,而且已有成員的[[configurable]]特性將被設置為false。這就意味著不能刪除屬性和方法,因為不能使用Object.defineProperty()把數據修改為訪問其屬性,或者相反。但是屬性值是可以修改的。
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()方法可以確定對象是否被密封瞭,因為被密封的對象也是不可擴展的,所以使用Object.istExtensible()檢測密封對象也會返回false(即不可擴展)
var person = {name:'tom'}; alert(Object.isExtensible(person));///true,可擴展 alert(Object.isSealed(person));////false,未加密 Object.seal(person); alert(Object.isExtensible(person));///false,不可擴展 alert(Object.isSealed(person));////true,已經加密
3、凍結的對象
最嚴格的的防止篡改級別的是凍結對象,凍結的對象既不可擴展,又是密封的,而且對象的數據屬性的[[Writable]]特性會被設置為false,如果定義set函數,訪問器屬性仍然是可寫的,現在使用Object.freeze(object)方法可以將對象改為凍結的對象。
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()方法可以檢測對象是否是凍結對象,因為凍結對象既是不可擴展對象,又是密封的對象,所以用isExtensible()
和Object.istExtensible()檢測凍結對象將分別返回false和true,
var person = {name:'tom'}; alert(Object.isExtensible(person));///true,可擴展 alert(Object.isSealed(person));////false,未加密 alert(Object.isFrozen(person));////false,未加密 Object.seal(person); alert(Object.isExtensible(person));///false,不可擴展 alert(Object.isSealed(person));////true,已經加密 alert(Object.isFrozen(person));////true,已經凍結
以上就是JavaScript 防篡改對象的用法示例的詳細內容,更多關於JavaScript 防篡改對象的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- JavaScript Object.defineProperty與proxy代理模式的使用詳細分析
- 前端JavaScript中的反射和代理
- Javascript Object對象類型使用詳解
- JS Object構造函數之Object.freeze
- 一文搞懂JavaScript中的this綁定規則