最近在github中看到一個python的PPTV的接口,有人能幫忙把此接口當中的演算法轉換成PHP嗎?
<code>#!/usr/bin/env python __all__ = ['pptv_download', 'pptv_download_by_id'] from ..common import * import re import time import urllib from random import random def constructKey(arg): def str2hex(s): r="" for i in s[:8]: t=hex(ord(i))[2:] if len(t)==1: t="0"+t r+=t for i in range(16): r+=hex(int(15*random()))[2:] return r #ABANDONED Because SERVER_KEY is static def getkey(s): #returns 1896220160 l2=[i for i in s] l4=0 l3=0 while l4<len(l2): l5=l2[l4] l6=ord(l5) l7=l6<<((l4%4)*8) l3=l3^l7 l4+=1 return l3 pass def rot(k,b): ##>>> in as3 if k>=0: return k>>b elif k<0: return (2**32+k)>>b pass def lot(k,b): return (k<<b)%(2**32) #WTF? def encrypt(arg1,arg2): delta=2654435769 l3=16; l4=getkey(arg2) #1896220160 l8=[i for i in arg1] l10=l4; l9=[i for i in arg2] l5=lot(l10,8)|rot(l10,24)#101056625 # assert l5==101056625 l6=lot(l10,16)|rot(l10,16)#100692230 # assert 100692230==l6 l7=lot(l10,24)|rot(l10,8) # assert 7407110==l7 l11="" l12=0 l13=ord(l8[l12])<<0 l14=ord(l8[l12+1])<<8 l15=ord(l8[l12+2])<<16 l16=ord(l8[l12+3])<<24 l17=ord(l8[l12+4])<<0 l18=ord(l8[l12+5])<<8 l19=ord(l8[l12+6])<<16 l20=ord(l8[l12+7])<<24 l21=(((0|l13)|l14)|l15)|l16 l22=(((0|l17)|l18)|l19)|l20 l23=0 l24=0 while l24<32: l23=(l23+delta)%(2**32) l33=(lot(l22,4)+l4)%(2**32) l34=(l22+l23)%(2**32) l35=(rot(l22,5)+l5)%(2**32) l36=(l33^l34)^l35 l21=(l21+l36)%(2**32) l37=(lot(l21,4)+l6)%(2**32) l38=(l21+l23)%(2**32) l39=(rot(l21,5))%(2**32) l40=(l39+l7)%(2**32) l41=((l37^l38)%(2**32)^l40)%(2**32) l22=(l22+l41)%(2**32) l24+=1 l11+=chr(rot(l21,0)&0xff) l11+=chr(rot(l21,8)&0xff) l11+=chr(rot(l21,16)&0xff) l11+=chr(rot(l21,24)&0xff) l11+=chr(rot(l22,0)&0xff) l11+=chr(rot(l22,8)&0xff) l11+=chr(rot(l22,16)&0xff) l11+=chr(rot(l22,24)&0xff) return l11 loc1=hex(int(arg))[2:]+(16-len(hex(int(arg))[2:]))*"\x00" SERVER_KEY="qqqqqww"+"\x00"*9 res=encrypt(loc1,SERVER_KEY) return str2hex(res) def pptv_download_by_id(id, title = None, output_dir = '.', merge = True, info_only = False): xml = get_html('http://web-play.pptv.com/webplay3-0-%s.xml?type=web.fpp' % id) #vt=3 means vod mode vt=5 means live mode host = r1(r'<sh>([^<>]+)</sh>', xml) k = r1(r'<key expire=[^<>]+>([^<>]+)</key>', xml) rid = r1(r'rid="([^"]+)"', xml) title = r1(r'nm="([^"]+)"', xml) st=r1(r'<st>([^<>]+)</st>',xml)[:-4] st=time.mktime(time.strptime(st))*1000-60*1000-time.time()*1000 st+=time.time()*1000 st=st/1000 key=constructKey(st) pieces = re.findall('<sgm no="(\d+)"[^<>]+fs="(\d+)"', xml) numbers, fs = zip(*pieces) urls=["http://{}/{}/{}?key={}&fpp.ver=1.3.0.4&k={}&type=web.fpp".format(host,i,rid,key,k) for i in range(max(map(int,numbers))+1)] total_size = sum(map(int, fs)) assert rid.endswith('.mp4') print_info(site_info, title, 'mp4', total_size) if not info_only: try: download_urls(urls, title, 'mp4', total_size, output_dir = output_dir, merge = merge) except urllib.error.HTTPError: #for key expired pptv_download_by_id(id, output_dir = output_dir, merge = merge, info_only = info_only) def pptv_download(url, output_dir = '.', merge = True, info_only = False, **kwargs): assert re.match(r'http://v.pptv.com/show/(\w+)\.html$', url) html = get_html(url) id = r1(r'webcfg\s*=\s*{"id":\s*(\d+)', html) assert id pptv_download_by_id(id, output_dir = output_dir, merge = merge, info_only = info_only) </code>
回覆內容:
<code>#!/usr/bin/env python __all__ = ['pptv_download', 'pptv_download_by_id'] from ..common import * import re import time import urllib from random import random def constructKey(arg): def str2hex(s): r="" for i in s[:8]: t=hex(ord(i))[2:] if len(t)==1: t="0"+t r+=t for i in range(16): r+=hex(int(15*random()))[2:] return r #ABANDONED Because SERVER_KEY is static def getkey(s): #returns 1896220160 l2=[i for i in s] l4=0 l3=0 while l4<len(l2): l5=l2[l4] l6=ord(l5) l7=l6<<((l4%4)*8) l3=l3^l7 l4+=1 return l3 pass def rot(k,b): ##>>> in as3 if k>=0: return k>>b elif k<0: return (2**32+k)>>b pass def lot(k,b): return (k<<b)%(2**32) #WTF? def encrypt(arg1,arg2): delta=2654435769 l3=16; l4=getkey(arg2) #1896220160 l8=[i for i in arg1] l10=l4; l9=[i for i in arg2] l5=lot(l10,8)|rot(l10,24)#101056625 # assert l5==101056625 l6=lot(l10,16)|rot(l10,16)#100692230 # assert 100692230==l6 l7=lot(l10,24)|rot(l10,8) # assert 7407110==l7 l11="" l12=0 l13=ord(l8[l12])<<0 l14=ord(l8[l12+1])<<8 l15=ord(l8[l12+2])<<16 l16=ord(l8[l12+3])<<24 l17=ord(l8[l12+4])<<0 l18=ord(l8[l12+5])<<8 l19=ord(l8[l12+6])<<16 l20=ord(l8[l12+7])<<24 l21=(((0|l13)|l14)|l15)|l16 l22=(((0|l17)|l18)|l19)|l20 l23=0 l24=0 while l24<32: l23=(l23+delta)%(2**32) l33=(lot(l22,4)+l4)%(2**32) l34=(l22+l23)%(2**32) l35=(rot(l22,5)+l5)%(2**32) l36=(l33^l34)^l35 l21=(l21+l36)%(2**32) l37=(lot(l21,4)+l6)%(2**32) l38=(l21+l23)%(2**32) l39=(rot(l21,5))%(2**32) l40=(l39+l7)%(2**32) l41=((l37^l38)%(2**32)^l40)%(2**32) l22=(l22+l41)%(2**32) l24+=1 l11+=chr(rot(l21,0)&0xff) l11+=chr(rot(l21,8)&0xff) l11+=chr(rot(l21,16)&0xff) l11+=chr(rot(l21,24)&0xff) l11+=chr(rot(l22,0)&0xff) l11+=chr(rot(l22,8)&0xff) l11+=chr(rot(l22,16)&0xff) l11+=chr(rot(l22,24)&0xff) return l11 loc1=hex(int(arg))[2:]+(16-len(hex(int(arg))[2:]))*"\x00" SERVER_KEY="qqqqqww"+"\x00"*9 res=encrypt(loc1,SERVER_KEY) return str2hex(res) def pptv_download_by_id(id, title = None, output_dir = '.', merge = True, info_only = False): xml = get_html('http://web-play.pptv.com/webplay3-0-%s.xml?type=web.fpp' % id) #vt=3 means vod mode vt=5 means live mode host = r1(r'<sh>([^<>]+)</sh>', xml) k = r1(r'<key expire=[^<>]+>([^<>]+)</key>', xml) rid = r1(r'rid="([^"]+)"', xml) title = r1(r'nm="([^"]+)"', xml) st=r1(r'<st>([^<>]+)</st>',xml)[:-4] st=time.mktime(time.strptime(st))*1000-60*1000-time.time()*1000 st+=time.time()*1000 st=st/1000 key=constructKey(st) pieces = re.findall('<sgm no="(\d+)"[^<>]+fs="(\d+)"', xml) numbers, fs = zip(*pieces) urls=["http://{}/{}/{}?key={}&fpp.ver=1.3.0.4&k={}&type=web.fpp".format(host,i,rid,key,k) for i in range(max(map(int,numbers))+1)] total_size = sum(map(int, fs)) assert rid.endswith('.mp4') print_info(site_info, title, 'mp4', total_size) if not info_only: try: download_urls(urls, title, 'mp4', total_size, output_dir = output_dir, merge = merge) except urllib.error.HTTPError: #for key expired pptv_download_by_id(id, output_dir = output_dir, merge = merge, info_only = info_only) def pptv_download(url, output_dir = '.', merge = True, info_only = False, **kwargs): assert re.match(r'http://v.pptv.com/show/(\w+)\.html$', url) html = get_html(url) id = r1(r'webcfg\s*=\s*{"id":\s*(\d+)', html) assert id pptv_download_by_id(id, output_dir = output_dir, merge = merge, info_only = info_only) </code>

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Golang在性能和可擴展性方面優於Python。 1)Golang的編譯型特性和高效並發模型使其在高並發場景下表現出色。 2)Python作為解釋型語言,執行速度較慢,但通過工具如Cython可優化性能。

