com.glaf.oa.purchase.web.springmvc.PurchaseController.java Source code

Java tutorial

Introduction

Here is the source code for com.glaf.oa.purchase.web.springmvc.PurchaseController.java

Source

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.glaf.oa.purchase.web.springmvc;

import java.io.IOException;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Date;
import java.util.List;
import java.util.Map;
import java.util.StringTokenizer;

import javax.servlet.http.HttpServletRequest;

import org.apache.commons.lang3.StringUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.servlet.ModelAndView;

import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.glaf.oa.purchase.model.Purchase;
import com.glaf.oa.purchase.query.PurchaseQuery;
import com.glaf.oa.purchase.service.PurchaseService;
import com.glaf.base.modules.BaseDataManager;
import com.glaf.base.modules.others.service.AttachmentService;
import com.glaf.base.modules.sys.model.SysDepartment;
import com.glaf.base.modules.sys.service.SysDepartmentService;
import com.glaf.base.modules.sys.service.SysUserService;
import com.glaf.base.utils.RequestUtil;
import com.glaf.core.config.ViewProperties;
import com.glaf.core.identity.User;
import com.glaf.core.security.LoginContext;
import com.glaf.core.util.JsonUtils;
import com.glaf.core.util.PageResult;
import com.glaf.core.util.ParamUtils;
import com.glaf.core.util.RequestUtils;
import com.glaf.core.util.ResponseUtils;
import com.glaf.core.util.Tools;
import com.glaf.jbpm.container.ProcessContainer;
import com.glaf.jbpm.context.ProcessContext;
import com.glaf.jbpm.datafield.DataField;

@Controller("/oa/purchase")
@RequestMapping("/oa/purchase")
public class PurchaseController {
    protected static final Log logger = LogFactory.getLog(PurchaseController.class);

    protected PurchaseService purchaseService;

    protected SysDepartmentService sysDepartmentService;

    protected SysUserService sysUserService;

    protected AttachmentService attachmentService;

    public PurchaseController() {

    }

    /**
     * ?
     * 
     * @param purchase
     * @param flag
     *            0?? 1???
     * @param request
     * @return
     */
    private boolean completeTask(Purchase purchase, int flag, HttpServletRequest request) {

        String processName = "PurchaseProcess";
        User appUser = BaseDataManager.getInstance().getSysUserService().findByAccount(purchase.getAppuser());

        // ?id ?GZ01
        SysDepartment curdept = sysDepartmentService.findById(appUser.getDeptId());

        // ?CODE(GZ01)??2? 
        String curAreadeptCode = curdept.getCode().substring(0, 2);
        // ?code ? GZ06
        SysDepartment HRdept = sysDepartmentService.findByCode(curAreadeptCode + "06");
        // ?code ? GZ
        SysDepartment curAreadept = sysDepartmentService.findByCode(curAreadeptCode);

        // ?JT
        SysDepartment sysdeptMem = sysDepartmentService.findByCode("JT");

        ProcessContext ctx = new ProcessContext();
        ctx.setRowId(purchase.getPurchaseid());// id
        ctx.setActorId(appUser.getActorId());// 
        ctx.setProcessName(processName);// ???
        String opinion = request.getParameter("approveOpinion");
        ctx.setOpinion(opinion);// ??

        Collection<DataField> dataFields = new ArrayList<DataField>();// ?

        DataField dataField = new DataField();
        dataField.setName("isAgree");// ?
        if (flag == 0) {
            dataField.setValue("true");
        } else {
            dataField.setValue("false");
        }
        dataFields.add(dataField);

        // GZ01??
        DataField datafield1 = new DataField();
        datafield1.setName("deptId01");
        datafield1.setValue(appUser.getDeptId());
        dataFields.add(datafield1);

        // GZ06
        DataField datafield4 = new DataField();
        datafield4.setName("deptId02");
        datafield4.setValue(HRdept.getId());
        dataFields.add(datafield4);

        // GZ
        DataField datafield5 = new DataField();
        datafield5.setName("deptId03");
        datafield5.setValue(curAreadept.getId());
        dataFields.add(datafield5);

        // (JT)
        DataField datafield2 = new DataField();
        datafield2.setName("deptId04");
        datafield2.setValue(sysdeptMem.getId());
        dataFields.add(datafield2);

        DataField datafield3 = new DataField();
        datafield3.setName("rowId");
        datafield3.setValue(purchase.getPurchaseid());
        dataFields.add(datafield3);

        ctx.setDataFields(dataFields);

        Long processInstanceId;
        boolean isOK = false;

        if (purchase.getProcessinstanceid() != null && purchase.getWfstatus() != 9999
                && purchase.getWfstatus() != null) {
            processInstanceId = purchase.getProcessinstanceid();
            ctx.setProcessInstanceId(processInstanceId);
            isOK = ProcessContainer.getContainer().completeTask(ctx);
            logger.info("workflowing .......  ");
        } else {
            processInstanceId = ProcessContainer.getContainer().startProcess(ctx);
            logger.info("processInstanceId=" + processInstanceId);
            isOK = true;
            logger.info("workflow start");
        }
        return isOK;
    }

