5

飞牛社区签到脚本(配合青龙面板可以实现每日自动签到)

发表于:2024-11-10 14:01:14 应用分享 414

飞牛社区自动签到脚本指南

在这篇文章中,我将分享一个自动签到的 Python 脚本,适用于飞牛社区。通过该脚本,您可以方便快捷地完成每日签到,避免手动操作的繁琐。

脚本参考:fnOS 青龙面板部署飞牛社区自动签到脚本带通知功能_青龙面板自动签到-CSDN博客

1. 实现功能

该脚本主要负责完成以下任务:

  • 自动发送签到请求,获取签到结果。
  • 提取并展示用户的签到情况,包括最近打卡、本月打卡和累计打卡奖励等信息并发送邮件通知本人。
  • 在发生错误时,自动发送电子邮件通知本人。

2. 代码解析

请求部分:

使用 requests 库向签到接口发起 GET 请求,并根据返回的数据判断签到结果。

def sign_in():
    try:
        # 签到请求链接右键打卡按钮直接复制替换
        response = requests.get('*******签到请求链接右键打卡按钮直接复制替换*******', cookies=cookies)

        if '恭喜您,打卡成功!' in response.text:
            print('签到详情(打卡成功):\n')
            get_sign_in_info()
        elif '您今天已经打过卡了,请勿重复操作!' in response.text:
            print('签到详情(已经打过卡了):\n')
            get_sign_in_info()
        else:
            print('打卡失败, cookies可能已经过期或站点更新.')
            smtp(title='飞牛社区自动签到(打卡失败)', content='cookies可能已经过期或站点更新.')  # 发送邮件
    except Exception as error:
        print('签到请求失败:', error)
        smtp(title='飞牛社区自动签到(请求失败)', content=str(error))  # 发送邮件

若签到成功或已签到,脚本会调用 get_sign_in_info() 函数获取详细信息。

def get_sign_in_info():
    try:
        response = requests.get('https://club.fnnas.com/plugin.php?id=zqlj_sign', cookies=cookies)

        soup = BeautifulSoup(response.text, 'html.parser')
        content = []

        # 定义需要查找的模式和选择器
        patterns = [
            {'name': '最近打卡', 'selector': 'li:-soup-contains("最近打卡")'},
            {'name': '本月打卡', 'selector': 'li:-soup-contains("本月打卡")'},
            {'name': '连续打卡', 'selector': 'li:-soup-contains("连续打卡")'},
            {'name': '累计打卡', 'selector': 'li:-soup-contains("累计打卡")'},
            {'name': '累计奖励', 'selector': 'li:-soup-contains("累计奖励")'},
            {'name': '最近奖励', 'selector': 'li:-soup-contains("最近奖励")'},
            {'name': '当前打卡等级', 'selector': 'li:-soup-contains("当前打卡等级")'}
        ]

        for pattern in patterns:
            element = soup.select_one(pattern['selector'])
            if element:
                # 提取文本并清洗
                text = element.get_text()
                content.append(f"{pattern['name']}: {text.split(':')[-1].strip()}")
        content_text = '\n'.join(content)
        print(content_text + '\n')
        smtp(title='飞牛社区自动签到(成功)', content=str(content_text))  # 发送邮件

    except Exception as error:
        print('获取打卡信息失败:', error)
        smtp(title='飞牛社区自动签到(获取打卡信息失败)', content=str(error))  # 发送邮件

信息提取:

脚本使用 BeautifulSoup 对 HTML 内容进行解析,提取用户的签到信息。我们定义了一系列的模式,通过选择器查找特定的文本。

def get_sign_in_info():
    try:
        response = requests.get('https://club.fnnas.com/plugin.php?id=zqlj_sign', cookies=cookies)

        soup = BeautifulSoup(response.text, 'html.parser')
        content = []

        # 定义需要查找的模式和选择器
        patterns = [
            {'name': '最近打卡', 'selector': 'li:-soup-contains("最近打卡")'},
            {'name': '本月打卡', 'selector': 'li:-soup-contains("本月打卡")'},
            {'name': '连续打卡', 'selector': 'li:-soup-contains("连续打卡")'},
            {'name': '累计打卡', 'selector': 'li:-soup-contains("累计打卡")'},
            {'name': '累计奖励', 'selector': 'li:-soup-contains("累计奖励")'},
            {'name': '最近奖励', 'selector': 'li:-soup-contains("最近奖励")'},
            {'name': '当前打卡等级', 'selector': 'li:-soup-contains("当前打卡等级")'}
        ]

        for pattern in patterns:
            element = soup.select_one(pattern['selector'])
            if element:
                # 提取文本并清洗
                text = element.get_text()
                content.append(f"{pattern['name']}: {text.split(':')[-1].strip()}")
        content_text = '\n'.join(content)
        print(content_text + '\n')
        smtp(title='飞牛社区自动签到(成功)', content=str(content_text))  # 发送邮件

    except Exception as error:
        print('获取打卡信息失败:', error)
        smtp(title='飞牛社区自动签到(获取打卡信息失败)', content=str(error))  # 发送邮件

