304 CORS

304響應, CORS問題: 沒有 Access-Control-Allow-Origin 這個頭信息時,之前次返回的200請求爲準。javascript

示例:可能已被刪除
http://7af3zm.com1.z0.glb.clouddn.com/ajax_304_cors.htmlhtml

附上源碼:
htmljava

<!doctype html>
<html>
<head>
	<meta charset="UTF-8">
</head>
<body>
<script type="text/javascript">
// var _ajax_34re = false;
	function getAjax () {
		var _ajax_34re = false;
		if (_ajax_34re) {
			return _ajax_34re;
		}
		try {
			_ajax_34re = new XMLHttpRequest();
	   } catch (trymicrosoft) {
	     try {
			_ajax_34re = new ActiveXObject("Msxml2.XMLHTTP");
	     } catch (othermicrosoft) {
	       try {
			_ajax_34re = new ActiveXObject("Microsoft.XMLHTTP");
	       } catch (failed) {
			_ajax_34re = false;
	       }
	     }
	   }
		return _ajax_34re;
	}

	function load(url) {
		request =  getAjax ();
		request.open("GET", url);
    	request.onreadystatechange = updatePage;
    	request.send(null);
   }

   function updatePage() {
     if (request.readyState == 4)
       if (request.status == 200)
         alert("Server is done!" + request.responseText);
       else if (request.status == 404)
         alert("Request URL does not exist");
       else
         alert("Error: status code is " + request.status);
   }


</script>
<pre>
	access: 200、304響應都有 Access-Control-Allow-Origin:*;
	access-non: 200、304響應都 沒 有 Access-Control-Allow-Origin;
	access-200: 200響應都有 Access-Control-Allow-Origin:*, 304響應 沒 有 Access-Control-Allow-Origin;
</pre>
<input type="button" onclick='load("http://73a8eb41cb.a.passageway.io/access")' value="access" />
<input type="button" onclick='load("http://73a8eb41cb.a.passageway.io/access-non")' value="access-non" />
<input type="button" onclick='load("http://73a8eb41cb.a.passageway.io/access-200")' value="access-200" />
</body>
</html>

clojureweb

(ns base-web.handler
  (:require [compojure.core :refer :all]
            [compojure.route :as route]
            [ring.middleware.defaults :refer [wrap-defaults site-defaults]]
            [clojure.pprint :as log]))

(def my-route
    (-> site-defaults
        (assoc-in [:security :anti-forgery] false)
        (assoc-in [:params] false)
        ))

(defn print-req [req]
    (println )
    (log/pprint my-route)
    (log/pprint req)
    (log/pprint (slurp (:body req)))
    (println "done"))

(defn access-200 [req]
    (let [etag "e-access-200"]
    (if (not= etag (get-in req [:headers "if-none-match"]))
        (do (println "200")
            {:status 200,
             :headers {"Content-Type" "application/json", "Access-Control-Allow-Origin" "*", "ETag" etag}
             :body "{\"success\":true, \"frame\": \"ring\"}"})
         (do (println "304")
            {:status 304,
                :headers {"Content-Type" "application/json", "ETag" etag}}))))

(defn access-non [req]
    (let [etag "e-access-non"]
    (if (not= etag (get-in req [:headers "if-none-match"]))
        (do (println "200")
            {:status 200,
             :headers {"Content-Type" "application/json", "ETag" etag}
             :body "{\"success\":true, \"frame\": \"ring\"}"})
         (do (println "304")
            {:status 304,
                :headers {"Content-Type" "application/json", "ETag" etag}}))))

(defn access [req]
    (let [etag "e-access"]
    (if (not= etag (get-in req [:headers "if-none-match"]))
        (do (println "200")
            {:status 200,
             :headers {"Content-Type" "application/json", "Access-Control-Allow-Origin" "*", "ETag" etag}
             :body "{\"success\":true, \"frame\": \"ring\"}"})
         (do (println "304")
            {:status 304,
                :headers {"Content-Type" "application/json", "ETag" etag}}))))

(defroutes app-routes
  (GET "/access-200" req (access-200 req) )
  (GET "/access-non" req (access-non req) )
  (GET "/access" req (access req) )
  (ANY "*" req
    (print-req req)
    "{\"success\":true, \"frame\": \"compojure\"}")
  (route/not-found "Not Found"))


(def app
  (wrap-defaults app-routes my-route))

;; lein ring server [<port>]
相關文章
相關標籤/搜索