    @ResponseBody
    @RequestMapping("/delete")
    public ModelAndView delete(HttpServletRequest request, ModelMap modelMap) {
        String purchaseids = request.getParameter("purchaseIds");
        if (StringUtils.isNotEmpty(purchaseids)) {// purchaseids?null
            StringTokenizer token = new StringTokenizer(purchaseids, ",");
            List<Long> ids = new ArrayList<Long>();
            while (token.hasMoreTokens()) {
                String x = token.nextToken();
                if (StringUtils.isNotEmpty(x)) {
                    ids.add(Long.valueOf(x));
                }
            }
            try {
                purchaseService.delete(ids);
            } catch (Exception ex) {
                ex.printStackTrace();
                logger.error(ex.getMessage());
                ModelAndView mav = new ModelAndView();
                mav.addObject("message", "");
                return mav;
            }
        }
        return this.list(request, modelMap);
    }

    @ResponseBody
    @RequestMapping("/detail")
    public byte[] detail(HttpServletRequest request) throws IOException {

        Purchase purchase = purchaseService.getPurchase(RequestUtils.getLong(request, "purchaseid"));

        JSONObject rowJSON = purchase.toJsonObject();
        return rowJSON.toJSONString().getBytes("UTF-8");
    }

    @RequestMapping("/edit")
    public ModelAndView edit(HttpServletRequest request, ModelMap modelMap) {
        User user = RequestUtils.getUser(request);
        String actorId = user.getActorId();
        RequestUtils.setRequestParameterToAttribute(request);
        request.removeAttribute("canSubmit");
        Purchase purchase = purchaseService.getPurchase(RequestUtils.getLong(request, "purchaseId"));
        if (purchase == null) {
            purchase = new Purchase();
            purchase.setStatus(-1);// 
            SysDepartment sysDepartment = BaseDataManager.getInstance().getSysDepartmentService()
                    .findById(user.getDeptId());
            String areaCode = "";
            if (sysDepartment.getCode() != null && sysDepartment.getCode().length() >= 2) {
                areaCode = sysDepartment.getCode().substring(0, 2);
            }
            purchase.setArea(areaCode);// 
            purchase.setDept(sysDepartment.getCode());// 
            purchase.setPost(RequestUtil.getLoginUser(request).getHeadship());// ??
            purchase.setAppuser(actorId);
            purchase.setAppdate(new Date());
            purchase.setCreateBy(actorId);
            purchaseService.save(purchase);
        }
        request.setAttribute("purchase", purchase);
        JSONObject rowJSON = purchase.toJsonObject();
        request.setAttribute("x_json", rowJSON.toJSONString());

        boolean canUpdate = false;
        String x_method = request.getParameter("x_method");
        if (StringUtils.equals(x_method, "submit")) {

        }

        if (StringUtils.containsIgnoreCase(x_method, "update")) {
            if (purchase != null) {
                if (purchase.getStatus() == 0 || purchase.getStatus() == -1) {
                    canUpdate = true;
                }
            }
        }

        request.setAttribute("canUpdate", canUpdate);

        String view = request.getParameter("view");
        if (StringUtils.isNotEmpty(view)) {
            return new ModelAndView(view, modelMap);
        }

        String x_view = ViewProperties.getString("purchase.edit");
        if (StringUtils.isNotEmpty(x_view)) {
            return new ModelAndView(x_view, modelMap);
        }

        return new ModelAndView("/oa/purchase/edit", modelMap);
    }

