您好,登錄后才能下訂單哦!
小編給大家分享一下javascript如何實現防篡改對象,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
具體如下:
JavaScript中對象內置有多個屬性Configurable,Writable,Enumerable,Value,Get和Set,來控制屬性的行為。同樣的ES5也有幾個方法,來指定對象的行為。我們知道,javascript中的對象是可以共享的,也是默認可拓展的:
//一旦將對象設置防篡改,就不能撤銷了 //眾所周知,一般的對象是可以隨意拓展的 var person = {name:'liufang'}; person.age = 22; document.write(person.age+"<br>");//22
我們可以添加、刪除或者修改其他的屬性或者方法。但是這也會導致一些問題,比如多人開發時,某些屬性被人為修改,造成工程上的麻煩。這就促使了防篡改對象的誕生。防篡改對象有三個級別,分別是不可拓展對象、密封對象和凍結對象。
不可拓展對象
先來說說不可拓展對象吧,可以通過就普通對象設置為不可拓展對象,來使新添加的屬性無效:
//防拓展對象 Object.preventExtensions(person);//設置為防拓展對象 person.smallName = 'ff'; document.write(person.smallName+"<br>");//undefined //說明不能添加新屬性 //檢測是否為可拓展對象 document.write(Object.isExtensible(person)+"<br>");//false //雖然防拓展對象不能添加屬性,但是可以刪除屬性 delete person.age; document.write(person.age+"<br>");//undefined ,已經刪除成功
可以看到,雖然不可拓展對象可以防止新添加屬性,卻不能阻止他人刪除屬性,當然也不能阻止修改了。所以引出了第二個等級的密封對象。
密封對象
密封對象就是在不可拓展對象的基礎上添加一條規則,也就是不能刪除屬性。
//密封對象 //在不可拓展的基礎上也不能刪除 var people = {name:'liufang'}; Object.seal(people);//將對象密封 delete people.name; document.write(people.name+"<br>");//liufang ,說明不能刪除 people.name = "tyq";//雖然不能刪除,但是可以修改 document.write(people.name+"<br>");//tyq ,說明修改成功 //檢測 document.write(Object.isSealed(people)+"<br>");//true
可以看出,密封對象雖然防止了刪除,但是還是無法阻止修改,所以就有了最高級別的限制,也就是凍結對象。
凍結對象
被凍結的對象既不能拓展,也不能刪除和修改。
//凍結對象 //不能拓展,不能刪除,不能修改 var man = {name:'tyq'}; Object.freeze(man); //檢測 document.write(Object.isFrozen(man));//true
最后要注意的就是,一旦對象被設置放篡改對象,則不能撤銷,所以需要慎重考慮。
以上是“javascript如何實現防篡改對象”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。