缓存AngularJS JSONP请求

最近在用angularjs写了一个github page博客,要用的github的jsonp api来获取文件列表。

这是github的api: GET /repos/:owner/:repo/contents/:path

我想要在AngularJS缓存下JSONP请求。一开始代码是这样写的: $http.jsonp("https://api.github.com/repos/cs1707/blog/posts?callback=ANGULAR_CALLBACK",{ cache : true}); 但是奇怪的是{ cache : true } 并没有起作用。在chrome查看网络请求,发现有这样几个请求

https://api.github.com/repos/cs1707/blog/contents/posts?callback=angular.callbacks._0
https://api.github.com/repos/cs1707/blog/contents/posts?callback=angular.callbacks._1
https://api.github.com/repos/cs1707/blog/contents/posts?callback=angular.callbacks._2

说明AngularJS对于JSONP请求每次都生成不同的url。

下面用$cacheFactory缓存JSONP请求。

app.service("GBlog", ["$q", "$http", "$cacheFactory", function($q, $http, $cacheFactory) {
		var cacheEngine = $cacheFactory("list"); // caches name
		this.getList = function(url){
			var cache = cacheEngine.get("list");
			var d = $q.defer();
			if(cache) {
				// get from cache
				d.resolve(cache);
			} else {
				$http.jsonp(url,{cache: true})
					.success(function(data){
						// store to cache
						cacheEngine.put("list", data);
						d.resolve(data);
					})
					.error(function(error){
						d.reject(error);
					});
			}
			return d.promise;
		}

在chrome查看网络请求。可以看到只生成这样一个请求https://api.github.com/repos/cs1707/blog/contents/posts?callback=angular.callbacks._0 OK 缓存JSONP请求成功。