1

我是 XmlHttpRequest 为了发出 http 请求,我想获取 cookie。获取 cookie 的代码:

let http_post url =
  XmlHttpRequest.perform_raw_url
    ~post_args:[("login", `String (Js.string "foo"));
                ("password", `String (Js.string "bar"))]
    url >>= fun r -> 
  let code = r.XmlHttpRequest.code in
  let msg = r.XmlHttpRequest.content in
  let cookie = match r.XmlHttpRequest.headers "Set-Cookie" with
  | None -> "Empty Cookie"
  | Some s -> s in 
  if code = 0 || code = 200
  then Lwt.return (msg,cookie)

let make_test_request id =
  let button = get_element_by_id id in
  button##onclick <- (Html.handler (fun _ ->
      http_post "www.website.com" >>=
      (fun (msg,cookie) ->
         Printf.printf "cookie = %s\n" cookie;
         Html.document##cookie <- Js.string cookie;
         Printf.printf "s = %s\n" msg;
         Lwt.return());
      Js._true))

cookie 应该在标题中,我收到此错误:拒绝获取不安全的标题“Set-Cookie”

这是我弄错cookie的方式还是我的网络浏览器有问题(我使用的是铬)?

4

1 回答 1

1

http://www.w3.org/TR/XMLHttpRequest/#the-getresponseheader()-方法

客户 。getResponseHeader(header) 从响应中返回字段名称与 header 匹配的 header 字段值,除非字段名称是 Set-Cookie 或 Set-Cookie2。

为什么在使用 setRequestHeader 制作 xmlhttprequest 时无法设置 cookie 和 set-cookie 标头的答案?

于 2015-03-22T19:55:06.483 回答