    @RequestMapping("/json")
    @ResponseBody
    public byte[] json(HttpServletRequest request, ModelMap modelMap) throws IOException {
        LoginContext loginContext = RequestUtils.getLoginContext(request);
        Map<String, Object> params = RequestUtils.getParameterMap(request);
        PurchaseQuery query = new PurchaseQuery();
        Tools.populate(query, params);
        query.setActorId(loginContext.getActorId());// ?
        query.setLoginContext(loginContext);
        /**
         * ?
         */
        query.setPurchasenoLike(ParamUtils.getString(params, "purchaseNoLike"));
        query.setAppdateGreaterThanOrEqual(ParamUtils.getDate(params, "appdateGreaterThanOrEqual"));
        query.setAppdateLessThanOrEqual(ParamUtils.getDate(params, "appdateLessThanOrEqual"));
        if (!loginContext.isSystemAdministrator()) {
            String actorId = loginContext.getActorId();
            query.createBy(actorId);
        }

        String rstatus = request.getParameter("rstatus");
        if (!StringUtils.isEmpty(rstatus) && !"null".equals(rstatus)) {
            query.setStatus(Integer.parseInt(rstatus));
        }
        String status = request.getParameter("status");
        if (!StringUtils.isEmpty(status)) {
            query.setStatus(Integer.parseInt(status));
        }

        String gridType = ParamUtils.getString(params, "gridType");
        if (gridType == null) {
            gridType = "easyui";
        }
        int start = 0;
        int limit = 10;
        String orderName = null;
        String order = null;

        int pageNo = ParamUtils.getInt(params, "page");
        limit = ParamUtils.getInt(params, "rows");
        start = (pageNo - 1) * limit;
        orderName = ParamUtils.getString(params, "sortName");
        order = ParamUtils.getString(params, "sortOrder");

        if (start < 0) {
            start = 0;
        }

        if (limit <= 0) {
            limit = PageResult.DEFAULT_PAGE_SIZE;
        }

        JSONObject result = new JSONObject();
        int total = purchaseService.getPurchaseCountByQueryCriteria(query);
        if (total > 0) {
            result.put("total", total);
            result.put("totalCount", total);
            result.put("totalRecords", total);
            result.put("start", start);
            result.put("startIndex", start);
            result.put("limit", limit);
            result.put("pageSize", limit);

            if (StringUtils.isNotEmpty(orderName)) {
                query.setSortOrder(orderName);
                if (StringUtils.equals(order, "desc")) {
                    query.setSortOrder(" desc ");
                }
            }

            List<Purchase> list = purchaseService.getPurchasesByQueryCriteria(start, limit, query);
            if (list != null && !list.isEmpty()) {
                JSONArray rowsJSON = new JSONArray();

                result.put("rows", rowsJSON);
                for (Purchase purchase : list) {
                    JSONObject rowJSON = purchase.toJsonObject();
                    rowJSON.put("id", purchase.getPurchaseid());
                    rowJSON.put("purchaseId", purchase.getPurchaseid());
                    rowJSON.put("startIndex", ++start);

                    String areaname = BaseDataManager.getInstance().getStringValue(purchase.getArea(), "area");
                    rowJSON.put("areaname", areaname);
                    String companyname = BaseDataManager.getInstance().getStringValue(purchase.getCompany(),
                            purchase.getArea());
                    rowJSON.put("companyname", companyname);
                    String appusername = BaseDataManager.getInstance().getStringValue(purchase.getAppuser(),
                            "SYS_USERS");
                    rowJSON.put("appusername", appusername);
                    String deptname = BaseDataManager.getInstance().getStringValue(purchase.getDept(), "SYS_DEPTS");
                    rowJSON.put("deptname", deptname);

                    rowsJSON.add(rowJSON);
                }

            }
        } else {
            JSONArray rowsJSON = new JSONArray();
            result.put("rows", rowsJSON);
            result.put("total", total);
        }
        return result.toJSONString().getBytes("UTF-8");
    }

