RTMPDUMPによるradikoの録音(2012/10/28修正)
October 28, 2012 – 10:23 am2,3日前からradikoの録音ができなくなっていたのに気づいた。
原因は、radikoの仕様が少し変わったことのようだ。変更部分が反映されるように、Radiko録音用shell scriptを修正しておいた。
修正したshell script: 以前のポスト(RTMPDUMPによるradikoの録音)に示しておいたshell scriptを以下に置き換えることで問題なく動作。
動作を確認。
radiko.sh:
#!/bin/sh
date=`date '+%Y-%m-%d-%H:%M'`
playerurl=http://radiko.jp/player/swf/player_3.0.0.01.swf
playerfile=./player.swf
keyfile=./authkey.png
if [ $# -eq 2 ]; then
station=$1
DURATION=`expr $2 \* 60`
else
echo "usage : $0 station_name duration(minuites)"
exit 1
fi
#
# get player
#
if [ ! -f $playerfile ]; then
wget -q -O $playerfile $playerurl
if [ $? -ne 0 ]; then
echo "failed get player"
exit 1
fi
fi
#
# get keydata (need swftool)
#
if [ ! -f $keyfile ]; then
swfextract -b 14 $playerfile -o $keyfile
if [ ! -f $keyfile ]; then
echo "failed get keydata"
exit 1
fi
fi
if [ -f auth1_fms ]; then
rm -f auth1_fms
fi
#
# access auth1_fms
#
wget -q \
--header="pragma: no-cache" \
--header="X-Radiko-App: pc_1" \
--header="X-Radiko-App-Version: 2.0.1" \
--header="X-Radiko-User: test-stream" \
--header="X-Radiko-Device: pc" \
--post-data='\r\n' \
--no-check-certificate \
--save-headers \
https://radiko.jp/v2/api/auth1_fms
if [ $? -ne 0 ]; then
echo "failed auth1 process"
exit 1
fi
#
# get partial key
#
authtoken=`perl -ne 'print $1 if(/x-radiko-authtoken: ([\w-]+)/i)' auth1_fms`
offset=`perl -ne 'print $1 if(/x-radiko-keyoffset: (\d+)/i)' auth1_fms`
length=`perl -ne 'print $1 if(/x-radiko-keylength: (\d+)/i)' auth1_fms`
partialkey=`dd if=$keyfile bs=1 skip=${offset} count=${length} 2> /dev/null | base64`
echo "authtoken: ${authtoken} \noffset: ${offset} length: ${length} \npartialkey:
$partialkey"
rm -f auth1_fms
if [ -f auth2_fms ]; then
rm -f auth2_fms
fi
#
# access auth2_fms
#
wget -q \
--header="pragma: no-cache" \
--header="X-Radiko-App: pc_1" \
--header="X-Radiko-App-Version: 2.0.1" \
--header="X-Radiko-User: test-stream" \
--header="X-Radiko-Device: pc" \
--header="X-Radiko-Authtoken: ${authtoken}" \
--header="X-Radiko-Partialkey: ${partialkey}" \
--post-data='\r\n' \
--no-check-certificate \
https://radiko.jp/v2/api/auth2_fms
if [ $? -ne 0 -o ! -f auth2_fms ]; then
echo "failed auth2 process"
exit 1
fi
echo "authentication success"
areaid=`perl -ne 'print $1 if(/^([^,]+),/i)' auth2_fms`
echo "areaid: $areaid"
rm -f auth2_fms
#
# rtmpdump
#
/opt/rtmpdump-2.4/rtmpdump -v \
-r "rtmpe://w-radiko.smartstream.ne.jp" \
--playpath "simul-stream.stream" \
--app "${station}/_definst_" \
-W $playerurl \
-C S:"" -C S:"" -C S:"" -C S:$authtoken \
--live \
--stop $DURATION \
-o "/tmp/${1}_${date}"
ffmpeg -y -i "/tmp/${1}_${date}" -acodec libmp3lame "/var/www/test/audio/${1}_${date}.mp3"
rm "/tmp/${1}_${date}"
修正情報については、http://fukubaya.blogspot.jp/2012/10/radiko.htmlを参考にさせていただいた。
4 Responses to “RTMPDUMPによるradikoの録音(2012/10/28修正)”
player_3.0.1.01.swf は player_3.0.0.01.swf じゃないとダメかも
By otsune on Nov 6, 2012
ご指摘ありがとうございました。
playerurl を type miss していました。
みなさん修正お願いします。
とはいうものの、player_3.0.1.01.swf のままでも動作していました???
何なんでしょうね?
By yama on Nov 7, 2012