My server REST Jsersey receive Json and query param. I have 3 query params: username, password and email
@POST
@Consumes({MediaType.APPLICATION_JSON})
@Path("register")
public Response register(@QueryParam("email") String email, @QueryParam("username") String userName, @QueryParam("password") String password) {
System.out.println("username: " + userName);
System.out.println("password: " + password);
System.out.println("email: " + email);
if (TextUtil.isEmpty(userName) || TextUtil.isEmpty(password) || TextUtil.isEmpty(email)) {
return Response.status(Response.Status.BAD_REQUEST)
.header("Access-Control-Allow-Origin", "*")
.entity(ErrorUtil.badRequest("Field should not be empty")).build();
}
List<User> listUser = findAll();
for(User user: listUser) {
if (user.getUsername().equals(userName)) {
return Response.status(Response.Status.BAD_REQUEST)
.header("Access-Control-Allow-Origin", "*")
.entity(ErrorUtil.badRequest("This username is already registered"))
.build();
}
if (user.getEmail().equals(email)){
return Response.status(Response.Status.BAD_REQUEST)
.header("Access-Control-Allow-Origin", "*")
.entity(ErrorUtil.badRequest("This email is already registered"))
.build();
}
}
I try to user Jquery to send a request to the server but I got 415 Unsupported media type
var signUp = function () {
$("#formSignUp").submit(function (e) {
// var userName = $('#textUserNameSignUp').val();
// var email = $('#textEmailSignUp').val();
// var password = $('#textPasswordSignUp').val();
e.preventDefault();
$.post('http://localhost:43319/BR/webresources/users/register',
{ username: "hello", password : "123", email : "email"},
function(returnedData){
console.log(returnedData);
})
.fail(function(){
console.log("error");
});
});
}
Can you please show me what's wrong and suggest me how to do it right