zoukankan      html  css  js  c++  java
  • 。net MVC 序列化 反序列化

           序列化 (Serialization)将对象的状态信息转换为可以存储或传输的形式的过程。在序列化期间,对象将其当前状态写入到临时或持久性存储区。以后,可以通过从存储区中读取或反序列化对象的状态,重新创建该对象。
          序列化使其他代码可以查看或修改那些不序列化便无法访问的对象实例数据。确切地说,代码执行序列化需要特殊的权限:即指定了 SerializationFormatter 标志的 SecurityPermission。在默认策略下,通过 Internet 下载的代码或 Intranet 代码不会授予该权限;只有本地计算机上的代码才被授予该权限。
         通常,对象实例的所有字段都会被序列化,这意味着数据会被表示为实例的序列化数据。这样,能够解释该格式的代码有可能能够确定这些数据的值,而不依赖于该成员的可访问性。类似地,反序列化从序列化的表示形式中提取数据,并直接设置对象状态,这也与可访问性规则无关。
    对于任何可能包含重要的安全性数据的对象,如果可能,应该使该对象不可序列化。如果它必须为可序列化的,请尝试生成特定字段来保存不可序列化的重要数据。如果无法实现这一点,则应注意该数据会被公开给任何拥有序列化权限的代码,并确保不让任何恶意代码获得该权限。
     
    目的:
    1、以某种存储形式使自定义对象持久化
    2、将对象从一个地方传递到另一个地方。
    3、使程序更具维护性。
     
    页面序列化、反序列方法
    如:
    <script language="javascript">    
          var t = JSON.parse('{"name":123}');    //反序列化
          alert(t.name);   
            
          var student = new Object();     
            student.name = "Lanny";     
            student.age = "25";     
            student.location = "China";  
            var ar = new Array();  
            for(var i = 0 ;i<8;i++){  
              var elelem = new Object();  
              elelem.name = 'aa'+i;  
              elelem.age = 'bb'+i;  
              ar.push(elelem);  
            }   
             student.par = ar;   
            var json = JSON.stringify(student); //序列化    
            alert(student);     
            alert(json);  
      </script>  


    控制器:

    JsonConvert.DeserializeObject<WebImage[]>(_ImgJson);  //反序列化

    JsonConvert.SerializeObjectobject); //序列化

     
  • 相关阅读:
    基于ADO的远程Oracle连接
    oracle中的定时任务
    关于C++ const 变量
    堆排序和选择排序
    插入排序
    多线程的两种启动方式
    多尺度变换去噪的阈值选择
    jstree
    JS中call、apply、bind使用指南,带部分原理。
    六. JavaScript时间日期格式化
  • 原文地址:https://www.cnblogs.com/lizhenlin/p/5641911.html
Copyright © 2011-2022 走看看