我正在尝试使用javascript和ajax将index.html中的HTML表单中的数据作为JSON数据发送到Java REST Web服务。我尝试了到目前为止在网上找到的所有内容,并且仍然每次都遇到HTTP错误415。
我知道该错误的含义,但由于我对javascript尚不甚了解,所以无法弄清楚哪里出了错。
代码如下:
index.html
div style="text-align:center">
<form action="http://localhost/MyTaskTest/servicea" method="post"
id="test">
<fieldset>
<legend>Add to Your balance</legend>
<label for="amount">Money amount</label>
<input type="text" name="Amount" /> <br/>
<label for="currency">Select currency</label>
<select name="Currency">
<option value="eur">EUR</option>
</select>
<input type="submit" value="Add">
</fieldset>
</form>
</div>
<script
src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js">
</script>
<script>
(function() {
function toJSONString( form ) {
var obj = {};
var elements = form.querySelectorAll( "input, select" );
for( var i = 0; i < elements.length; ++i ) {
var element = elements[i];
var name = element.name;
var value = element.value;
if( name ) {
obj[ name ] = value;
}
}
return JSON.stringify( obj );
}
window.onload = function() {
var form = document.getElementById("test");
var output = document.getElementById("output");
form.onsubmit = function( e ) {
e.preventDefault();
var json = toJSONString( this );
console.log(json);
console.log("TEST");
$.ajax({
url: form.getAttribute( 'action' ),
headers: {
'Accept': 'application/json',
'Content-Type': "application/json; charset=utf-8"
},
type: 'POST',
data: json,
success: function(data) {
alert("data saved")
console.log("SUCCESS");
},
error: function() {
console.log("ERROR");
console.log(errorThrown);
}
})
};
}
})();
</script>
这是REST服务:
@Path("/")
public class ServiceA {
@POST
@Path("/servicea")
//@Consumes(MediaType.APPLICATION_JSON)
public Response postRequest(String obj) {
String res = "hii";
return Response.status(200).entity(obj).build();
}
编辑
我编辑了代码...现在可以正常工作了。但是为什么我需要将参数设置为String而不是JSONObject并删除@Consumes?在控制台中,我从以ajax发送的变量中获取此数据:{“ Amount”:“ 213”,“ Currency”:“ eur”} ...因此,我正在发送JSON,但仅当参数为String时,服务才有效。
最终编辑
我设法解决了这个问题,因为缺少jersey-json的依赖关系。谢谢:)
答案 0 :(得分:1)
您的代码中存在一些错误,请尝试在chrome开发人员工具中对其进行调试。我进行了一些更改,这是可行的
(function() {
function toJSONString( form ) {
var obj = {};
var elements = form.querySelectorAll( "input, select" );
for( var i = 0; i < elements.length; ++i ) {
var element = elements[i];
var name = element.name;
var value = element.value;
if( name ) {
obj[ name ] = value;
}
}
return JSON.stringify( obj );
}
window.onload = function() {
var form = document.getElementById("test");
var output = document.getElementById("output");
form.onsubmit = function( e ) {
e.preventDefault();
var json = toJSONString( this );
console.log(json);
$.ajax({
url: form.getAttribute( 'action' ),
headers: {
'Accept': 'application/json',
'Content-Type': "application/json; charset=utf-8"
},
type: 'POST',
data: json,
success: function(data) {
alert("data saved")
},
error: function() {
console.log(errorThrown);
}
})
};
}
})();
答案 1 :(得分:0)
尝试添加
dataType: "json",
contentType : "application/json"
使用您的$ .ajax方法
$.ajax({
url: $form.attr( 'action' ),
dataType: "json",
contentType : "application/json"
type: 'POST',
data: json,
success: function(data) {
alert("data saved")
},
error: function() {
console.log(errorThrown);
}
})
你也有;在$ .ajax方法的网址字段中-最好将其删除;) 同样最好使用例如PostMan检查服务是否能正常工作,因此您确定它不是服务端,我不知道您使用了什么框架,但是您也可以尝试替换
public Response postRequest(JSONObject object) {
使用
public Response postRequest(String object) {
检查映射是否没有问题