    @RequestMapping
    public ModelAndView list(HttpServletRequest request, ModelMap modelMap) {
        RequestUtils.setRequestParameterToAttribute(request);
        String x_query = request.getParameter("x_query");
        if (StringUtils.equals(x_query, "true")) {
            Map<String, Object> paramMap = RequestUtils.getParameterMap(request);
            String x_complex_query = JsonUtils.encode(paramMap);
            x_complex_query = RequestUtils.encodeString(x_complex_query);
            request.setAttribute("x_complex_query", x_complex_query);
        } else {
            request.setAttribute("x_complex_query", "");
        }
        String view = request.getParameter("view");
        if (StringUtils.isNotEmpty(view)) {
            return new ModelAndView(view, modelMap);
        }

        return new ModelAndView("/oa/purchase/list", modelMap);
    }

    @RequestMapping("/query")
    public ModelAndView query(HttpServletRequest request, ModelMap modelMap) {
        RequestUtils.setRequestParameterToAttribute(request);
        String view = request.getParameter("view");
        if (StringUtils.isNotEmpty(view)) {
            return new ModelAndView(view, modelMap);
        }
        String x_view = ViewProperties.getString("purchase.query");
        if (StringUtils.isNotEmpty(x_view)) {
            return new ModelAndView(x_view, modelMap);
        }
        return new ModelAndView("/oa/purchase/query", modelMap);
    }

    @RequestMapping("/save")
    public ModelAndView save(HttpServletRequest request, ModelMap modelMap) {
        User user = RequestUtils.getUser(request);
        String actorId = user.getActorId();
        Map<String, Object> params = RequestUtils.getParameterMap(request);

        Purchase purchase = new Purchase();
        Tools.populate(purchase, params);
        purchase.setPurchaseid(RequestUtils.getLong(request, "purchaseid"));
        purchase.setPurchaseno(request.getParameter("purchaseno"));
        purchase.setArea(request.getParameter("area"));
        purchase.setCompany(request.getParameter("company"));
        purchase.setDept(request.getParameter("dept"));
        purchase.setPost(request.getParameter("post"));
        purchase.setAppuser(request.getParameter("appuser"));
        purchase.setAppdate(RequestUtils.getDate(request, "appdate"));
        purchase.setPurchasesum(RequestUtils.getDouble(request, "purchasesum"));
        purchase.setStatus(0);
        purchase.setCreateBy(request.getParameter("createBy") == null ? actorId : request.getParameter("createBy"));
        purchase.setCreateDate(RequestUtils.getDate(request, "createDate") == null ? new Date()
                : RequestUtils.getDate(request, "createDate"));
        purchase.setUpdateDate(new Date());
        purchase.setUpdateBy(actorId);
        try {
            purchaseService.save(purchase);
        } catch (Exception ex) {
            ex.printStackTrace();
            logger.error(ex.getMessage());
            ModelAndView mav = new ModelAndView();
            mav.addObject("message", "?");
            return mav;
        }
        return this.list(request, modelMap);
    }

    @ResponseBody
    @RequestMapping("/savePurchase")
    public byte[] savePurchase(HttpServletRequest request) {
        User user = RequestUtils.getUser(request);
        String actorId = user.getActorId();
        Map<String, Object> params = RequestUtils.getParameterMap(request);
        Purchase purchase = new Purchase();
        try {
            Tools.populate(purchase, params);
            purchase.setPurchaseno(request.getParameter("purchaseno"));
            purchase.setArea(request.getParameter("area"));
            purchase.setCompany(request.getParameter("company"));
            purchase.setDept(request.getParameter("dept"));
            purchase.setPost(request.getParameter("post"));
            purchase.setAppuser(request.getParameter("appuser"));
            purchase.setAppdate(RequestUtils.getDate(request, "appdate"));
            purchase.setPurchasesum(RequestUtils.getDouble(request, "purchasesum"));
            purchase.setStatus(RequestUtils.getInt(request, "status"));
            purchase.setProcessname(request.getParameter("processname"));
            purchase.setProcessinstanceid(RequestUtils.getLong(request, "processinstanceid"));
            purchase.setWfstatus(RequestUtils.getLong(request, "wfstatus"));
            purchase.setCreateBy(request.getParameter("createBy"));
            purchase.setCreateDate(RequestUtils.getDate(request, "createDate"));
            purchase.setUpdateDate(RequestUtils.getDate(request, "updateDate"));
            purchase.setUpdateBy(request.getParameter("updateBy"));
            purchase.setCreateBy(actorId);
            this.purchaseService.save(purchase);

            return ResponseUtils.responseJsonResult(true);
        } catch (Exception ex) {
            ex.printStackTrace();
            logger.error(ex);
        }
        return ResponseUtils.responseJsonResult(false);
    }

