在javascript中获取servlet值,并使用ajax将该值分配给文本框

时间:2015-03-24 05:01:44

标签: javascript ajax servlets

我有一个servlet,我从属性文件中获取价值。我想从我的javascript中获取servlet的值,并使用AJAX将该值设置为文本框。我是Ajax的新手,所以请通过查看我的代码为我提供解决方案。

SERVLET

       @WebServlet("/PopulateProperties")
      public class PopulateProperties extends HttpServlet {
     private static final long serialVersionUID = 1L;
     Properties prop = new Properties(); 
      protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    // TODO Auto-generated method stub
    String serverName=request.getParameter("servernameDD");
    List<Map<String,String>> returnObj = new ArrayList<Map<String,String>>();
    String[] servers = getSearchAttr("servers");
    if (servers != null && servers.length > 0) {


        String[] lookfor = getSearchAttr("servers_lookfor");
        for (String server : servers) {
            Map<String,String> obj = new HashMap<String,String>();
            if (lookfor != null) {
                for (String look : lookfor) {
                    //System.out.println("looking for :"+look);
                    String value =  prop.getProperty(server+"_"+look);
                    if(server.equalsIgnoreCase(serverName)){
                        if(look.equalsIgnoreCase("Links")){
                        String getlook=prop.getProperty(look);
                        String getlink=prop.getProperty(server+'_'+look,"Links");
                        System.out.println("Hello" +getlink);
                        System.out.println(getlook);
                        request.setAttribute("serverLink", getlink);

                        }
                    }
                    if (value != null) {
                        obj.put(look, value);
                    }
                    request.setAttribute("servers", server);
                    request.setAttribute("lookfor", look);

                }           

            }       
            //System.out.println("Object :"+obj);
            returnObj.add(obj);

        }


    }
    response.sendRedirect("updateserverstatus.html");

        }






private String[] getSearchAttr( String property){
    String lookfor = prop.getProperty(property,"");
    String[] ret = {lookfor};
    if (lookfor.contains(",")) {
        return lookfor.split(",");
    } else {
        //System.out.println("comma not present in "+property);
        //System.out.println("webservice :"+lookfor);
        return ret;

        }

     }

我尝试了以下Ajax请求,但我得到了&#34; serverLink未定义错误&#34;

function OnSelectionChange(){


$.ajax({
    type: "POST",
    url: "/PopulateProperties",
    data: "{Links: " + serverLink + "}",
    success: function(result){
        alert(result.d);
        console.log(result);
    }
});
  }

2 个答案:

答案 0 :(得分:0)

您使用servlet获取数据并转发。这不是用servlet提供数据的正确方法。更好的解决方案是:

在servlet中,您应该以json格式返回属性数据。您可以参考this
然后在html页面中使用ajax获取此数据,并更新textarea的文本。

答案 1 :(得分:0)

最好为此目的创建单独的servlet。这将使您的代码保持一致。 将所有将用于缩小的参数传递给您需要检索的数据。

为简单起见,只需返回值,或者您可以将数据作为JSON键值对返回。

如果您的文本框是这样的。 <input type="text" id="prop_txt"> 那么ajax代码将是

$.ajax({
  type: "POST",
  url: "/PopulateProperties",
  data: "{A:(..a value..),
          B:(..b value..),
          ....
          ....
          (..all the parameters required..)
         }",
  success: function(result){
      //alert(result.d);
      console.log(result);
      $('#prop_txt').val(result);
  }
});

希望这一点。