0

我一直在互联网上搜索一些(正确)方法来@Consume 在我的服务器上的网络资源中使用“应用程序/json”文件。

我正在使用 glassfish 应用服务器,所以它是一个 java 资源。

这是调用 javascvript 代码:

        var url="/MBC/pages/lives/";
        var mygetrequest=new ajaxRequest();
        mygetrequest.onreadystatechange=function(){
         if (mygetrequest.readyState==4){
          if (mygetrequest.status==200 || window.location.href.indexOf("http")==-1){
              var render="";

              var JsonIn =JSON.parse(mygetrequest.responseText);

              if(JsonIn.error==undefined){
                    render="generic error"; 
                  }
               }else
                  render=mygetrequest.responseText  ;

               document.getElementById(div).innerHTML=render;

            }else{
           render="An error has occured making the request";
          } 
        };
        var json2Send = "{" +
                "boss:\""+location.href.substring(location.href.length-5,location.href.length-4)+"\"," ;
        if(document.newLive.bval.value=='')
            json2Send+="bands:[],";
        else
            json2Send+="bands:["+document.newLive.bval.value+"],";

        json2Send+="data:\""+document.newLive.dateEvent.value+"\"," +
                "address:{street:\""+document.newLive.street.value+"\"," +
                        "number:\""+document.newLive.number.value+"\"," +
                        "city:\""+document.newLive.city.value+"\"," +
                        "region:\""+document.newLive.region.value+"\"," +
                        "state:\""+document.newLive.state.value+"\"}" +
                "}";
        mygetrequest.open("POST", url, true);
        mygetrequest.setRequestHeader("Content-type", "application/json");
        mygetrequest.send(json2Send);

其中 json2Send 是客户端必须发送到服务器的 json 字符串。

这里是服务器端代码:

@POST
@Path("configLiveBand")
@Consumes("application/json")
@Produces("application/json")
public String liveBandInsert(String jsonIn, @Context HttpServletRequest request) throws ParseException{

我现在问你我必须做什么才能让服务器读取来自 javascript 的输入 json 字符串。显然,我上面描述的方式是行不通的。服务器返回

HTTP Status 405 -

type Status report

message

descriptionThe specified HTTP method is not allowed for the requested resource ().

通过互联网查看我的问题,我找到了涉及“BufferedReader”类的“readline()”方法的解决方案。我不喜欢这个解决方案。如果有办法,我更喜欢注入 json 文件,而不是逐行读取输入字符串。

任何帮助都会被接受,谢谢

4

2 回答 2

0

问题是菲利普写道的json:

json2Send+="\"data\":\""+document.newLive.dateEvent.value+"\"," +
        "\"address\":{\"street\":\""+document.newLive.street.value+"\"," +
                "\"number\":\""+document.newLive.number.value+"\"," +
                "\"city\":\""+document.newLive.city.value+"\"," +
                "\"region\":\""+document.newLive.region.value+"\"," +
                "\"state\":\""+document.newLive.state.value+"\"}" +
        "}";

代替

json2Send+="data:\""+document.newLive.dateEvent.value+"\"," +
        "address:{street:\""+document.newLive.street.value+"\"," +
                "number:\""+document.newLive.number.value+"\"," +
                "city:\""+document.newLive.city.value+"\"," +
                "region:\""+document.newLive.region.value+"\"," +
                "state:\""+document.newLive.state.value+"\"}" +
        "}";

现在我可以读取、发布并将 json 结果发送回客户端。;-) 谢谢菲利普

于 2012-06-25T21:21:09.493 回答
0

很高兴我能帮上忙。

我仍然建议json2Send使用实际的 Javascript 对象表示法 (JSON) 而不是字符串连接来构建您的,例如:

// This creates an "empty" JS object, with no properties.
var json2Send = new Object();
var length = location.href.length;
// Adding a property is as easy as just setting it, it will be created by this.
json2Send.boss = location.href.substring(length - 5, length - 4);
if (document.newLive.bval.value == '') {
  json2Send.bands = [];
} else {
  json2Send.bands = [document.newLive.bval.value];
}
json2Send.data = document.newLive.dateEvent.value;
// Properties can also be other objects, here created with the
// object literal notation of { key:value, ...}.
json2Send.address = {
  // Inside, it's just another JS object again,
  // this time setting properties with literal notation key:value
  // Note how there's no need to quote anything here!
  street: document.newLive.street.value,
  number: document.newLive.number.value,
  city: document.newLive.city.value,
  region: document.newLive.region.value,
  state: document.newLive.state.value
};

然后将其转换为 HTTP POST 的字符串,如下所示:

mygetrequest.open("POST", url, true);
mygetrequest.setRequestHeader("Content-type", "application/json");
mygetrequest.send(JSON.stringify(json2Send));

This will catch syntax errors much earlier, relieves you from manually quoting all the different bits and pieces, is most likely faster and it sure makes the whole thing a lot more robust.

于 2012-06-25T22:27:49.300 回答