私はRESTful APIの初心者であり、ログインサービスを構築しようとしています。このサービスでは、メールとパスワードを提供し、検証が成功した場合はCookieを保存します。さらに、Cookie(保存されている場合)を確認するにはどうすればよいですか?
どうすればこれを達成できますか?
@Path("/login")
@POST
@Produces(MediaType.APPLICATION_JSON)
@Consumes({MediaType.APPLICATION_FORM_URLENCODED, MediaType.APPLICATION_JSON})
public Response Login(final String i_LoginDetails) throws JSONException {
final JSONObject obj = new JSONObject(i_LoginDetails);
try {
if (isValidUser(obj.getString("email"), obj.getString("password"))) {
// Set a cookie
} else {
// return error invalid-credentials message
}
} catch (Exception e) {
e.printStackTrace();
}
return Response.ok("TEST").build();
}
そして、どのようにクッキーをチェックしますか(設定されている場合)?
次のことができます。
新しいCookieを保存するには:
@GET
@Path("/login")
@Produces(MediaType.TEXT_PLAIN)
public Response login() {
NewCookie cookie = new NewCookie("name", "123");
return Response.ok("OK").cookie(cookie).build();
}
Cookie(javax.ws.rs.core.Cookie
):
@GET
@Path("/foo")
@Produces(MediaType.TEXT_PLAIN)
public Response foo(@CookieParam("name") Cookie cookie) {
if (cookie == null) {
return Response.serverError().entity("ERROR").build();
} else {
return Response.ok(cookie.getValue()).build();
}
}
ただし、値のみが必要な場合があります。
@GET
@Path("/foo")
@Produces(MediaType.TEXT_PLAIN)
public Response foo(@CookieParam("name") String value) {
System.out.println(value);
if (value == null) {
return Response.serverError().entity("ERROR").build();
} else {
return Response.ok(value).build();
}
}
ちなみに、次のコードを試してください。
@GET
@Path("/logout")
@Produces(MediaType.TEXT_PLAIN)
public Response logout(@CookieParam("name") Cookie cookie) {
if (cookie != null) {
NewCookie newCookie = new NewCookie(cookie, null, 0, false);
return Response.ok("OK").cookie(newCookie).build();
}
return Response.ok("OK - No session").build();
}
これにより、ブラウザのCookieが削除されます。動作はJAX-RSの実装に依存します。 RESTEasy(JBoss AS 7.0)およびGoogle Chromeは正常に動作します。