Installations
npm install xhr2
Releases
Unable to fetch releases
Developer
pwnall
Developer Guide
Module System
CommonJS, UMD
Min. Node Version
>= 6
Typescript Support
No
Node Version
15.8.0
NPM Version
7.5.1
Statistics
104 Stars
60 Commits
41 Forks
5 Watching
5 Branches
7 Contributors
Updated on 13 Sept 2024
Bundle Size
166.00 B
Minified
148.00 B
Minified + Gzipped
Languages
CoffeeScript (98.51%)
HTML (1.29%)
Vim Script (0.16%)
JavaScript (0.04%)
Total Downloads
Cumulative downloads
Total Downloads
183,999,681
Last day
-6.8%
182,797
Compared to previous day
Last week
2.7%
969,486
Compared to previous week
Last month
6.1%
4,020,824
Compared to previous month
Last year
23.6%
43,876,819
Compared to previous year
Daily Downloads
Weekly Downloads
Monthly Downloads
Yearly Downloads
XMLHttpRequest Emulation for node.js
This is an npm package that implements the W3C XMLHttpRequest specification on top of the node.js APIs.
Supported Platforms
This library is tested against the following platforms.
Keep in mind that the versions above are not hard requirements.
Installation and Usage
The preferred installation method is to add the library to the dependencies
section in your package.json
.
1{ 2 "dependencies": { 3 "xhr2": "*" 4 } 5}
Alternatively, npm
can be used to install the library directly.
1npm install xhr2
Once the library is installed, require
-ing it returns the XMLHttpRequest
constructor.
1var XMLHttpRequest = require('xhr2');
The other objects that are usually defined in an XHR environment are hanging
off of XMLHttpRequest
.
1var XMLHttpRequestUpload = XMLHttpRequest.XMLHttpRequestUpload;
MDN (the Mozilla Developer Network) has a great intro to XMLHttpRequest.
This library's CoffeeDocs can be used as quick reference to the XMLHttpRequest specification parts that were implemented.
Features
The following standard features are implemented.
http
andhttps
URI protocols- Basic authentication according to the XMLHttpRequest specification
- request and response header management
send()
accepts the following data types: String, ArrayBufferView, ArrayBuffer (deprecated in the standard)responseType
values:text
,json
,arraybuffer
readystatechange
and download progress eventsoverrideMimeType()
abort()
timeout
- automated redirection following
The following node.js extensions are implemented.
send()
accepts a node.js Buffer- Setting
responseType
tobuffer
produces a node.js Buffer nodejsSet
does XHR network configuration that is not exposed in browsers, for security reasons
The following standard features are not implemented.
- FormData
- Blob
file://
URIsdata:
URIs- upload progress events
- synchronous operation
- Same-origin policy checks and CORS
- cookie processing
Versioning
The library aims to implement the W3C XMLHttpRequest specification, so the library's API will always be a (hopefully growing) subset of the API in the specification.
Development
The following commands will get the source tree in a node-xhr2/
directory and
build the library.
1git clone git://github.com/pwnall/node-xhr2.git 2cd node-xhr2 3npm install 4npm pack
Installing CoffeeScript globally will let you type cake
instead of
node_modules/.bin/cake
1npm install -g coffeescript
The library comes with unit tests that exercise the XMLHttpRequest API.
1cake test
The tests themselves can be tested by running them in a browser environment, where a different XMLHttpRequest implementation is available. Both Google Chrome and Firefox deviate from the specification in small ways, so it's best to run the tests in both browsers and mentally compute an intersection of the failing tests.
1cake webtest 2BROWSER=firefox cake webtest
Copyright and License
The library is Copyright (c) 2013 Victor Costan, and distributed under the MIT License.
No vulnerabilities found.
Reason
no binaries found in the repo
Reason
license file detected
Details
- Info: project has a license file: LICENSE.txt:0
- Info: FSF or OSI recognized license: MIT License: LICENSE.txt:0
Reason
0 existing vulnerabilities detected
Reason
Found 6/30 approved changesets -- score normalized to 2
Reason
0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0
Reason
no effort to earn an OpenSSF best practices badge detected
Reason
security policy file not detected
Details
- Warn: no security policy file detected
- Warn: no security file to analyze
- Warn: no security file to analyze
- Warn: no security file to analyze
Reason
project is not fuzzed
Details
- Warn: no fuzzer integrations found
Reason
branch protection not enabled on development/release branches
Details
- Warn: branch protection not enabled for branch 'master'
Reason
SAST tool is not run on all commits -- score normalized to 0
Details
- Warn: 0 commits out of 6 are checked with a SAST tool
Score
3.3
/10
Last Scanned on 2024-11-18
The Open Source Security Foundation is a cross-industry collaboration to improve the security of open source software (OSS). The Scorecard provides security health metrics for open source projects.
Learn More