小編給大家分享一下nodejs怎么實現(xiàn)百度輿情接口,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)自2013年起,先為廣東等服務(wù)建站,廣東等地企業(yè),進行企業(yè)商務(wù)咨詢服務(wù)。為廣東企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
具體如下:
const URL = require('url'); const http = require('http'); const https = require('https'); const qs = require('querystring'); let trends = exports; trends.getInstance = function () { return new Trends; } function Trends() { this.expireTime = 1800; this.accessKey = 'xxxxxxxx'; this.secretKey = 'xxxxxxxx'; this.userKey = 'xxxxxxxx'; this.userSecret = 'xxxxxxxx'; this.host = 'trends.baidubce.com'; this.timestamp = _.time(); this.utcTimestamp = _.utcTime(); } Trends.prototype.request = async function (method, uri, params) { method = method.toUpperCase(); let token = this.getToken(); let headers = this.getHeaders(method, uri); params = Object.assign({}, params || {}, { 'user_key': this.userKey, 'token': token, 'timestamp': this.timestamp }); let url = `http://${this.host}${uri}`; return await this.httpRequest(method, url, params, headers); } Trends.prototype.getHeaders = function (method, uri) { let authorization = this.getAuthorization(method, uri); return { 'Content-Type': 'application/x-www-form-urlencoded', 'Host': this.host, 'x-bce-date': this.utcTimestamp, 'Authorization': authorization, }; } Trends.prototype.getAuthorization = function (method, uri) { let authString = `bce-auth-v1/${this.accessKey}/${this.utcTimestamp}/${this.expireTime}`; let signinKey = _.hmac(authString, this.secretKey, 'sha256'); let header = { 'host': this.host, 'x-bce-date': _.urlencode(this.utcTimestamp) }; let headerArr = []; for (let name in header) { let val = header[name]; headerArr.push(`${name}:${val}`); } let headerKeyStr = Object.keys(header).sort().join(';'); let requestStr = `${method}\n${uri}\n\n${headerArr.join('\n')}`; let signautre = _.hmac(requestStr, signinKey, 'sha256'); return `${authString}/${headerKeyStr}/${signautre}`; } Trends.prototype.getToken = function () { return _.hmac(this.userKey + this.timestamp, this.userSecret); } Trends.prototype.httpRequest = async function (method, url, params, headers) { let urlObj = URL.parse(url); let protocol = urlObj.protocol; let options = { hostname: urlObj.hostname, port: urlObj.port, path: urlObj.path, method: method, headers: headers, timeout: 10000, }; let postData = qs.stringify(params || {}); return new Promise((resolve, reject) => { let req = (protocol == 'http:' ? http : https).request(options, (res) => { let chunks = []; res.on('data', (data) => { chunks.push(data); }); res.on('end', () => { let buffer = Buffer.concat(chunks); let encoding = res.headers['content-encoding']; if (encoding == 'gzip') { zlib.unzip(buffer, function (err, decoded) { resolve(decoded.toString()); }); } else if (encoding == 'deflate') { zlib.inflate(buffer, function (err, decoded) { resolve(decoded.toString()); }); } else { resolve(buffer.toString()); } }); }); req.on('error', (e) => { _.error('request error', method, url, params, e); resolve(''); }); req.on("timeout", (e) => { _.error('request timeout', method, url, params, e); resolve(''); }) if (method.toUpperCase() == 'POST') { req.write(postData); } req.end(); }); }
module.exports = function () { return new Script; } function Script() {} Script.prototype.run = async function () { let rst = this.getTaskList(); console.log(rst); } Script.prototype.getTaskList = async function () { let params = {}; let method = 'post'; let uri = '/openapi/getTasklist'; let rst = await _.trends.getInstance().request(method, uri, params); return rst; }
以上是“nodejs怎么實現(xiàn)百度輿情接口”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
文章題目:nodejs怎么實現(xiàn)百度輿情接口
標題網(wǎng)址:http://bm7419.com/article12/gejggc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、域名注冊、定制開發(fā)、網(wǎng)站營銷、建站公司、App設(shè)計
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)