数据库发送webservice请求,接受json格式的时候,需要解析格式,引入解析json.jar包比较方便

 

1)首先我们确定要导入的json.jar包,这里推荐gson.jar,因为这个jar不依赖于其他jar,功能也很强大!

 

2)loadjava -r -f -u 用户名/密码@数据库地址:端口/数据库实例 gson.jar                   导入jar

      

     dropjava -u 用户名/密码@数据库地址:端口/数据库实例 gson.jar                          删除导入的jar

 

3)这时候我们只是引入了gson.jar,我们还需要封装一个类,将我们需要的方法写进去



create or replace and compile java source named "Cux_Gson_Util" as


import com.google.gson.JsonArray;
import com.google.gson.JsonObject;
import com.google.gson.JsonElement;
import com.google.gson.JsonNull;
import com.google.gson.JsonParseException;
import com.google.gson.JsonParser;
import com.google.gson.JsonPrimitive;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.Reader;
import java.lang.Integer;
import java.sql.Clob;
import java.sql.SQLException;

public class Cux_Gson_Util {
  
 public static boolean isJsonString(String json) {

        try {
            new JsonParser().parse(json);
            return true;
        } catch (JsonParseException e) {
            return false;
        } catch (NullPointerException e) {
            return false;
        } catch (Exception e) {
            return false;
        }
    }

    // 取json串单个节点值
    // json取值,有两种常见的异常,KEY不存在,空指针异常,数组型json,数组长度越界异常
    // 应该还是要按Exceptin处理,否则由于传参的数据错误的话,就发现不了,直接当空值返回了。
    // 不能返回空,应该在第一步数据校验里面直接抛出来。
    public static String getValue(String jsonStr, String nodeName) {
        String nodeValue = "";
        if (!isJsonString(jsonStr)) {
            nodeValue = "";
        } else {
            try {
                JsonParser jsonParser = new JsonParser();
                JsonObject obj = new JsonObject();
                obj = (JsonObject) jsonParser.parse(jsonStr);
                nodeValue = "";
                if (obj.get(nodeName) instanceof JsonObject) {
                    nodeValue = obj.get(nodeName).toString();
                } else if (obj.get(nodeName) instanceof JsonArray) {
                    nodeValue = obj.get(nodeName).toString();
                } else if (obj.get(nodeName) instanceof JsonPrimitive) {
                    // Error toString will , the result will start and end with
                    // "
                    // nodeValue = obj.get(nodeName).toString();

                    // 四种写法都可以
                    // nodeValue = obj.get(nodeName).getAsString();
                    // nodeValue = obj.getAsString();
                    // nodeValue =
                    // obj.get(nodeName).getAsJsonPrimitive().toString();
                    nodeValue = obj.get(nodeName).getAsJsonPrimitive().getAsString();
                } else if (obj.get(nodeName) instanceof JsonNull) {
                    nodeValue = "";
                } else {
                    nodeValue = obj.get(nodeName).getAsJsonPrimitive().getAsString();
                }
            } catch (Exception e) {
            }

        }

        return nodeValue;
    }

    // 取json数组长度便于循环处理
    public static int getArrayLength(String jsonArrayStr) {
        int length = 0;
        if (isJsonString(jsonArrayStr)) {
            JsonArray jsonArr = new JsonParser().parse(jsonArrayStr).getAsJsonArray();
            length = jsonArr.size();
        } else {
            length = 0;
        }
        return length;
    }

    // 取json数组第index个元素
    public static String getArrayValue(String jsonStr, Integer index) {
        String nodeValue = "";
        if (isJsonString(jsonStr)) {
            JsonArray jsonArr = new JsonParser().parse(jsonStr).getAsJsonArray();
            // 此处不能用getAsString()或者getAsJsonPrimitive(),因为数组中的类型未知,需要先做空判断
            if (jsonArr.get(index) instanceof JsonNull) {
                nodeValue = "";
            } else {
                nodeValue = jsonArr.get(index).toString();
            }
        } else {
            nodeValue = null;
        }

        return nodeValue;
    }

    // 取json串下级节点值
    public static String getJsonValue(String jsonStr, String nodeName) {
        String nodeValue = "";

        if (isJsonString(jsonStr)) {
            JsonParser parser = new JsonParser();
            JsonElement jsonElement = parser.parse(jsonStr);

            if (jsonElement.isJsonNull()) {
                nodeValue = "";
            } else if (jsonElement.isJsonPrimitive()) {
                nodeValue = jsonElement.getAsJsonPrimitive().getAsString();
            } else if (jsonElement.isJsonObject()) {
                nodeValue = getJSONObjectValue(jsonElement.getAsJsonObject().toString(), nodeName);
            } else if (jsonElement.isJsonArray()) {
                nodeValue = getJSONArrayValue(jsonElement.getAsJsonArray().toString(), nodeName);
            } else {
                nodeValue = null;
            }

        }

        return nodeValue;

    }

