# soulsign-chrome
**Repository Path**: inu1255/soulsign-chrome
## Basic Information
- **Project Name**: soulsign-chrome
- **Description**: 魂签,一款用于自动签到的chrome插件
- **Primary Language**: JavaScript
- **License**: Not specified
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 107
- **Forks**: 23
- **Created**: 2018-11-14
- **Last Updated**: 2025-04-25
## Categories & Tags
**Categories**: chrome-plugins
**Tags**: None
## README
## soulsign-chrome

### 功能
自动签到,每天只要打开浏览器就可以自动签到,不用填写账号密码,不用手动抓取cookie,只需要 添加脚本+登录账号
### 使用方法
1. 手动安装: 下载[build.zip](https://github.com/inu1255/soulsign-chrome/releases)并解压,选项->更多工具->扩展程序->开发者模式->加载已解压的扩展程序
2. [chrome网上应用店安装](https://chrome.google.com/webstore/detail/%E9%AD%82%E7%AD%BE/llbielhggjekmfjikgkcaloghnibafdl?hl=zh-CN)(由于不能通过审核,没有更新了)
**firefox** [安装](https://addons.mozilla.org/zh-CN/firefox/addon/%E9%AD%82%E7%AD%BE/)
### 安装脚本
1. 最简单的方法,点击插件图标->任务管理->脚本推荐->挑选安装
2. 第三方或者自用脚本安装方法, 点击插件图标->任务管理->添加脚本->上传脚本文件/粘贴脚本代码/拖拽脚本文件/粘贴脚本链接
### 更新:
20181207: 支持用户填写参数,用于用户填写账号密码进行自动登录的场景。使用方法参考 `public/demos/m.jd.js`, 需要版本1.0.4+

20190326: 支持引用外部js,支持获取指定网页的cookie
[示例/public/demo/xiami.js](https://github.com/inu1255/soulsign-chrome/blob/master/public/demos/xiami.js)
20190428: 支持域名模糊匹配, *.baidu.com 将匹配 xxoo.baidu.com 或 www.baidu.com 但不能匹配 baidu.com
20191205: 代码重构,清理了一些逻辑,将任务管理等操作统一到了后端,保证数据一至性;增加导入导出功能;增强脚本安全性,新增@grant用于权限申请
20191208: 增加了返利捐赠开关, 访问`https://www.jd.com/`时将跳转到作者的返利链接
20191218: 优化代码结构,支持脚本导出/导入,增加脚本网站
20200827: 支持 `查看日志` 页面

20200831: 支持类似[puppeteer](https://github.com/GoogleChrome/puppeteer#readme)模拟点击等功能, [使用说明](#模拟点击)
### 计划:
1. ~~低版本支持(自带babel)~~ 无明显需求,所以放弃
1. 脚本更新(手动/自动) ✅
1. [脚本发布站点](https://soulsign.inu1255.cn) ✅
### 脚本开发
示例:
``` javascript
// ==UserScript==
// @name v2ex签到
// @namespace https://github.com/inu1255/soulsign-chrome
// @version 1.0.0
// @author inu1255
// @loginURL https://www.v2ex.com/signin
// @expire 900e3
// @domain www.v2ex.com
// ==/UserScript==
/**
* 签到接口,可以使用axios库发起请求,请求url域名必须通过@domain声明
* throw 签到失败并抛出失败原因
* return 签到成功并返回成功信息
*/
exports.run = async function() {
var ret = await axios.get('https://www.v2ex.com/mission/daily');
if (ret.status != 200) throw '需要登录';
if (/每日登录奖励已领取/.test(ret.data)) return '已领取';
let m = /redeem\?once=(.*?)'/.exec(ret.data);
if (!m) throw '失败1';
await axios.get('https://www.v2ex.com/mission/daily/redeem?once=' + m[1]);
var ret = await axios.get('https://www.v2ex.com/mission/daily');
if (/每日登录奖励已领取/.test(ret.data)) return '成功';
throw '失败2';
};
/**
* 检查是否在线接口,可以使用axios库发起请求,请求url域名必须通过@domain声明
* return true 代表在线
*/
exports.check = async function() {
var ret = await axios.get('https://www.v2ex.com/mission/daily');
return ret.status == 200;
};
```
说明:
1. 前面的 ==UserScript== 不可少
1. @name 脚本名称
1. @namespace 脚本官方网址
1. @version 脚本版本
1. @author 脚本作者
1. @loginURL 登录链接(帮助用户通过这个链接去登录)
1. @expire 会话过期时间(毫秒),系统会隔一段时间调用一次check接口检查在线状态并保持会话活跃
1. @domain 请求域名(向用户申明该脚本会访问的域名)
1. @domain 另一个请求域名(@domain支持多个)
1. @param 参数键 [参数类型,选填,默认text] 参数说明
1. (@author,@name)唯一确定一个脚本,重复会被当成一个脚本
1. 后面的 ==/UserScript== 不可少
更多[demos](https://github.com/inu1255/soulsign-chrome/tree/master/public/demos)
ps: 作者自己写的脚本用到了async/await不支持低版本浏览器
### 日志配置
预览:

示例:
> `输出` 指 `export.run()` 的返回值
- 标准输出格式***object***
```javascript
{
summary: "签到成功", // `执行结果`,可渲染 `html`
detail: [
{
domain: "www.example.com", // `细节/日志` 中的 `域名`
url: "https://www.example.com", // `细节/日志` 中的 `域名` 的跳转链接
message: "获得 1 积分", // `细节/日志` 中的 `消息`,格式同 `执行结果`
errno: false, // 成功,errno = (false || 0);失败,errno = (true || !0)
log: {
data: "some_data",
param: {
param1: 1,
param2: "some_string",
},
}, // 或任何其他的额外属性,类型和数量不限,其将会在 `表单展开项` 中出现
},
],
}
```
- 兼容输出格式***string***
```javascript
"签到成功"
// 将默认转化为 `标准输出格式`,如下所示
//
// {
// summary: "签到成功",
// detail: [
// {
// domain: @domain[0],
// url: @loginUrl,
// message: "签到成功",
// errno: throw ? true : false,
// },
// ],
// }
```
说明:
1. 如果你利用 `标准输出格式` 开发,请尽量使用 [`tools.version`](https://soulsign.inu1255.cn/scripts/247)***{ inputLower: 1, inputEqual: 0, inputHigher: -1 } = function (string)*** 对输出格式做兼容处理,`object` 在旧版本插件中会以 `JSON` 形式展示在 `执行结果` 处,观感可能会很差。
2. `.log | 额外的其他属性` 的内容完全由脚本内部定义,初衷是更好地开发和请求用户反馈信息,为非必要选项,所以默认不可复制。
3. `细节/日志` 页面可以 `复选` 分域名 `复制`,默认可复制的信息中有 `domain`, `url`, `message`, `errno`,其他信息需要用户自行开启选项,添加后复制。
4. `细节/日志` 中的 `域名` 不仅拥有 `执行结果` 的两种颜色,还支持 `errno = 2 : orange`、`errno = 3 : orchid`、`errno = 4 : pink`、`errno = 5 : brown`。
5. `表单展开项` 中的 `JSON` 树默认仅展开一层。
### 模拟点击
请参考demo脚本 [京东金融PC](https://github.com/inu1255/soulsign-chrome/tree/master/public/demos/jr.jd.js) 和 [阿里云签到](https://github.com/inu1255/soulsign-chrome/tree/master/public/demos/club.aliyun.js)
### 思路
作者以前用[puppeteer](https://github.com/GoogleChrome/puppeteer#readme)做过一套签到工具,用nodejs做过签到站点,不过两者都有一个短板--拿cookie不方便。做成插件的好处就是不用管理cookie,插件不用记录cookie信息,用户不用抓取cookie只需要在浏览器登录账号就行了。