data:image/s3,"s3://crabby-images/4c2e4/4c2e40ecfd250d97aecce3ea65c15912728b3827" alt="phin logo"
The ultra-lightweight Node.js HTTP client
Full documentation | GitHub | NPM
Simple Usage
const p = require('phin')
const res = await p('https://ethanent.me')
console.log(res.body)
Note that the above should be in an async context! phin also provides an unpromisified version of the library.
Install
npm install agent-phin
Why phin?
phin is trusted by some really important projects. The hundreds of contributors at Less, for example, depend on phin as part of their development process.
Also, phin is super lightweight. Like 99.8% smaller than request lightweight. To compare to other libraries, see phin vs. the Competition.
Quick Demos
Simple POST:
await p({
url: 'https://ethanent.me',
method: 'POST',
data: {
hey: 'hi'
}
})
Using HTTP request agent:
const HttpsProxyAgent = require('https-proxy-agent');
const proxy = 'http://localhost:8008';
const agent = new HttpsProxyAgent(proxy);
await p({
url: 'https://ethanent.me',
method: 'POST',
data: {
hey: 'hi'
},
agent: agent
})
Unpromisified Usage
const p = require('phin').unpromisified
p('https://ethanent.me', (err, res) => {
if (!err) console.log(res.body)
})
Simple parsing of JSON:
const res = await p({
url: 'https://ethanent.me/name',
parse: 'json'
})
console.log(res.body.first)
Default options
const ppostjson = p.defaults({
'method': 'POST',
'parse': 'json',
'timeout': 2000
})
const res = await ppostjson('https://ethanent.me/somejson')
Full Documentation
See the phin documentation.
phin vs. the Competition
phin is a very lightweight library, yet it contains all of the common HTTP client features included in competing libraries!
Here's a size comparison table:
Package | Size |
---|
request | data:image/s3,"s3://crabby-images/34f36/34f368860fb40e317639cfbe84cb9c6913f5bbae" alt="request package size" |
superagent | data:image/s3,"s3://crabby-images/3402f/3402f206737ff7a20a03c3fab3b1e1751efb4ce8" alt="superagent package size" |
isomorphic-fetch | data:image/s3,"s3://crabby-images/ae279/ae279b47a063f55ea78b1c72c44b368d4da33ffc" alt="isomorphic-fetch package size" |
axios | data:image/s3,"s3://crabby-images/35926/35926b91f957be54187fb8e78526e4cf6f5509f2" alt="axios package size" |
got | data:image/s3,"s3://crabby-images/92242/92242203bc80b5c6701f0cc306d58c887894a005" alt="got package size" |
r2 | data:image/s3,"s3://crabby-images/b7a81/b7a810408fd2bc8400af26e4bb4ec88fb5a81fce" alt="r2 package size" |
node-fetch | data:image/s3,"s3://crabby-images/64b38/64b3863810dd3a0659fb6568d8010b035ca2b66c" alt="node-fetch package size" |
snekfetch | data:image/s3,"s3://crabby-images/f7e64/f7e64e56b1bf28ce7ca3ff845b47d1f7ead35d9c" alt="snekfetch package size" |
phin | data:image/s3,"s3://crabby-images/e75a2/e75a2b90196bb49e7f51f6d4faaad35f382e4acc" alt="phin package size" |