    // 对于数组,以"@"作为分隔, index/nodeName形式,如 0@Amount
    public static String getJSONArrayValue(String jsonStr, String nodeName) {
        String nodeValue = "";
        JsonParser jsonParser = new JsonParser();
        JsonArray obj = jsonParser.parse(jsonStr).getAsJsonArray();

        int position = nodeName.indexOf("@");
        String objStr = nodeName.substring(0, position);
        int index = Integer.parseInt(objStr);
        String nodeStr = nodeName.substring(position + 1);
        // 此处未做数组越界异常判断,

        nodeValue = getJsonValue(obj.get(index).toString(), nodeStr);
        return nodeValue;
    }

    // 参数nodeName,对于嵌套json以"/"作为分隔,比如HEADER/LINE
    public static String getJSONObjectValue(String jsonStr, String nodeName) {
        String nodeValue = null;
        JsonParser jsonParser = new JsonParser();
        JsonObject obj = jsonParser.parse(jsonStr).getAsJsonObject();

        int position = nodeName.indexOf("/");
        if (position == -1) {
            // 此处未做Key是否存在的检查,如果要做,应该将检查方法单独提前校验
            if (obj.get(nodeName) instanceof JsonObject) {
                // 此处可以直接用toString方法
                // nodeValue = obj.get(nodeName).toString();
                nodeValue = obj.get(nodeName).getAsJsonObject().getAsString();
            } else if (obj.get(nodeName) instanceof JsonArray) {
                // 此处可以直接用toString方法
                // nodeValue = obj.get(nodeName).toString();
                nodeValue = obj.get(nodeName).getAsJsonArray().getAsString();
            } else if (obj.get(nodeName) instanceof JsonPrimitive) {
                nodeValue = obj.get(nodeName).getAsJsonPrimitive().getAsString();
            } else if (obj.get(nodeName) instanceof JsonNull) {
                nodeValue = "";
            } else {
                nodeValue = "";
            }

        } else {
            String objStr = nodeName.substring(0, position);
            String nodeStr = nodeName.substring(position + 1);
            nodeValue = getJsonValue(obj.get(objStr).toString(), nodeStr);
        }

        return nodeValue;

    }

    public static String ClobToString(Clob clob) throws SQLException, IOException {

        String reString = "";
        Reader is = clob.getCharacterStream();// 得到流
        BufferedReader br = new BufferedReader(is);
        String s = br.readLine();
        StringBuffer sb = new StringBuffer();
        while (s != null) {// 执行循环将字符串全部取出付值给StringBuffer由StringBuffer转成STRING
            sb.append(s);
            s = br.readLine();
        }
        reString = sb.toString();
        return reString;
    }

    public static String getClobArrayValue(Clob jsonStr, String str1, String str2) throws SQLException, IOException {
        return getValue(getValue(getArrayValue(ClobToString(jsonStr), 0), str1), str2);
    }

    public static int getClobLength(Clob jsonStr, String str1, String str2) throws SQLException, IOException {
        return getArrayLength(getValue(getValue(getArrayValue(ClobToString(jsonStr), 0), str1), str2));

    }

    public static String getClobArrayValue(Clob jsonStr, String str1, String str2, Integer index)
            throws SQLException, IOException {
        return getArrayValue(getValue(getValue(getArrayValue(ClobToString(jsonStr), 0), str1), str2), index);
    }
}



前面的代码是借鉴网上的,后面解析Clob类型的方法是我添加的,因为存在json字符串过长,超过2000个字符,string就无法解析了!

4)java类写好后,还需要写PKG,将java方法映射到存储过程上去



