Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
@chunpu/http
Advanced tools
Promise Based request / fetch / http For Real Project, Support multiple platforms
request / fetch / http For Real Project, Support multiple platforms
npm i min-fetch
Inspired by axios
Send Http Request just like axios in 微信小程序
, 快应用
, jQuery
, or XMLHttpRequest
by default
Let's have the Same Experience with Request Data😜
import http from 'min-fetch'
http.init({
baseURL: 'https://my.domain'
})
http.get('/data').then(({data}) => {
console.log(data)
})
const anotherHttp = http.create({
baseURL: 'https://my.domain'
})
.get(url, config)
.delete(url, config)
.head(url, config)
.options(url, config)
Careful! There is no such api like
.get(url, params)
.post(url, data, config)
.put(url, data, config)
.patch(url, data, config)
.request(config)
.request(url, config)
All config param is not required
data
data for request bodyheaders
request headersmethod
request http method, default GET
params
the url querystring objecttimeout
request timeoutwithCredentials
whether use cors, default false
data will be handled by the value of headers['content-type']
, Plain Object data will be auto stringify
application/json
will JSON.stringify
the data objectapplication/x-www-form-urlencoded
will qs.stringify
the data objectdata also support FormData, Blob, String
data
response data, will always try to JSON.parse
, because most server not respect the response mimeheaders
name: value
headers, all header names are lower casedstatus
status code, numberconfig
the request objectimport http from 'min-fetch'
http.init({
baseURL: 'https://my.domain',
wx: wx
})
http.get('/data').then(({data}) => {
console.log(data)
})
请通过 npm 安装, 参见 npm 支持
import http from 'min-fetch'
import fetch from '@system.fetch'
http.init({
baseURL: 'https://my.domain',
quickapp: fetch
})
记得在 manifest.json
文件中加入权限
"features": [
{ "name": "system.network" },
{ "name": "system.fetch" }
]
const axios = require('axios')
import http from 'min-fetch'
http.init({
baseURL: 'https://my.domain',
axios: axios
})
import http from 'min-fetch'
http.init({
baseURL: 'https://my.domain',
jQuery: $
})
// support axios style
http.defaults.baseURL = 'https://my.domain'
http.defaults.timeout = 1000 * 20
// can also use http.init
http.init({
baseURL: 'https://my.domain',
timeout: 1000 * 20
})
Config default Post request
Content-Type
default is JSON
Always stringify Data to JSON
http.defaults.headers.post['Content-Type'] = 'application/json'
Always stringify Data to querystring
, which can really work not like axios...
http.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded'
import http from 'min-fetch'
http.init({
baseURL: 'https://my.domain'
})
http.interceptors.request.use(config => {
// Do something before request is sent
return config
})
http.interceptors.response.use(response => {
// Do something with response
return response
})
Assume the my.domain
service always return data like this
{
code: 0,
message: 'ok',
data: {
key: 'value'
}
}
import http from 'min-fetch'
http.init({
baseURL: 'https://my.domain'
})
http.interceptors.response.use(response => {
if (typeof response.data === 'object') {
// always spread the response data for directly usage
Object.assign(response, response.data)
}
return response
})
http.post('/user/1024', {
name: 'Tony'
}).then(({data, code, message}) => {
if (code === 0) {
return data
} else {
console.error('error', message)
}
})
import http from 'min-fetch'
Vue.prototype.$http = http
// in vue component file
submit () {
this.$http.post('/user/1024', {name: 'Tony'}).then(({data}) => {
this.user = data
})
}
You can stringify query string by
import http from 'min-fetch'
http.qs.stringify({
query: 'string'
})
// => 'query=string'
FAQs
Promise Based request / fetch / http For Real Project, Support multiple platforms
The npm package @chunpu/http receives a total of 9 weekly downloads. As such, @chunpu/http popularity was classified as not popular.
We found that @chunpu/http demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.