zoukankan      html  css  js  c++  java
  • node-request模块

    node中,http模块也可作为客户端使用(发送请求),第三方模块request对其使用方法进行了封装,操作更方便!所以来介绍一下request模块

    1.安装request模块
    cnpm install request --save
    

    基本形式

    //request(options,callback)
    
    request({
        url: url,//请求路径
        method: "POST",//请求方式,默认为get
        headers: {//设置请求头
            "content-type": "application/json",
        },
        body: JSON.stringify(requestData)//post参数字符串
    }, function(error, response, body) {
        if (!error && response.statusCode == 200) {
        }
    }); 
    

    1.1简单示例

    var request = require('request');
    request('https://www.baidu.com', function (error, response, body) {
           console.log(body)//打印百度首页html内容
    })
    
    or
    
    request({url:'https://www.baidu.com'}, function (error, response, body) {
           console.log(body)//打印百度首页html内容
    })
    

    2.结合文件流

    进行网络爬虫的时候,有时我们需要保存图片、js、css等文件,request支持文件流

    request('https://www.baidu.com/img/bd_logo1.png').pipe(fs.createWriteStream('a.png'))
    //抓取百度logo并保存到本地
    

    也可以将文件传给PUT或POST请求,用于文件上传。未提供header的情况下,会检测文件后缀名,在PUT请求中设置相应的content-type。

    fs.createReadStream('pic.jpg').pipe(request.put('http://veb.com/upload'))
    //读取流pipe上传
    

    3.表单上传
    request.post('http://service.com/upload', {form:{key:'value'}})
    
    or
    
    request.post('http://service.com/upload').form({key:'value'})
    

    formData形式

    var r = request.post('http://veblen.com/upload')
    var form = r.form()
    form.append('my_field', 'my_value')
    form.append('my_buffer', new Buffer([1, 2, 3]))
    form.append('my_file', fs.createReadStream(path.join(__dirname, 'doodle.png'))
    form.append('remote_file', request('https://www.baidu.com/img/bd_logo1.png'))
    

    附上nodejs重定向(跟request没关系)

    res.writeHead(302, {
        'Location': 'https://www.baidu.com'
        //add other headers here...
    });
    res.end();
    

    结合cheerio爬虫很酷

    //npm install cheerio
    var  cheerio = require('cheerio');
    var  $ = cheerio.load('<ul id="fruits">...</ul>');//jquery 一样的操作



  • 相关阅读:
    菜鸟学Windows Phone 8开发(2)——了解XAML
    菜鸟学Windows Phone 8开发(1)——创建第一个应用程序
    Android6.0之来电转接号码显示修改
    Android之拨号界面图片风格,无信息默认显示界面修改
    Android之mtklog分析
    Android之常用Git命令
    Android开发之Git配置
    Android之Dialer之紧急号码
    Android之mtk上传log
    字节对齐
  • 原文地址:https://www.cnblogs.com/kjtt/p/11063565.html
Copyright © 2011-2022 走看看