c# - 通过隐藏字段传递 JSON 序列化数据

标签 c# javascript asp.net serialization webforms

在 ASP.NET WebForms 中,我想将任意数据从服务器传递到客户端,然后再返回。我正在序列化为 JSON,并且一直在简单地生成在客户端创建对象的 JavaScript。我使用 ajax 将数据发送到服务器没有问题,但在某些情况下我还想在回发时将 Javascript 对象数据发送回服务器。所以我想它需要在一个隐藏的字段中。

关于这个的几个一般性问题。

1) 就最小化复杂性以及优化空间和效率而言,执行此操作的最佳方法是什么?在研究这个过程中,我发现了 Protocol Buffers但似乎没有一个好的 C# 实现。我确实找到了一个,但它已经有几年历史了,而且自称是 buggy ,这让我很害怕。

2) 如果我只传递一个 JSON 字符串,我如何确定它作为隐藏字段的值包含在内是安全的?有什么理由我可能不想这样做吗?我可以进行 Base64 编码,但这似乎增加了很多开销。什么被认为是最好的或首选的方法?

最佳答案

过去,我通常会做以下事情:

  1. 创建了一个我可以轻松序列化为 XML 的 C# 对象(.Net 可以在 native 执行此操作,并且那里也有 JSON 序列化程序)。 (实际上,我认为 .Net 也可以处理 JSON……虽然不确定)
  2. 获取此对象并通过隐藏字段与客户端共享,或通过 AJAX 请求将其延迟加载到客户端。
  3. 客户端然后解析和操作 XML(jQuery 可以做到这一点)并通过 AJAX 或通过 POST 的隐藏字段将其发送回服务器。
  4. 最后,我将来自客户端的 XML(或 JSON)反序列化为一个对象,并从那里使用它。

所以我不确定您试图通过编码获得什么,但我认为将对象从 JSON(或 XML)转换为更小的东西的开销对于任何打包/收缩的好处来说都是太多的开销。 (除非您的超高流量站点比服务器/客户端处理更关心带宽使用情况。)

示例

希望这能让您了解如何完成此任务。如果您还有其他问题,请告诉我。

<html> 
<head> 
</head> 
<body> 
    <input type="button" id="btnObject" value="Show Object" /> 
    <input type="button" id="btnShowHid" value="Show Hidden Input Value" /> 
    <input type="hidden" id="hidInput" value="" /> 
</body> 
</html> 
<script type='text/javascript' src='https://ajax.googleapis.com/ajax/libs/jquery/1.5.0/jquery.min.js'></script>
<script type='text/javascript' src='https://github.com/douglascrockford/JSON-js/raw/master/json2.js'></script> 
<script> 
    //Your JSON Object
    var myJSONObject = {"bindings": [ 
            {"ircEvent": "PRIVMSG", "method": "newURI", "regex": "^http://.*"}, 
            {"ircEvent": "PRIVMSG", "method": "deleteURI", "regex": "^delete.*"}, 
            {"ircEvent": "PRIVMSG", "method": "randomURI", "regex": "^random.*"} 
        ] 
    }; 

    //jQuery Document Ready Event
    $(function(){
         //Get a reference to your hidden field
        var $hidInput = $("#hidInput");

        //Use json2.js library to convert the json object to a string
        //and assign it to the hidden input's value
        //NOTE: ASP.NET hidden input control reduces to a hidden input so you can treat them the same.
        $hidInput.val(JSON.stringify(myJSONObject));

        //Set up click events to view object and hidden value
        $("#btnShowHid").click(function(){
            alert($hidInput.val());
        });

        $("#btnObject").click(function(){
            alert(myJSONObject);
        });

    });
</script> 

关于c# - 通过隐藏字段传递 JSON 序列化数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5173292/

相关文章:

c# - DragDropEffects.Copy 和 DragDropEffects.Move 有什么区别?

c# - Stack Overflow 用户图片生成(Identicons)

c# - C# 中 networkstream.read() 的奇怪行为

javascript - Visual Studio Code 中的命令行/窗口

.net - ASP .Net 服务器控制事件顺序

c# - MVVM逻辑架构

javascript - 是否可以在 jQuery 插件的非函数参数参数中访问 DOM 元素 'this'?

javascript - 使用 D3 将刻度值更改为文本

javascript - Keydown 功能在 aspx 页面上不起作用。!

c# - 在 asp.net 中动态生成 HTML 元素时缺少图像源