zoukankan      html  css  js  c++  java
  • action中json的应用

          这篇文章重点介绍action中json数据的返回处理;如果需要看前端代码的一些特效或ajax的json接收,请看上一篇博客:http://blog.csdn.net/yangkai_hudong/article/details/24422817

    1.需要依赖的方法

     /**

        * 获取PrintWriter

        *

        * @throws IOException

        */

        public static PrintWritergetPrintWriter(HttpServletResponse response) throws IOException {

           response.setContentType("text/plain;charset=utf-8");

           response.setCharacterEncoding("UTF-8");

           response.setHeader("Pragma", "no-cache");

           response.setHeader("Cache-Control", "no-cache");

           response.setDateHeader("Expires", 0);

           PrintWriter out = response.getWriter();

           return out;

        }

     

        /**

        * 输出json操作

        *

        * @param out

        *            PrintWriter

        * @param result

        */

        public voidresponseStr(PrintWriter out, String result) {

           out.println(result);

           out.flush();

           out.close();

        }

     

        public String createJsonObject(Stringflag, String msg) {

           JSONObject obj = new JSONObject();

           try {

               obj.put("flag", flag);

               obj.put("msg", msg);

           } catch (JSONException e) {

               logger.error("生成JSON格式出错" + e);

               obj.put("flag", "0");

               obj.put("msg", "由于网络问题,数据处理失败");

           } finally {

                return obj.toString();

           }

    }

    2.action中的使用案例

        public ActionForwardadd(ActionMapping mapping, ActionForm form, HttpServletRequest request,HttpServletResponse response) throws IOException,AppException {

           PrintWriter out = getPrintWriter(response);

           String docTitle = Tool.getDefaultValue(request, "docTitle", "");

           String uid = Tool.getDefaultValue(request, "uid", "");

           try {

               Long flag1 = WeiboWidgetDao.add(docTitle, uid);

               Long flag2 = WeiboWidgetDao.addRel(docTitle, uid);

               if (flag1 != null && flag2 != null) {

                    responseStr(out, createJsonObject("1", "添加成功!"));

                    WeiboWidgetDao.updateCache("doc", docTitle); // 更新词条缓存

               } else {

                    responseStr(out, createJsonObject("0", "添加词条微博失败!"));

               }

           } catch (Exception e) {

               logger.debug("添加词条微博失败:" + e);

               responseStr(out,createJsonObject("0", "添加词条微博失败,发生异常!"));

           }

           return null;

        }

    3.js中的使用案例

    保存

    function save() {

           // 保存前验证

           var docTitle = $("#win_docTitle").val();

           var uid = $("#win_uid").val();

           if (docTitle != "" && uid != "") {

                  $.ajax({

                         dataType: 'json',

                         type: 'POST',

                         url: '/weiboWidget.do',

                         data: {

                                'action' : $("#win_action").val(),

                                'id' : $("#win_id").val(),

                                'docTitle' : $("#win_docTitle").val(),

                                'uid' : $("#win_uid").val(),

                         },

                         success : function(data) {

                                if (data.flag == 1) {

                                       alert(data.msg);

                                       window.location.href= "/weiboWidget.do?action=show";

                                }else {

                                       alert(data.msg);

                                }

                                return false;

                         },

                         error: function() {

                                alert("由于网络问题,保存数据失败!");

                                return false;

                         }

                  });

           }else {

                  alert("词条名和微博UID不能为空!");

                  return false;

           }

    }

    删除

    /**

     * 批量删除操作

     *

     */

    function deleteData() {

           var idList =document.getElementsByName("id_list");

           var ids = "";

           var docTitles = "";

           // 检查是否选择内容

           for (i = 0; i < idList.length;i++) {

                  if(idList[i].checked) {

                         var temp =idList[i].value.split(";");

                         ids+= temp[0] + ",";

                         docTitles+= temp[1] + ",";

                  }

           }

           if (ids == "") {

                  alert("请选择纪录!");

           }else {

                  $.post("/weiboWidget.do?action=delete&" + new Date(), {

                         'ids' : ids,

                         'docTitles' : docTitles

                  },function(data) {

                         window.location.href= "/weiboWidget.do?action=show";

                         return false;

                  });

           }

    }


    转载请指明:http://blog.csdn.net/yangkai_hudong

  • 相关阅读:
    《计算机图形学》学习笔记 0
    最全面的百度地图JavaScript离线版开发
    android 中文api
    SQL Compare数据库比较工具 完全破解+使用教程
    Android系统自带样式(android:theme)
    android studio 导入第三方库的记录
    web在线打印,打印阅览,打印维护,打印设计
    Oracle如何实现跨库查询
    WPF自适应窗体实现小结
    【转】WCF OpenTimeout, CloseTimeout, SendTimeout, ReceiveTimeout
  • 原文地址:https://www.cnblogs.com/yangkai-cn/p/4016600.html
Copyright © 2011-2022 走看看