フォーラムで同様のエラーを調べましたが、まだ機能していないようで、
Status Code: HTTP/1.1 415 Unsupported Media Type
私はこのjQueryを送信しています:
$("#btnInsertCustomer").click(function (){
var myObj = {name: "Bill Adama", address:"Vancouver Canada"};
var jsondata = JSON.stringify(myObj);
$.ajax({
type: "POST",
url: "http://localhost:8081/RestDemo/services/customers/add",
contentType: "application/json",
dataType: "json",
data: jsondata,
success: function (resp, status, xhr) {
var msg = "Name: " + resp.name + ", Address: " + resp.address;
alert(msg);
$("#successPost").html(msg + " - STATUS: " + xhr.status + " " + xhr.statusText);
},
error: function(resp, status, xhr){
alert("Error: " + resp.e);
$("#errorPost").html("Error: " + resp.e + " - STATUS: " + xhr.status + " " + xhr.statusText);
}
});
});
この次のリソースに:
@POST
@Path("/add")
@Produces("application/json")
@Consumes({MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON})
public String addCustomer(Customer customer) {
//insert
int id = customerMap.size();
customer.setId(id);
customerMap.put(id, customer);
//get inserted
Customer result = customerMap.get(id);
return "{\"name\": \" " + result.getName() + " \", \"address\": \"" + result.getAddress() + "\"}";
}
それはサービスに当たっておらず、私にエラーを与えています。エラーがjQuery側(問題ないようです)で送信されたデータのフォーマットにあるのか、サービスレシーバーにあるのか理解できません。
どんな助けでもありがたいです、ありがとう!
更新1:転送するDTOを作成しました
$("#btnInsertCustomer").click(function (){
//var myObj = '{"name": "Bill Adama", "address":"Vancouver Canada"}';
//var jsondata = JSON.stringify(myObj);
var NewCustomer = { };
NewCustomer.name = "Bill Adama";
NewCustomer.address = "Vancouver Canada";
var DTO = { 'NewCustomer' : NewCustomer };
$.ajax({
type: "POST",
contentType: "application/json; charset=utf-8",
url: "http://localhost:8081/RestDemo/services/customers/add",
data: JSON.stringify(DTO),
dataType: "json",
success: function (resp, status, xhr) {
var msg = "Name: " + resp.name + ", Address: " + resp.address;
alert(msg);
$("#successPost").html(msg + " - STATUS: " + xhr.status + " " + xhr.statusText);
},
error: function(resp, status, xhr){
alert("Error: " + resp.e);
$("#errorPost").html(resp.e + " - STATUS: " + xhr.status + " " + xhr.statusText);
}
});
});
しかし、それでも同じエラーが発生します。