#!/bin/bash
########################################################
程序名称: 海洋CMS自动采集脚本
版本信息:seacmsbot/ v2.0
使用方法:直接复制代码到宝塔计划任务shell脚本内容里添加每小时任务使用
更新时间:2019.9.26
##########################################################
#请修改下面的网站域名及管理目录
web_site="http://www.68baiteyinshua.com/rich666/admin_reslib2.php"
#请修改下面项内容为"admin_reslib2.php"里设置的访问密码(默认为系统设置的cookie密码)
web_pwd="0fff729e83764f03a37d6bde9f1f44e5"
#下面项内容为资源站每日采集链接地址列表,请自行修改,每行一条,可添加多个,前后需添加引号。
#每日采集链接获取方法:选择"后台-采集-资源库列表",复制资源站右边的"采集每天"的链接地址,去掉?前面的内容。
web_api=(
'?ac=day&rid=1&url=https://m3u8.apiyhzy.com/api.php/seacms/vod/at/xml/?ac=list'
'?ac=day&rid=2&url=https://api.wujinapi.com/api.php/provide/vod/from/wjm3u8/at/xmlsea/'
'?ac=day&rid=4&url=https://sdzyapi.com/api.php/provide/vod/from/sdm3u8/at/xmlsea/'
'?ac=day&rid=5&url=https://api.tiankongapi.com/api.php/provide/vod/from/tkm3u8/at/xmlsea/'
'?ac=day&rid=8&url=http://cj.ffzyapi.com/api.php/seacms/vod/at/xml/'
'?ac=day&rid=9&url=https://cj.lziapi.com/api.php/seacms/vod/from/lzm3u8/at/xml/ '
'?ac=day&rid=10&url=https://suoniapi.com/api.php/provide/vod/from/snm3u8/at/xmlsea/'
)
#采集单页
function get_content() {
echo "正在采集第$page页..."
#echo " get_content: --->url:--->$1"
cResult=$(curl --connect-timeout 10 -m 20 -k -s -L -A "$web_ua" "$1" )
echo $cResult | grep -q "采集"
#echo -e "$1\n$cResult"
if [ "$?" = "0" ]; then
next_content "$cResult"
else
echo -e "采集失败,请检查设置!\n失败链接-->$1\n返回信息-->$cResult\n采集结束,共0页"
fi
}
#采集下页
function next_content() {
#统计数据
Result=$(echo "$1" | tr "<br>" "\n")
a=$(echo "$Result" | grep -c "采集成功")
b=$(echo "$Result" | grep -c "更新数据")
c=$(echo "$Result" | grep -c "无需更新")
d=$(echo "$Result" | grep -c "跳过")
echo "采集成功-->已更$c部,新增$a部,更新$b部,跳过$d部"
let add+=$a
let update+=$b
let none+=$c
let jmp+=$d
#检测并采集下页
next_url=${1##location.href=\'}
next_url=${next_url%%\'}
#echo $next_url
if [ "${next_url:0:1}" = "?" ]
then
let page++
get_content "$web_site$next_url"
else
echo "采集结束,共$page页"
fi
}
#脚本入口
echo "海洋CMS自动采集脚本开始执行 版本:v1.2"
starttime=$(date +%s)
update=0 #更新
add=0 #新增
none=0 #无变化
jmp=0 # 跳过
for url in ${web_api[@]};
do
if [[ ! -z $url ]]
then
web_param="$web_site$url&password=$web_pwd"
page=1
echo "开始采集:$url"
get_content $web_param
fi
done
endtime=$(date +%s)
echo "============================"
echo "入库-->$add部"
echo "更新-->$update部"
echo "跳过-->$jmp部(未绑定分类或链接错误)"
echo "今日-->$[none+add+update]部"
echo "============================"
echo "全部采集结束,耗时$[endtime - starttime]秒"