0

フィールドcodigo_casoのぼかしに応じて、JSP ページでフォームを自動入力する必要があります。フォームを完成させるために必要なデータを取得している別の JSP に、単純な json のような文字列を渡しています。

ページをテストしたところ、DB から正しいデータを取得し、それを使用して JSONObject を構築する 2 番目の JSP を呼び出しています。

問題は、JSON を最初の JSP ページに返していないようで、success 関数内のコードが実行されていないことです。[可能であれば、サーブレットではなく、jsp で動作させる必要があります]

スクリプトは次のとおりです-最初のjsp

<script type="text/javascript">
  $("#codigo_caso").blur(function() {
    var cod = $(this).val();
    var dataString1 = {"codigo": cod};
    $.ajax({
      type: "GET",
      url: "otros/codigoCasoDependienteNuevaTarea.jsp",
      datatype: "json",
      contentType: "application/json; charset=utf-8",
      data: dataString1,
      cache: false,
      success: function(response) {
        alert ( response );
        var jsontest = eval(response);
        $(".linea_equipo").val(jsontest("linea_equipo"));
        $("#selectArea").filter(function() {
            return $(this).jsontest("id_area") === jsontest("area");
        }).prop('selected', true);
        //("#selectArea").val(area);
        $(".listaCentros").jsontest("nombre_centro");
        $("#listaRolNuevaTarea").filter(function() {
            return $(this).jsontest("id_rol") === jsontest("rol");
        }).prop('selected', true);
        //("#listaRolNuevaTarea").val(rol);
      }
    });
  });

これは、DBからデータを取得するJSPです[JSONを返すことを意図しています]

<%@page import="java.sql.*"%>
<%@page import="clases.*"%>
<%@page import="org.json.simple.*"%>
<%@page contentType="text/html" pageEncoding="UTF-8"%>
<html>
<%
String data1 = "", linea = "", centro = "", error = "No existe el caso indicado", cadenaOut = "";
int area, rol;
Connection conex = (Connection) session.getAttribute("conexion");
Statement st = conex.createStatement();
String sql = "";
String cod = request.getParameter("codigo").toString();
JSONObject j = new JSONObject();
if (cod != null && !cod.isEmpty() && !cod.equals("0")) {
    sql = "SELECT t1.linea_equipo,t1.id_rol, t2.id_area,t2.nombre_centro "
            + " FROM gen_casos_prisma t1 LEFT OUTER JOIN gen_centros t2 ON "
            + " t1.id_centro = t2.id_centro "
            + " WHERE "
            + " t1.CODIGO_CASO =  " + cod;
    ResultSet rs = st.executeQuery(sql);
    rs.beforeFirst();
    if (rs.next()) {
        linea = rs.getString("linea_equipo");
        area = rs.getInt("id_area");
        centro = rs.getString("nombre_centro");
        rol = rs.getInt("id_rol");
        j.put("linea_equipo", linea);
        j.put("id_area", area+"");
        j.put("nombre_centro", centro);
        j.put("id_rol", rol+"");
        System.out.println(j.toString());
    } else {
        /* return variable error */
    }
}
response.setContentType("application/json");
response.getWriter().print(j);
out.flush();
//out.print(j.toJSONString());
%>
</html>

コードがjsonを出力すると、[2番目のjsp、ほぼ最後]、次のように表示されます。

  • {"id_area":"268435465","linea_equipo":"MODULAR xxx","nombre_centro":"center xxx","id_rol":"2"}
4

1 に答える 1

0

JavaScript が json のみを受け取るようにしたい場合は、

<html> 

</html> 

JSP からのタグであるため、json のみが返されます。

明らかにあなたが電話してから

 response.setContentType("application/json"); 

出力で html タグを使用しても意味がありません。

于 2013-10-15T13:29:45.430 に答える