邮件推送:

在签到成功或失败时,脚本通过 SMTP 发送结果邮件,保证用户及时了解签到状态。

def smtp(title: str, content: str):
    """ 使用 SMTP 邮件 推送消息。 """
    if (
            not push_config.get("SMTP_SERVER")
            or not push_config.get("SMTP_SSL")
            or not push_config.get("SMTP_EMAIL")
            or not push_config.get("SMTP_PASSWORD")
            or not push_config.get("SMTP_NAME")
    ):
        print(
            "SMTP 邮件 的 SMTP_SERVER 或者 SMTP_SSL 或者 SMTP_EMAIL 或者 SMTP_PASSWORD 或者 SMTP_NAME 未设置!!\n取消推送"
        )
        return
    print("SMTP 邮件 服务启动")

    message = MIMEText(content, "plain", "utf-8")
    message["From"] = formataddr(
        (
            Header(push_config.get("SMTP_NAME"), "utf-8").encode(),
            push_config.get("SMTP_EMAIL"),
        )
    )
    message["To"] = formataddr(
        (
            Header(push_config.get("SMTP_NAME"), "utf-8").encode(),
            push_config.get("SMTP_EMAIL"),
        )
    )
    message["Subject"] = Header(title, "utf-8")

    try:
        smtp_server = (
            smtplib.SMTP_SSL(push_config.get("SMTP_SERVER"))
            if push_config.get("SMTP_SSL") == "true"
            else smtplib.SMTP(push_config.get("SMTP_SERVER"))
        )
        smtp_server.login(
            push_config.get("SMTP_EMAIL"), push_config.get("SMTP_PASSWORD")
        )
        smtp_server.sendmail(
            push_config.get("SMTP_EMAIL"),
            push_config.get("SMTP_EMAIL"),
            message.as_bytes(),
        )
        smtp_server.close()
        print("SMTP 邮件 推送成功!")
    except Exception as e:
        print(f"SMTP 邮件 推送失败!{e}")

3. 使用前准备

(1)用户需要设置相应的 Cookie 值和 SMTP 邮件服务配置。确保使用的邮箱支持 SMTP 发送,并提供正确的服务器信息。

  • Cookie获取链接:https://club.fnnas.com/plugin.php?id=zqlj\_sign
  • 打开链接登录后,使用开发者模式获取所需要的Cookie相应字段的值。
  • 邮件服务可以选择配置,详细配置教程可以参考来自bing的搜索。
# 填写对应的 Cookie 值
cookies = {
    'pvRK_2132_saltkey': '',
    'pvRK_2132_auth': '',
}
# SMTP 邮件服务配置
push_config = {
    'SMTP_SERVER': '',  # SMTP 发送邮件服务器,形如 smtp.exmail.qq.com:465
    'SMTP_SSL': 'true',  # SMTP 发送邮件服务器是否使用 SSL,填写 true 或 false
    'SMTP_EMAIL': '',  # SMTP 收发件邮箱,通知将会由自己发给自己
    'SMTP_PASSWORD': '',  # SMTP 登录密码,也可能为特殊口令,视具体邮件服务商说明而定
    'SMTP_NAME': '定时任务',  # SMTP 收发件人姓名,可随意填写
}

(2)签到链接获取

# 签到请求链接右键打卡按钮直接复制替换
response = requests.get('**签到请求链接右键打卡按钮直接复制替换**', cookies=cookies)

4.完整脚本

import requests
from bs4 import BeautifulSoup
import smtplib
from email.mime.text import MIMEText
from email.header import Header
from email.utils import formataddr