PHP仍然流行的原因是其易用性、靈活性和強大的生態系統。 1)易用性和簡單語法使其成為初學者的首選。 2)與web開發緊密結合,處理HTTP請求和數據庫交互出色。 3)龐大的生態系統提供了豐富的工具和庫。 4)活躍的社區和開源性質使其適應新需求和技術趨勢。

Python更易學且易用,C 則更強大但複雜。 1.Python語法簡潔,適合初學者,動態類型和自動內存管理使其易用,但可能導致運行時錯誤。 2.C 提供低級控制和高級特性,適合高性能應用,但學習門檻高,需手動管理內存和類型安全。

Python和JavaScript在開發環境上的選擇都很重要。 1)Python的開發環境包括PyCharm、JupyterNotebook和Anaconda,適合數據科學和快速原型開發。 2)JavaScript的開發環境包括Node.js、VSCode和Webpack,適用於前端和後端開發。根據項目需求選擇合適的工具可以提高開發效率和項目成功率。

Golangisidealforbuildingscalablesystemsduetoitsefficiencyandconcurrency,whilePythonexcelsinquickscriptinganddataanalysisduetoitssimplicityandvastecosystem.Golang'sdesignencouragesclean,readablecodeanditsgoroutinesenableefficientconcurrentoperations,t

IIS和PHP可以兼容,通過FastCGI實現。 1.IIS通過配置文件將.php文件請求轉發給FastCGI模塊。 2.FastCGI模塊啟動PHP進程處理請求,提高性能和穩定性。 3.實際應用中需注意配置細節、錯誤調試和性能優化。

Laravel適合團隊熟悉PHP且需功能豐富的項目,Python框架則視項目需求而定。 1.Laravel提供優雅語法和豐富功能,適合需要快速開發和靈活性的項目。 2.Django適合複雜應用,因其“電池包含”理念。 3.Flask適用於快速原型和小型項目,提供極大靈活性。

Python和C 各有優勢,選擇應基於項目需求。 1)Python適合快速開發和數據處理,因其簡潔語法和動態類型。 2)C 適用於高性能和系統編程,因其靜態類型和手動內存管理。
