我在VertX中创建Cookie,并希望在用户退出后再次删除它们。
AccountController.handleLogin(vertx, router.post("/login"))
...
fun handleLogin(vertx: Vertx, route: Route) {
route.handler { rtx ->
rtx.request().bodyHandler { btx ->
vertx.executeBlocking<Login>({
it.complete(AccountController.login(Json.decodeValue(String(btx.bytes), Login::class.java)))
}, {
if (it.succeeded()) {
// set some cookies
rtx.addCookie(Cookie.cookie("atom-session", it.result().session).setHttpOnly(true).setSecure(secure))
现在可以在Chrome中看到该Cookie:
当我想再次删除该cookie时:
AccountController.handleLogout(vertx, router.post("/logout"))
...
fun handleLogout(vertx: Vertx, route: Route) {
route.handler { rtx ->
rtx.request().bodyHandler { btx ->
vertx.executeBlocking<Logout>({
val logout = Json.decodeValue(String(btx.bytes), Logout::class.java)
it.complete(AccountController.logout(logout))
}, {
if (it.succeeded()) {
log.info("Cookies Will No Be Removed ...")
rtx.removeCookie("atom-session")
log.info("DONE!")
我可以看到正在打印的消息说将删除Cookie,但是当我刷新Chrome中的资源时,登录时设置的所有Cookie仍然存在。包括atom-session
我做错了还是这是VertX中的错误?
答案 0 :(得分:5)
removeCookie
方法会将其从请求对象中删除,但不会从Web客户端中删除cookie。为了强制将其从客户端中删除,必须将cookie与过期日期一起发回。例如,你应该这样做:
rtx.getCookie("atom-session").setMaxAge(0)
这本身不是vert.x功能,而是Cookie如何工作。