    @javax.annotation.Resource
    public void setAttachmentService(AttachmentService attachmentService) {
        this.attachmentService = attachmentService;
    }

    @javax.annotation.Resource
    public void setPurchaseService(PurchaseService purchaseService) {
        this.purchaseService = purchaseService;
    }

    @javax.annotation.Resource
    public void setSysDepartmentService(SysDepartmentService sysDepartmentService) {
        this.sysDepartmentService = sysDepartmentService;
    }

    @javax.annotation.Resource
    public void setSysUserService(SysUserService sysUserService) {
        this.sysUserService = sysUserService;
    }

    /**
     * ??
     * 
     * @param contract
     * @param request
     * @return
     */
    private boolean startProcess(Purchase purchase, HttpServletRequest request) {
        String processName = "PurchaseProcess";

        // ?
        User appUser = BaseDataManager.getInstance().getSysUserService().findByAccount(purchase.getAppuser());

        // ?id ?GZ01
        SysDepartment curdept = sysDepartmentService.findById(appUser.getDeptId());

        // ?CODE(GZ01)??2? 
        String curAreadeptCode = curdept.getCode().substring(0, 2);
        // ?code ? GZ06
        SysDepartment HRdept = sysDepartmentService.findByCode(curAreadeptCode + "06");
        // ?code ? GZ
        SysDepartment curAreadept = sysDepartmentService.findByCode(curAreadeptCode);

        // ?JT
        SysDepartment sysdeptMem = sysDepartmentService.findByCode("JT");

        ProcessContext ctx = new ProcessContext();
        ctx.setRowId(purchase.getPurchaseid());// id
        ctx.setActorId(appUser.getActorId());// 
        ctx.setProcessName(processName);// ???

        Collection<DataField> dataFields = new ArrayList<DataField>();// ?

        // GZ01
        DataField datafield1 = new DataField();
        datafield1.setName("deptId01");
        datafield1.setValue(appUser.getDeptId());
        dataFields.add(datafield1);

        // GZ06
        DataField datafield4 = new DataField();
        datafield4.setName("deptId02");
        datafield4.setValue(HRdept.getId());
        dataFields.add(datafield4);

        // GZ
        DataField datafield5 = new DataField();
        datafield5.setName("deptId03");
        datafield5.setValue(curAreadept.getId());
        dataFields.add(datafield5);

        // (JT)
        DataField datafield2 = new DataField();
        datafield2.setName("deptId04");
        datafield2.setValue(sysdeptMem.getId());
        dataFields.add(datafield2);

        DataField datafield3 = new DataField();
        datafield3.setName("rowId");
        datafield3.setValue(purchase.getPurchaseid());
        dataFields.add(datafield3);

        ctx.setDataFields(dataFields);

        Long processInstanceId = null;
        boolean isOK = false;

        if (purchase.getProcessinstanceid() != null && purchase.getWfstatus() != 9999
                && purchase.getWfstatus() != null) {
            processInstanceId = purchase.getProcessinstanceid();
            ctx.setProcessInstanceId(processInstanceId);
            isOK = ProcessContainer.getContainer().completeTask(ctx);
            logger.info("workflowing .......");
        } else {
            processInstanceId = ProcessContainer.getContainer().startProcess(ctx);
            logger.info("processInstanceId=" + processInstanceId);
            isOK = true;
            logger.info("workflow start");
        }
        return isOK;
    }

