Improve this Doc View Source $http
- $httpProvider
- service in module ng
Overview
The $http
service is a core AngularJS service that facilitates communication with the remote HTTP servers via the browser's XMLHttpRequest object or via JSONP.
For unit testing applications that use $http
service, see $httpBackend mock.
For a higher level of abstraction, please check out the $resource service.
The $http API is based on the deferred/promise APIs exposed by the $q service. While for simple usage patterns this doesn't matter much, for advanced usage it is important to familiarize yourself with these APIs and the guarantees they provide.
General usage
The $http
service is a function which takes a single argument — a configuration object — that is used to generate an HTTP request and returns a promise that is resolved (request success) or rejected (request failure) with a response object.
// Simple GET request example: $http({ method: 'GET', url: '/someUrl' }).then(function successCallback(response) { // this callback will be called asynchronously // when the response is available }, function errorCallback(response) { // called asynchronously if an error occurs // or server returns response with an error status. });
Shortcut methods
Shortcut methods are also available. All shortcut methods require passing in the URL, and request data must be passed in for POST/PUT requests. An optional config can be passed as the last argument.
$http.get('/someUrl', config).then(successCallback, errorCallback); $http.post('/someUrl', data, config).then(successCallback, errorCallback);
Complete list of shortcut methods:
Writing Unit Tests that use $http
When unit testing (using ngMock), it is necessary to call $httpBackend.flush() to flush each pending request using trained responses.
$httpBackend.expectGET(...); $http.get(...); $httpBackend.flush();
Setting HTTP Headers
The $http service will automatically add certain HTTP headers to all requests. These defaults can be fully configured by accessing the $httpProvider.defaults.headers
configuration object, which currently contains this default configuration:
-
$httpProvider.defaults.headers.common
(headers that are common for all requests):Accept: application/json, text/plain, */*
-
$httpProvider.defaults.headers.post
: (header defaults for POST requests)Content-Type: application/json
-
$httpProvider.defaults.headers.put
(header defaults for PUT requests)Content-Type: application/json
To add or overwrite these defaults, simply add or remove a property from these configuration objects. To add headers for an HTTP method other than POST or PUT, simply add a new object with the lowercased HTTP method name as the key, e.g. $httpProvider.defaults.headers.get = { 'My-Header' : 'value' }
.
The defaults can also be set at runtime via the $http.defaults
object in the same fashion. For example:
module.run(function($http) { $http.defaults.headers.common.Authorization = 'Basic YmVlcDpib29w'; });
In addition, you can supply a headers
property in the config object passed when calling $http(config)
, which overrides the defaults without changing them globally.
To explicitly remove a header automatically added via $httpProvider.defaults.headers on a per request basis, Use the headers
property, setting the desired header to undefined
. For example:
var req = { method: 'POST', url: 'http://example.com', headers: { 'Content-Type': undefined }, data: { test: 'test' } } $http(req).then(function(){...}, function(){...});
Transforming Requests and Responses
Both requests and responses can be transformed using transformation functions: transformRequest
and transformResponse
. These properties can be a single function that returns the transformed value (function(data, headersGetter, status)
) or an array of such transformation functions, which allows you to push
or unshift
a new transformation function into the transformation chain.
data
parameter before it is passed into the transformRequest
pipeline. That means changes to the properties of data
are not local to the transform function (since Javascript passes objects by reference). For example, when calling $http.get(url, $scope.myObject)
, modifications to the object's properties in a transformRequest function will be reflected on the scope and in any templates where the object is data-bound. To prevent this, transform functions should have no side-effects. If you need to modify properties, it is recommended to make a copy of the data, or create new object to return. Default Transformations
The $httpProvider
provider and $http
service expose defaults.transformRequest
and defaults.transformResponse
properties. If a request does not provide its own transformations then these will be applied.
You can augment or replace the default transformations by modifying these properties by adding to or replacing the array.
AngularJS provides the following default transformations:
Request transformations ($httpProvider.defaults.transformRequest
and $http.defaults.transformRequest
) is an array with one function that does the following:
- If the
data
property of the request configuration object contains an object, serialize it into JSON format.
Response transformations ($httpProvider.defaults.transformResponse
and $http.defaults.transformResponse
) is an array with one function that does the following:
- If XSRF prefix is detected, strip it (see Security Considerations section below).
- If the
Content-Type
isapplication/json
or the response looks like JSON, deserialize it using a JSON parser.
Overriding the Default Transformations Per Request
If you wish to override the request/response transformations only for a single request then provide transformRequest
and/or transformResponse
properties on the configuration object passed into $http
.
Note that if you provide these properties on the config object the default transformations will be overwritten. If you wish to augment the default transformations then you must include them in your local transformation array.
The following code demonstrates adding a new response transformation to be run after the default response transformations have been run.
function appendTransform(defaults, transform) { // We can't guarantee that the default transformation is an array defaults = angular.isArray(defaults) ? defaults : [defaults]; // Append the new transformation to the defaults return defaults.concat(transform); } $http({ url: '...', method: 'GET', transformResponse: appendTransform($http.defaults.transformResponse, function(value) { return doTransform(value); }) });
Caching
$http
responses are not cached by default. To enable caching, you must set the config.cache value or the default cache value to TRUE or to a cache object (created with $cacheFactory
). If defined, the value of config.cache takes precedence over the default cache value.
In order to:
- cache all responses - set the default cache value to TRUE or to a cache object
- cache a specific response - set config.cache value to TRUE or to a cache object
If caching is enabled, but neither the default cache nor config.cache are set to a cache object, then the default $cacheFactory("$http")
object is used.
The default cache value can be set by updating the $http.defaults.cache
property or the $httpProvider.defaults.cache
property.
When caching is enabled, $http
stores the response from the server using the relevant cache object. The next time the same request is made, the response is returned from the cache without sending a request to the server.
Take note that:
- Only GET and JSONP requests are cached.
- The cache key is the request URL including search parameters; headers are not considered.
- Cached responses are returned asynchronously, in the same way as responses from the server.
- If multiple identical requests are made using the same cache, which is not yet populated, one request will be made to the server and remaining requests will return the same response.
- A cache-control header on the response does not affect if or how responses are cached.
Interceptors
Before you start creating interceptors, be sure to understand the $q and deferred/promise APIs.
For purposes of global error handling, authentication, or any kind of synchronous or asynchronous pre-processing of request or postprocessing of responses, it is desirable to be able to intercept requests before they are handed to the server and responses before they are handed over to the application code that initiated these requests. The interceptors leverage the promise APIs to fulfill this need for both synchronous and asynchronous pre-processing.
The interceptors are service factories that are registered with the $httpProvider
by adding them to the $httpProvider.interceptors
array. The factory is called and injected with dependencies (if specified) and returns the interceptor.
There are two kinds of interceptors (and two kinds of rejection interceptors):
-
request
: interceptors get called with a http config object. The function is free to modify theconfig
object or create a new one. The function needs to return theconfig
object directly, or a promise containing theconfig
or a newconfig
object. -
requestError
: interceptor gets called when a previous interceptor threw an error or resolved with a rejection. -
response
: interceptors get called with httpresponse
object. The function is free to modify theresponse
object or create a new one. The function needs to return theresponse
object directly, or as a promise containing theresponse
or a newresponse
object. -
responseError
: interceptor gets called when a previous interceptor threw an error or resolved with a rejection.
// register the interceptor as a service $provide.factory('myHttpInterceptor', function($q, dependency1, dependency2) { return { // optional method 'request': function(config) { // do something on success return config; }, // optional method 'requestError': function(rejection) { // do something on error if (canRecover(rejection)) { return responseOrNewPromise } return $q.reject(rejection); }, // optional method 'response': function(response) { // do something on success return response; }, // optional method 'responseError': function(rejection) { // do something on error if (canRecover(rejection)) { return responseOrNewPromise } return $q.reject(rejection); } }; }); $httpProvider.interceptors.push('myHttpInterceptor'); // alternatively, register the interceptor via an anonymous factory $httpProvider.interceptors.push(function($q, dependency1, dependency2) { return { 'request': function(config) { // same as above }, 'response': function(response) { // same as above } }; });
Security Considerations
When designing web applications, consider security threats from:
Both server and the client must cooperate in order to eliminate these threats. AngularJS comes pre-configured with strategies that address these issues, but for this to work backend server cooperation is required.
JSON Vulnerability Protection
A JSON vulnerability allows third party website to turn your JSON resource URL into JSONP request under some conditions. To counter this your server can prefix all JSON requests with following string ")]}',\n"
. AngularJS will automatically strip the prefix before processing it as JSON.
For example if your server needs to return:
['one','two']
which is vulnerable to attack, your server can return:
)]}', ['one','two']
AngularJS will strip the prefix, before processing the JSON.
Cross Site Request Forgery (XSRF) Protection
XSRF is an attack technique by which the attacker can trick an authenticated user into unknowingly executing actions on your website. AngularJS provides a mechanism to counter XSRF. When performing XHR requests, the $http service reads a token from a cookie (by default, XSRF-TOKEN
) and sets it as an HTTP header (by default X-XSRF-TOKEN
). Since only JavaScript that runs on your domain could read the cookie, your server can be assured that the XHR came from JavaScript running on your domain.
To take advantage of this, your server needs to set a token in a JavaScript readable session cookie called XSRF-TOKEN
on the first HTTP GET request. On subsequent XHR requests the server can verify that the cookie matches the X-XSRF-TOKEN
HTTP header, and therefore be sure that only JavaScript running on your domain could have sent the request. The token must be unique for each user and must be verifiable by the server (to prevent the JavaScript from making up its own tokens). We recommend that the token is a digest of your site's authentication cookie with a salt for added security.
The header will — by default — not be set for cross-domain requests. This prevents unauthorized servers (e.g. malicious or compromised 3rd-party APIs) from gaining access to your users' XSRF tokens and exposing them to Cross Site Request Forgery. If you want to, you can trust additional origins to also receive the XSRF token, by adding them to xsrfTrustedOrigins. This might be useful, for example, if your application, served from example.com
, needs to access your API at api.example.com
. See $httpProvider.xsrfTrustedOrigins for more details.
Only trusted origins that you have control over and make sure you understand the implications of doing so.
The name of the cookie and the header can be specified using the xsrfCookieName
and xsrfHeaderName
properties of either $httpProvider.defaults
at config-time, $http.defaults
at run-time, or the per-request config object.
In order to prevent collisions in environments where multiple AngularJS apps share the same domain or subdomain, we recommend that each application uses a unique cookie name.
Dependencies
Usage
$http(config);
Arguments
Param | Type | Details |
---|---|---|
config | object | Object describing the request to be made and how it should be processed. The object has following properties:
|
Returns
HttpPromise |
A The response object has these properties:
A response status code between 200 and 299 is considered a success status and will result in the success callback being called. Any response status code outside of that range is considered an error status and will result in the error callback being called. Also, status codes less than -1 are normalized to zero. -1 usually means the request was aborted, e.g. using a Note that if the response is a redirect, XMLHttpRequest will transparently follow it, meaning that the outcome (success or error) will be determined by the final response status code. |
Methods
-
get(url, [config]);
Shortcut method to perform
GET
request.Parameters
Param Type Details url string
TrustedObject
Absolute or relative URL of the resource that is being requested; or an object created by a call to
$sce.trustAsResourceUrl(url)
.config (optional)Object
Optional configuration object. See
$http()
arguments.Returns
HttpPromise
A Promise that will be resolved or rejected with a response object. See
$http()
return value. -
delete(url, [config]);
Shortcut method to perform
DELETE
request.Parameters
Param Type Details url string
TrustedObject
Absolute or relative URL of the resource that is being requested; or an object created by a call to
$sce.trustAsResourceUrl(url)
.config (optional)Object
Optional configuration object. See
$http()
arguments.Returns
HttpPromise
A Promise that will be resolved or rejected with a response object. See
$http()
return value. -
head(url, [config]);
Shortcut method to perform
HEAD
request.Parameters
Param Type Details url string
TrustedObject
Absolute or relative URL of the resource that is being requested; or an object created by a call to
$sce.trustAsResourceUrl(url)
.config (optional)Object
Optional configuration object. See
$http()
arguments.Returns
HttpPromise
A Promise that will be resolved or rejected with a response object. See
$http()
return value. -
jsonp(url, [config]);
Shortcut method to perform
JSONP
request.Note that, since JSONP requests are sensitive because the response is given full access to the browser, the url must be declared, via
$sce
as a trusted resource URL. You can trust a URL by adding it to the trusted resource URL list via$sceDelegateProvider.trustedResourceUrlList
or by explicitly trusting the URL via$sce.trustAsResourceUrl(url)
.You should avoid generating the URL for the JSONP request from user provided data. Provide additional query parameters via
params
property of theconfig
parameter, rather than modifying the URL itself.JSONP requests must specify a callback to be used in the response from the server. This callback is passed as a query parameter in the request. You must specify the name of this parameter by setting the
jsonpCallbackParam
property on the request config object.$http.jsonp('some/trusted/url', {jsonpCallbackParam: 'callback'})
You can also specify a default callback parameter name in
$http.defaults.jsonpCallbackParam
. Initially this is set to'callback'
.You can no longer use theJSON_CALLBACK
string as a placeholder for specifying where the callback parameter value should go.If you would like to customise where and how the callbacks are stored then try overriding or decorating the
$jsonpCallbacks
service.Parameters
Param Type Details url string
TrustedObject
Absolute or relative URL of the resource that is being requested; or an object created by a call to
$sce.trustAsResourceUrl(url)
.config (optional)Object
Optional configuration object. See
$http()
arguments.Returns
HttpPromise
A Promise that will be resolved or rejected with a response object. See
$http()
return value. -
post(url, data, [config]);
Shortcut method to perform
POST
request.Parameters
Param Type Details url string
Relative or absolute URL specifying the destination of the request
data *
Request content
config (optional)Object
Optional configuration object. See
$http()
arguments.Returns
HttpPromise
A Promise that will be resolved or rejected with a response object. See
$http()
return value. -
put(url, data, [config]);
Shortcut method to perform
PUT
request.Parameters
Param Type Details url string
Relative or absolute URL specifying the destination of the request
data *
Request content
config (optional)Object
Optional configuration object. See
$http()
arguments.Returns
HttpPromise
A Promise that will be resolved or rejected with a response object. See
$http()
return value. -
patch(url, data, [config]);
Shortcut method to perform
PATCH
request.Parameters
Param Type Details url string
Relative or absolute URL specifying the destination of the request
data *
Request content
config (optional)Object
Optional configuration object. See
$http()
arguments.Returns
HttpPromise
A Promise that will be resolved or rejected with a response object. See
$http()
return value.
Properties
-
pendingRequests
Array.<Object>
Array of config objects for currently pending requests. This is primarily meant to be used for debugging purposes.
-
defaults
Runtime equivalent of the
$httpProvider.defaults
property. Allows configuration of default headers, withCredentials as well as request and response transformations.See "Setting HTTP Headers" and "Transforming Requests and Responses" sections above.
Example
© 2010–2020 Google, Inc.
Licensed under the Creative Commons Attribution License 3.0.
https://code.angularjs.org/1.8.2/docs/api/ng/service/$http