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

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

代码目录

78faa986eba81d4aa456409749e568fc.png

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

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

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

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

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

效果图

716171a7f1f3ffa02df936f45a772645.png

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

f82ef6fb35ddf65ef621bae8bf1e098d.png

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

登录微博。

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

发送微博。

登录

登录可以使用Puppeteernode库,很轻松的实现登录获取微博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);

}

});

})

}

参考

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用springboot做基础框架,提供简单页面做图片上传,接口直接模拟微博登陆,上传完成后返回图片保存链接 public String getSinaCookies() { String base64name = Base64Utils.encodeToString(username.getBytes()); String loginUrl = "https://login.sina.com.cn/sso/login.php?client=ssologin.js(v1.4.15)&_=1403138799543"; String params = "entry=sso&gateway=1&from=null&savestate=30&useticket=0&pagerefer;=&vsnf=1&su;=" + base64name; params += "&service=sso&sp;=" + password + "&sr=1920*1080&encoding=UTF-8&cdult=3&domain=sina.com.cn&prelt=0&returntype=TEXT"; //登录 try { URL url = new URL(loginUrl); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setDoInput(true); conn.setDoOutput(true); conn.setRequestMethod("POST"); OutputStream out = conn.getOutputStream(); out.write(params.getBytes()); out.flush(); out.close(); String sessionId = ""; String cookieVal = ""; String key = null; //取cookie for (int i = 1; (key = conn.getHeaderFieldKey(i)) != null; i++) { if (key.equalsIgnoreCase("set-cookie")) { cookieVal = conn.getHeaderField(i); cookieVal = cookieVal.substring(0, cookieVal.indexOf(";")); sessionId = sessionId + cookieVal + ";"; } } if (sessionId != null) { String[] cookiearr = sessionId.split(";"); for (int i = 0; i < cookiearr.length; i++) { if (cookiearr[i].startsWith("SUB") && !cookiearr[i].startsWith("SUBP")) { sessionId = cookiearr[i] + ";"; } } } return sessionId; } catch (Exception e) { e.printStackTrace(); return null; } }
您好!要使用Python爬取微博图文,您可以使用第三方库`Selenium`来模拟浏览器操作,或者使用`requests`和`BeautifulSoup`来解析网页数据。这里我提供一个使用`Selenium`的简单示例代码,供您参考: ```python from selenium import webdriver from selenium.webdriver.common.keys import Keys import time # 设置 Chrome 的驱动路径 driver_path = 'chromedriver.exe' # 请自行下载对应系统的 Chrome 驱动并指定路径 # 创建一个 Chrome 浏览器实例 browser = webdriver.Chrome(driver_path) # 打开微博登录页面 browser.get('https://weibo.com') # 等待页面加载完成 time.sleep(5) # 输入账号和密码并登录 username = browser.find_element_by_name("username") password = browser.find_element_by_name("password") username.send_keys("Your_Username") # 替换为您的微博账号 password.send_keys("Your_Password") # 替换为您的微博密码 password.send_keys(Keys.RETURN) # 等待登录成功,根据需要增加等待时间 time.sleep(10) # 在搜索框中输入关键词并搜索 search_box = browser.find_element_by_xpath("//input[@node-type='searchInput']") search_box.send_keys("关键词") # 替换为您要搜索的关键词 search_box.send_keys(Keys.RETURN) # 等待页面加载完成 time.sleep(5) # 模拟滚动页面,加载更多数据 for i in range(5): browser.execute_script("window.scrollTo(0, document.body.scrollHeight);") time.sleep(3) # 获取页面中的图文信息 articles = browser.find_elements_by_xpath("//div[@class='WB_feed_detail clearfix']") for article in articles: # 解析文章内容,并提取需要的信息 # ... # 关闭浏览器 browser.quit() ``` 请注意,使用第三方库爬取网站数据需要注意法律和道德规范,遵守网站的使用条款,并尊重他人的隐私。另外,微博的网页结构和规则可能会不断变化,以上代码仅供参考,具体操作还需要根据实际情况进行调整。希望对您有所帮助!如有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值