仅供学习交流,请勿用于商业用途,并遵守新浪微博相关规定。

代码目录

此处输入图片的描述

此微博机器人的实现功能如下:

模拟登陆新浪微博,获取cookie;

自动上传图片至微博图床;

自动发送内容不同的图文微博;

通过定时任务,实现周期性发微博任务。

效果图

此处输入图片的描述

图文内容我固定了,可自行使用第三方api获取要发送的内容或爬取第三方内容发送。(偷个懒...

此处输入图片的描述

要实现发送图文微博可以分为三个步骤

登录微博。

图片上传至微博图床获取PID。

发送微博。

登录

登录可以使用Puppeteer node库,很轻松的实现登录获取微博cookie,这里不多介绍,可以自行搜索Puppeteer学习。

Puppeteer是谷歌官方出品的一个通过DevTools协议控制headless Chrome的Node库。可以通过Puppeteer的提供的api直接控制Chrome模拟大部分用户操作来进行UI Test或者作为爬虫访问页面来收集数据。

async function login(username, password) {

const browser = await puppeteer.launch({

// headless: false,

slowMo: 250,

executablePath: ''

});

const page = (await browser.pages())[0];

await page.setViewport({

width: 1280,

height: 800

});

await page.goto("https://weibo.com/");

await page.waitForNavigation();

await page.type("#loginname", username);

await page.type("#pl_login_form > div > div:nth-child(3) > div.info_list.password > div > input", password);

await page.click("#pl_login_form > div > div:nth-child(3) > div:nth-child(6)");

await page.waitForNavigation().then(result => {

return new Promise((resolve) => {

page.cookies().then(async cookie => {

fs.createWriteStream("cookie.txt").write(JSON.stringify(cookie), "UTF8");//存储cookie

await browser.close();//关闭打开的浏览器

resolve(cookie);

});

})

}).catch(e => {

page.screenshot({

path: 'code.png',

type: 'png',

x: 800,

y: 200,

width: 100,

height: 100

});

return new Promise((resolve, reject) => {

readSyncByRl("请输入验证码").then(async (code) => {

await page.type("#pl_login_form > div > div:nth-child(3) > div.info_list.verify.clearfix > div > input", code);

await page.click("#pl_login_form > div > div:nth-child(3) > div:nth-child(6)");

await page.waitForNavigation();

page.cookies().then(async cookie => {

fs.createWriteStream("cookie.txt").write(JSON.stringify(cookie), "UTF8");

await browser.close();

resolve(cookie);

});

})

})

})

}

图片上传至微博图床

上传到微博图床可以看这里 http://weibo.com/minipublish 抓包看上传的接口过程,可以看到上传的是base64图片信息。所以上传前把图片转换成base64编码,而本地图片的编码和互联网链接图片的编码又不一样,这里使用的是互联网链接的图片,node本地图片转换成base64编码更简单些。上传成功后返回微博图床图片的pid。记住这个pid,发微博用的就是这个pid。

发送微博

有了微博cookie和图片pid后就可以发微博了,多张图片时pid之间以|隔开的。

async function weibopost(text, pic_ids = '', cookie) { //发送微博内容(支持带图片)

return new Promise(async (resolve, reject) => {

if (cookie === '') {

reject('Error: Cookie not set!');

}

let post_data = querystring.stringify({

'location': 'v6_content_home',

'text': text,

'appkey': '',

'style_type': '1',

'pic_id': pic_ids,

'tid': '',

'pdetail': '',

'mid': '',

'isReEdit': 'false',

'rank': '0',

'rankid': '',

'module': 'stissue',

'pub_source': 'main_',

'pub_type': 'dialog',

'isPri': '0',

'_t': '0'

});

let post_options = {

'Accept': '*/*',

'Accept-Encoding': 'gzip, deflate, br',

'Accept-Language': 'zh-CN,zh;q=0.9,en;q=0.8,zh-TW;q=0.7',

'Connection': 'keep-alive',

'Content-Length': Buffer.byteLength(post_data),

'Content-Type': 'application/x-www-form-urlencoded',

'Cookie': cookie,

'Host': 'weibo.com',

'Origin': 'https://weibo.com',

'Referer': 'https://weibo.com',

'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_3) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.167 Safari/537.36',

'X-Requested-With': 'XMLHttpRequest'

};

let {

data

} = await axios.post('https://weibo.com/aj/mblog/add?ajwvr=6&__rnd=' + new Date().getTime(), post_data, {

withCredentials: true,

headers: post_options

})

if (data.code == 100000) {

console.log('\n' + text + '-----Sent!' + '---' + new Date().toLocaleString());

resolve(data);

} else {

console.log('post error');

reject('post error');

}

});

}

最后就是定时任务了,定时任务可以使用node-schedule node库,这里不多介绍,可以自行搜索学习。这里使用的是每隔10分钟发送一次。

function loginTo() {

login(config.username, config.password).then(async () => {

let rule = null;

rule = new schedule.RecurrenceRule();

rule.minute = [01, 11, 21, 31, 41, 51];

try {

let cookie = await getCookie();

getContent(cookie);

} catch (error) {

console.log(error);

}

j = schedule.scheduleJob(rule, async () => { //定时任务

try {

let cookie = await getCookie();

getContent(cookie);

} catch (error) {

console.log(error);

}

});

})

}

参考

java自动发图文微博_使用node搭建自动发图文微博机器人相关推荐

  1. java自动发图文微博_使用node搭建自动发图文微博机器人的方法

    本文仅供学习交流,请勿用于商业用途,并遵守新浪微博相关规定. 代码目录 此微博机器人的实现功能如下: 模拟登陆新浪微博,获取cookie: 自动上传图片至微博图床: 自动发送内容不同的图文微博: 通过 ...

  2. app后台运行会给服务器发信息吗_零基础搭建电视直播APP平台第一弹(支持安卓+电视盒子)...

    大家好 , 我是阿尘,欢迎来到:极梦小屋. 由于公众号改版,建议大家 星标置顶 本公众号,就可以第一时间接收到我们所推荐的精品资源啦! 为了大家更方便的交流和可以不错过每天的分享,所以特意建了一个交流 ...

  3. java自动售货机代码_急求简易自动售货机(java编程)

    引用z17199的回答: package com.test; import java.util.Scanner; import com.sun.java_cup.internal.internal_e ...

  4. java公路车组装教程_自行车DIY入门教程,图文展示自行车组装全过程。(原创图文,转载请注明出处)...

    本帖最后由 海南龙仔 于 2015-5-11 17:55 编辑 首先,我把自行车分为三个系统. 分别为车体系统.轮组系统.传动系统. 简单来说就是一个架子.二个轮子.加上传动与制动的部件. _____ ...

  5. python爬虫登录微博_【新手学Python爬虫】微博网页PC端抓包分析和模拟登录

    本帖最后由 杀猪用牛刀 于 2020-4-2 23:59 编辑 首先我是一个python爬虫的新手,模拟登录也是我看b站模拟登录教学加自己琢磨完成的,其中很多分析很粗糙,还希望大家多多包涵:lol 话 ...

  6. java配置中心开源项目_配置中心搭建(spring-cloud-config-server)

    1.github创建配置库 2.配置服务端 ①创建项目 ②导入jar org.springframework.boot spring-boot-starter-web org.springframew ...

  7. 基于单片机的自动追日系统设计_基于单片机的自动浇花系统的设计

    龙源期刊网 http://www.qikan.com.cn 基于单片机的自动浇花系统的设计 作者:吴蓓 张阳 来源:<现代信息科技> 2018 年第 03 期 摘 要:为了解决人们生活中由 ...

  8. python自动卸载win程序_利用python实现自动扫雷程序

    自动扫雷一般分为两种,一种是读取内存数据,而另一种是通过分析图片获得数据,并通过模拟鼠标操作,这里我用的是第二种方式. 一.准备工作 1.扫雷游戏 我是win10,没有默认的扫雷,所以去扫雷网下载 h ...

  9. python自动推送消息_使用Python制作自动推送微信消息提醒的备忘录功能

    日常工作生活中,事情一多,就会忘记一些该做未做的事情.即使有时候把事情记录在了小本本上或者手机.电脑端备忘录上,也总会有查看不及时,导致错过的尴尬.如果有一款小工具,可以及时提醒,而不用再主动去查备忘 ...

最新文章

  1. 端口号被占用时,查找占用该端口号的进程并释放端口号
  2. flowable6.4.2流程审批后涉及到的表
  3. spawn-fcgi 启动python 程序失败
  4. php分类程序,php 无限分类程序
  5. android 判断服务是否活动,Android:我如何获得当前的前台活动(从服务)?
  6. mysql更改安装路径6_关于mysql安装后更改数据库路径方法-Centos6环境
  7. web前端好入门吗?
  8. python测控_基于RN8302和Python的电能测控系统设计
  9. 步骤条自定义图片_用函数公式查找图片?我可没骗你
  10. 2020-12-13:C语言钱币兑换问题
  11. 计算机安装系统后鼠标无法使用,电脑重装系统后鼠标键盘不能用怎么办,鼠标键盘不能用解决方法...
  12. 关于django中render_to_response()的用法以及外键的使用
  13. KSF—— 关键成功因素法
  14. 软件项目管理系统-进度管理
  15. Stream流创建,常用方法
  16. 【火炉炼AI】机器学习008-简单线性分类器解决二分类问题
  17. Post Office
  18. iphone中怎么添加邮箱_如何在iPhone的Gmail中添加附件
  19. 【已解决】笔记本电脑连接wifi异常(无法连接到这个网络)
  20. js判断是否是数字——isNaN()函数

热门文章

  1. java中response.setHeader()
  2. VBA OR ODBC连接PostgreSQL
  3. CSS阴影样式大全(包含所有样式: demo代码全)看图看代码
  4. IIS与sxd的问题解决方法
  5. 穷人与富人的区别(转载)
  6. 传奇GEE脚本增加自定义按钮教程
  7. 计算机语言都是相通的,各类编程语言是不是都有互通的部分?
  8. 命令行中 python -v 和 python -V 详解
  9. Maple问题解决(一):解决绘图输出(打印)设置之后绘图不再在页面显示的问题
  10. 自适应滤波器算法综述以及代码实现