一、Node官网下载pkg安装包,点击安装便可,安装包包含nodejs和npm(node package manager)
二、安装完成后,在命令终端输入html
curl http://npmjs.org/install.sh | sh
三、这个npm.js其实是Node.js的套件管理工具,执行完成以后咱们继续执行命令,更新npm:前端
sudo npm update npm -g
四、查看npm是否安装成功vue
npm -v
建立node 服务和web 端通讯须要用到http、https
若是访问文件须要用到fsnode
一、新建一个文件server.js
二、引入对应所需的依赖ios
var http=require('http'); var https = require('https') var fs = require('fs');
三、建立http 服务web
const server = http.createServer((req, res) => { // 这里能够设置header信息, 如跨域等信息 }).listen(8090)
四、启动服务npm
以上内容便可启动服务,能够经过node 的命令启动服务,默认域名是 http://127.0.0.1:8090
便可访问node 服务,能够对建立的服务添加一些监听
request 监听有两个参数,req 请求 和 res 响应
添加监听的方法, 如文件的请求,方法接口的请求json
const requestHandle = (req, res) => { // 设置一些 请求处理的方法 if (url === '/index') { // 文件的请求 res.writeHead(200, { 'Content-Type': 'text/html' }) fs.readFile('index.html', 'utf8', function (err, data) { if (err) throw err res.end(data) }) } else if (url === '/api') { // 接口请求 req.on('data', function (pamas) { console.log('8888888') // 在此作一些数据的处理 }) req.on('end', () => { // 请求结束 }) } else { // 404 请求 res.write('404') res.end() } }
添加监听axios
server.on('request', requestHandle)
console.log 的内容均在服务终端上会展现出来api
以钉钉报警为例,因为前端不支持直接请求钉钉报警接口,须要经过服务来转发请求,便有了以下例子
const dingdingHandle = (str, callback) => { // 钉钉报警传参 const postData = { msgtype: "text", text: { content: str }, "at": { "atMobiles": [ "155********" ], "isAtAll": false } }; const options = { hostname: 'oapi.dingtalk.com', path: '/robot/send?access_token=d529ae67dcc82157032c3c84bad0c450a2329692adca0e00000efcbddf2898', method: 'POST', headers: { 'Content-Type': 'application/json;charset=UTF-8', } }; const req = https.request(options, (res) => { console.log(`状态码: ${res.statusCode}`); console.log(`响应头: ${JSON.stringify(res.headers)}`); res.setEncoding('utf8'); res.on('data', (chunk) => { console.log(`响应主体: ${chunk}`); callback(chunk) }); res.on('end', () => { console.log('响应中已无数据。'); }); }); req.on('error', (e) => { console.error(`请求遇到问题: ${e.message}`); }); // 写入数据到请求主体 req.write(JSON.stringify(postData)); req.end(); }
这个方法在接收到对应的请求时调用
在服务端request 监听的回调中对应的接口中调用
... } else if (url === '/api') { // 接口请求 req.on('data', function (params) { console.log('8888888') // 请求钉钉报警接口,并将响应返回的参数推到前端页面的请求中 dingdingHandle(params.toString, (data) => { res.end(data) }) }) req.on('end', () => { // 请求结束 }) } else { // 404 请求 ...
前端页面请求,业务场景是页面报错时监听
window.onerror = function (msg, url, line, column, error) { let data = { msg: msg, url: url, line: line, col: column } console.log(data, '--------------'); let xhr = new XMLHttpRequest() // xhr.withCredentials = true xhr.open('POST', 'http://127.0.0.1:8090/api', true) xhr.setRequestHeader("Content-type","application/x-www-form-urlencoded"); xhr.send(JSON.stringify(data)) xhr.onreadystatechange = function () { xhr.readyState === 4 && xhr.status === 200 && console.log('ok', xhr.responseText) } }
当前前端页面的服务为http://127.0.0.1:8080/,和node 服务存在跨域,此时须要在建立服务的时候,添加header 设置
const server = http.createServer(function(req,res) { res.setHeader('Access-Control-Allow-Origin', '*') res.setHeader('Access-Control-Allow-Oring', 'http://127.0.0.1:8080/') res.setHeader('Access-Control-Allow-Credentials', true) }).listen(8090);
注意:
若是是vue 项目中的axios, 须要手动设置header 以及强转化传输的数据
import axios from 'axios' import qs from 'qs' axios({ method: 'post', url: 'http://127.0.0.1:8090/api', data: errorData, withCredentials: false, headers: { 'Content-Type': 'application/x-www-form-urlencoded' }, transformRequest: [sdata => { // 强转数据格式 console.log(sdata, qs.stringify(sdata)) return qs.stringify(sdata) }] }).then(res => { console.log('res=>', res) })