# 填写对应的 Cookie 值
cookies = {
    'pvRK_2132_saltkey': '',
    'pvRK_2132_auth': '',
}
# SMTP 邮件服务配置
push_config = {
    'SMTP_SERVER': '',  # SMTP 发送邮件服务器,形如 smtp.exmail.qq.com:465
    'SMTP_SSL': 'true',  # SMTP 发送邮件服务器是否使用 SSL,填写 true 或 false
    'SMTP_EMAIL': '',  # SMTP 收发件邮箱,通知将会由自己发给自己
    'SMTP_PASSWORD': '',  # SMTP 登录密码,也可能为特殊口令,视具体邮件服务商说明而定
    'SMTP_NAME': '定时任务',  # SMTP 收发件人姓名,可随意填写
}


def sign_in():
    try:
        # 签到请求链接右键打卡按钮直接复制替换
        response = requests.get('**签到请求链接右键打卡按钮直接复制替换**', cookies=cookies)

        if '恭喜您,打卡成功!' in response.text:
            print('签到详情(打卡成功):\n')
            get_sign_in_info()
        elif '您今天已经打过卡了,请勿重复操作!' in response.text:
            print('签到详情(已经打过卡了):\n')
            get_sign_in_info()
        else:
            print('打卡失败, cookies可能已经过期或站点更新.')
            smtp(title='飞牛社区自动签到(打卡失败)', content='cookies可能已经过期或站点更新.')  # 发送邮件
    except Exception as error:
        print('签到请求失败:', error)
        smtp(title='飞牛社区自动签到(请求失败)', content=str(error))  # 发送邮件


def get_sign_in_info():
    try:
        response = requests.get('https://club.fnnas.com/plugin.php?id=zqlj_sign', cookies=cookies)

        soup = BeautifulSoup(response.text, 'html.parser')
        content = []

        # 定义需要查找的模式和选择器
        patterns = [
            {'name': '最近打卡', 'selector': 'li:-soup-contains("最近打卡")'},
            {'name': '本月打卡', 'selector': 'li:-soup-contains("本月打卡")'},
            {'name': '连续打卡', 'selector': 'li:-soup-contains("连续打卡")'},
            {'name': '累计打卡', 'selector': 'li:-soup-contains("累计打卡")'},
            {'name': '累计奖励', 'selector': 'li:-soup-contains("累计奖励")'},
            {'name': '最近奖励', 'selector': 'li:-soup-contains("最近奖励")'},
            {'name': '当前打卡等级', 'selector': 'li:-soup-contains("当前打卡等级")'}
        ]

        for pattern in patterns:
            element = soup.select_one(pattern['selector'])
            if element:
                # 提取文本并清洗
                text = element.get_text()
                content.append(f"{pattern['name']}: {text.split(':')[-1].strip()}")
        content_text = '\n'.join(content)
        print(content_text + '\n')
        smtp(title='飞牛社区自动签到(成功)', content=str(content_text))  # 发送邮件

    except Exception as error:
        print('获取打卡信息失败:', error)
        smtp(title='飞牛社区自动签到(获取打卡信息失败)', content=str(error))  # 发送邮件


def smtp(title: str, content: str):
    """ 使用 SMTP 邮件 推送消息。 """
    if (
            not push_config.get("SMTP_SERVER")
            or not push_config.get("SMTP_SSL")
            or not push_config.get("SMTP_EMAIL")
            or not push_config.get("SMTP_PASSWORD")
            or not push_config.get("SMTP_NAME")
    ):
        print(
            "SMTP 邮件 的 SMTP_SERVER 或者 SMTP_SSL 或者 SMTP_EMAIL 或者 SMTP_PASSWORD 或者 SMTP_NAME 未设置!!\n取消推送"
        )
        return
    print("SMTP 邮件 服务启动")

    message = MIMEText(content, "plain", "utf-8")
    message["From"] = formataddr(
        (
            Header(push_config.get("SMTP_NAME"), "utf-8").encode(),
            push_config.get("SMTP_EMAIL"),
        )
    )
    message["To"] = formataddr(
        (
            Header(push_config.get("SMTP_NAME"), "utf-8").encode(),
            push_config.get("SMTP_EMAIL"),
        )
    )
    message["Subject"] = Header(title, "utf-8")

    try:
        smtp_server = (
            smtplib.SMTP_SSL(push_config.get("SMTP_SERVER"))
            if push_config.get("SMTP_SSL") == "true"
            else smtplib.SMTP(push_config.get("SMTP_SERVER"))
        )
        smtp_server.login(
            push_config.get("SMTP_EMAIL"), push_config.get("SMTP_PASSWORD")
        )
        smtp_server.sendmail(
            push_config.get("SMTP_EMAIL"),
            push_config.get("SMTP_EMAIL"),
            message.as_bytes(),
        )
        smtp_server.close()
        print("SMTP 邮件 推送成功!")
    except Exception as e:
        print(f"SMTP 邮件 推送失败!{e}")