CREATE OR REPLACE PACKAGE Cux_Gson_Util_pkg AS
 --// 取json串单个KEY值
 FUNCTION getval(jsonstr VARCHAR2, nodename VARCHAR2) RETURN VARCHAR2;
 --//取json数组第index个元素
 FUNCTION getarrval(jsonarraystr VARCHAR2, index_num NUMBER) RETURN VARCHAR2;
 --//取json数组长度便于循环处理
 FUNCTION getarrlen(jsonarraystr VARCHAR2) RETURN NUMBER; --// 取json串下级节点值
 FUNCTION getjsonvalue(jsonarraystr VARCHAR2, nodename VARCHAR2)
 RETURN VARCHAR2; --// 对于数组,以"@"作为分隔, index/nodeName形式,如 0@Amount
 FUNCTION getjsonarrayvalue(jsonarraystr VARCHAR2, nodename VARCHAR2)
 RETURN VARCHAR2; --// 参数nodeName,对于嵌套json以"/"作为分隔,比如HEADER/LINE
 FUNCTION getjsonobjectvalue(jsonarraystr VARCHAR2, nodename VARCHAR2)
 RETURN VARCHAR2;
 --获取clob类型json的第一个值的str1的str2
 function getclobarrayvalue(jsonStr Clob, str1 VARCHAR2, str2 VARCHAR2)
 return varchar2;
 function getcloblength(jsonStr Clob, str1 VARCHAR2, str2 VARCHAR2)
 return NUMBER;
 function getclobarrayvalue(jsonStr Clob,
 str1 VARCHAR2,
 str2 VARCHAR2,
 index_num NUMBER) return varchar2;
END Cux_Gson_Util_pkg;
/
CREATE OR REPLACE PACKAGE BODY Cux_Gson_Util_pkg AS
 FUNCTION getval(jsonstr VARCHAR2, nodename VARCHAR2) RETURN VARCHAR2 AS
 LANGUAGE JAVA NAME 'Cux_Gson_Util.getValue(java.lang.String,java.lang.String) return java.lang.String'; FUNCTION getarrval(jsonarraystr VARCHAR2, index_num NUMBER) RETURN VARCHAR2 AS
 LANGUAGE JAVA NAME 'Cux_Gson_Util.getArrayValue(java.lang.String, java.lang.Integer) return java.lang.String'; FUNCTION getarrlen(jsonarraystr VARCHAR2) RETURN NUMBER AS
 LANGUAGE JAVA NAME 'Cux_Gson_Util.getArrayLength(java.lang.String) return java.lang.Integer'; FUNCTION getjsonvalue(jsonarraystr VARCHAR2, nodename VARCHAR2)
 RETURN VARCHAR2 AS
 LANGUAGE JAVA NAME 'Cux_Gson_Util.getJsonValue(java.lang.String,java.lang.String) return java.lang.String'; FUNCTION getjsonarrayvalue(jsonarraystr VARCHAR2, nodename VARCHAR2)
 RETURN VARCHAR2 AS
 LANGUAGE JAVA NAME 'Cux_Gson_Util.getJSONArrayValue(java.lang.String,java.lang.String) return java.lang.String'; FUNCTION getjsonobjectvalue(jsonarraystr VARCHAR2, nodename VARCHAR2)
 RETURN VARCHAR2 AS
 LANGUAGE JAVA NAME 'Cux_Gson_Util.getJSONObjectValue(java.lang.String,java.lang.String) return java.lang.String';
 function getclobarrayvalue(jsonStr Clob, str1 VARCHAR2, str2 VARCHAR2)
 return varchar2 as
 LANGUAGE JAVA NAME 'Cux_Gson_Util.getClobArrayValue(java.sql.Clob,java.lang.String,java.lang.String) return java.lang.String';
 function getcloblength(jsonStr Clob, str1 VARCHAR2, str2 VARCHAR2)
 return NUMBER as
 LANGUAGE JAVA NAME 'Cux_Gson_Util.getClobLength(java.sql.Clob,java.lang.String,java.lang.String) return java.lang.Integer';
 function getclobarrayvalue(jsonStr Clob,
 str1 VARCHAR2,
 str2 VARCHAR2,
 index_num NUMBER) return varchar2 as
 LANGUAGE JAVA NAME 'Cux_Gson_Util.getClobArrayValue(java.sql.Clob,java.lang.String,java.lang.String,java.lang.Integer) return java.lang.String';
END Cux_Gson_Util_pkg;
/



5)最后我们就可以测试使用了



select cux_gson_util_pkg.getarrval(jsonarraystr => '[{" name ":" aaa "," age ":" 12"},{" name ":" bbb "," age ":" 13 "}]',
                                   index_num    => 0)

  from dual;



kibana把json导入eS json包导入_java



select cux_gson_util_pkg.getval(cux_gson_util_pkg.getarrval(jsonarraystr => '[{"name":"aaa","age":"12"},{"name":"bbb","age":"13"}]',
                                                            index_num    => 0),
                                'name')

  from dual;