    @RequestMapping("/submit")
    public ModelAndView submit(HttpServletRequest request, ModelMap modelMap) {
        Map<String, Object> params = RequestUtils.getParameterMap(request);
        Purchase purchase = new Purchase();
        try {
            Tools.populate(purchase, params);
            purchase.setPurchaseid(RequestUtils.getLong(request, "purchaseid"));
            purchase.setPurchaseno(request.getParameter("purchaseno"));// ?
            purchase.setArea(request.getParameter("area"));// 
            purchase.setCompany(request.getParameter("company"));// ??
            purchase.setDept(request.getParameter("dept"));// 
            purchase.setPost(request.getParameter("post"));// ??
            purchase.setAppuser(request.getParameter("appuser"));// 
            purchase.setAppdate(RequestUtils.getDate(request, "appdate"));// 
            purchase.setPurchasesum(RequestUtils.getDouble(request, "purchasesum"));// ?
            purchase.setStatus(1);// ? ??
            purchase.setCreateBy(
                    request.getParameter("createby") == null ? null : request.getParameter("createby"));
            purchase.setCreateDate(RequestUtils.getDate(request, "createdate") == null ? null
                    : RequestUtils.getDate(request, "createdate"));
            purchase.setUpdateBy(request.getParameter("updateby"));
            purchase.setUpdateDate(RequestUtils.getDate(request, "updatedate"));

            purchaseService.save(purchase);

            // ? ?? ?
            if (purchase.getStatus() == 1) {
                if (purchase.getProcessinstanceid() != null && purchase.getProcessinstanceid() > 0) {
                    completeTask(purchase, 0, request);
                } else {
                    startProcess(purchase, request);
                }
            }

            return this.list(request, modelMap);

        } catch (Exception ex) {
            ex.printStackTrace();
            logger.error(ex);
            ModelAndView mav = new ModelAndView();
            mav.addObject("message", "??");
            return mav;
        }
    }

    @RequestMapping("/update")
    public ModelAndView update(HttpServletRequest request, ModelMap modelMap) {
        Map<String, Object> params = RequestUtils.getParameterMap(request);
        params.remove("status");
        params.remove("wfStatus");

        Purchase purchase = purchaseService.getPurchase(RequestUtils.getLong(request, "purchaseid"));

        purchase.setPurchaseno(request.getParameter("purchaseno"));
        purchase.setArea(request.getParameter("area"));
        purchase.setCompany(request.getParameter("company"));
        purchase.setDept(request.getParameter("dept"));
        purchase.setPost(request.getParameter("post"));
        purchase.setAppuser(request.getParameter("appuser"));
        purchase.setAppdate(RequestUtils.getDate(request, "appdate"));
        purchase.setPurchasesum(RequestUtils.getDouble(request, "purchasesum"));
        purchase.setStatus(RequestUtils.getInt(request, "status"));
        purchase.setProcessname(request.getParameter("processname"));
        purchase.setProcessinstanceid(RequestUtils.getLong(request, "processinstanceid"));
        purchase.setWfstatus(RequestUtils.getLong(request, "wfstatus"));
        purchase.setCreateBy(request.getParameter("createby"));
        purchase.setCreateDate(RequestUtils.getDate(request, "createdate"));
        purchase.setUpdateDate(RequestUtils.getDate(request, "updatedate"));
        purchase.setUpdateBy(request.getParameter("updateby"));

        purchaseService.save(purchase);

        return this.list(request, modelMap);
    }

    @RequestMapping("/view")
    public ModelAndView view(HttpServletRequest request, ModelMap modelMap) {
        RequestUtils.setRequestParameterToAttribute(request);
        Purchase purchase = purchaseService.getPurchase(RequestUtils.getLong(request, "purchaseId"));
        request.setAttribute("purchase", purchase);
        JSONObject rowJSON = purchase.toJsonObject();
        request.setAttribute("x_json", rowJSON.toJSONString());

        return new ModelAndView("/oa/purchase/view");
    }
}