if __name__ == '__main__':
    sign_in()

结尾

通过这个自动签到脚本,我们能够实现自动化操作,提高效率。如果您在使用过程中遇到问题,欢迎在评论区交流。

收藏
送赞 5
分享

发表回复

评论列表(12)

打卡失败, cookies可能已经过期或站点更新.
2024-11-11 13:29:35 回复
[md]需要把自己的cookie和签到地址填到脚本相应位置哦!脚本没问题的 ![1000008224.jpg](data/attachment/forum/202411/11/133957hcewh009jwfwwe89.jpg "1000008224.jpg") [/md]  详情 回复
2024-11-11 13:40

需要把自己的cookie和签到地址填到脚本相应位置哦!脚本没问题的 1000008224.jpg

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
2024-11-11 13:40:24 回复
签到详情(已经打过卡了):

最近打卡: 2024-11-11 13:55:42
本月打卡: 1天
连续打卡: 1天
累计打卡: 2天
累计奖励: 8飞牛币
最近奖励: 3飞牛币
当前打卡等级: 无名新人
2024-11-11 14:00:00 回复
有用,插个眼,标记一下
2024-11-11 18:51:43 回复
手动点赞,好东西,收下了
6 天前 回复
为啥不做pushplus这种消息推送服务
5 天前 回复
还有我报错: file:///ql/data/scripts/%E9%A3%9E%E7%89%9B%E7%A4%BE%E5%8C%BA%E7%AD%BE%E5%88%B02.mjs:2 from bs4 import BeautifulSoup ^^^ SyntaxError: Unexpected identifier 'bs4' at ModuleLoader.  详情 回复
5 天前
还有我报错:
file:///ql/data/scripts/%E9%A3%9E%E7%89%9B%E7%A4%BE%E5%8C%BA%E7%AD%BE%E5%88%B02.mjs:2
from bs4 import BeautifulSoup
     ^^^

SyntaxError: Unexpected identifier 'bs4'
    at ModuleLoader.moduleStrategy (node:internal/modules/esm/translators:169:18)
    at callTranslator (node:internal/modules/esm/loader:272:14)
    at ModuleLoader.moduleProvider (node:internal/modules/esm/loader:278:30)
    at async link (node:internal/modules/esm/module_**:78:21)

Node.js v20.15.1
5 天前 回复
还有,这个脚本的语言是python需要使用python解释器运行哦  详情 回复
6 小时前
[md]这个情况的话是没有下载bs4这个依赖,可以尝试下载bs4依赖后再次运行 ![image.png](data/attachment/forum/202411/19/191235vf4qc1869645xc17.png "image.png") [/md]  详情 回复
前天 19:12

这个情况的话是没有下载bs4这个依赖,可以尝试下载bs4依赖后再次运行 image.png

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
前天 19:12 回复
大佬,我运行这个报错
(node:72449) Warning: To load an ES module, set "type": "module" in the package.json or use the .mjs extension.
(Use `node --trace-warnings ...` to show where the warning was created)
/ql/data/scripts/fnsign.js:1
import requests
^^^^^^

SyntaxError: Cannot use import statement outside a module
    at wrapSafe (node:internal/modules/cjs/loader:1281:20)
    at Module._compile (node:internal/modules/cjs/loader:1321:27)
    at Module._extensions..js (node:internal/modules/cjs/loader:1416:10)
    at Module.load (node:internal/modules/cjs/loader:1208:32)
    at Module._load (node:internal/modules/cjs/loader:1024:12)
    at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:174:12)
    at node:internal/main/run_main_module:28:49

Node.js v20.15.1
昨天 10:40 回复
需要使用python解释器运行哦!记得要将导入的依赖都安装好  详情 回复
6 小时前
12下一页
晨阳

TA还没有介绍自己~

0

主题

2

回帖

2

积分

江湖小虾

积分
2
话题