當前位置: 首頁>>代碼示例>>Python>>正文


Python Decoder.rExtractWithRegex方法代碼示例

本文整理匯總了Python中core.decoder.Decoder.rExtractWithRegex方法的典型用法代碼示例。如果您正苦於以下問題:Python Decoder.rExtractWithRegex方法的具體用法?Python Decoder.rExtractWithRegex怎麽用?Python Decoder.rExtractWithRegex使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在core.decoder.Decoder的用法示例。


在下文中一共展示了Decoder.rExtractWithRegex方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: decodeContent

# 需要導入模塊: from core.decoder import Decoder [as 別名]
# 或者: from core.decoder.Decoder import rExtractWithRegex [as 別名]
 def decodeContent(html): #This method is used to fix a "probably" encoding/decoding problem from provider
     #new encoded iframe method
     logger.debug("trying new method for encrypted javascript code...")
     html2 = Decoder.extractWithRegex("eval(unescape('","'));",html)
     html3 = Decoder.rExtractWithRegex("eval(unescape('","'));",html)
     html3 = html3.replace("eval(","").replace("unescape(","").replace(" + ","").replace(")","").replace("'","").replace(";","")
     logger.debug("extracted code is: "+html3)
     decodedHtml = urllib.unquote(html2[:html2.find(";")+1]).decode('utf8')
     logger.debug("decypter function in javascript is: "+decodedHtml)
     encryptedCall = urllib.unquote(html3).decode('utf8')
     #encryptedCall = html3
     logger.debug("final html is: "+encryptedCall)
     #now extract encrypted string
     encryptedCall = Decoder.extract("('","'));",encryptedCall)
     splitter = Decoder.extract('s.split("','");',decodedHtml)
     logger.debug("splitter: "+splitter)
     subfixer = Decoder.extract('tmp[1] + "','");',decodedHtml)
     logger.debug("subfixer: "+subfixer)
     s = encryptedCall.split(splitter)[0]
     k = encryptedCall.split(splitter)[1]+subfixer
     xorDiff = int(Decoder.extract("charCodeAt(i))+",");",decodedHtml))
     #logger.debug(xorDiff)
     r = ""
     i = 0
     logger.debug("starting loop decoder, s: "+s+", k: "+k)
     '''
     r += String.fromCharCode((parseInt(k.charAt(i%k.length))^s.charCodeAt(i))+-2);
     '''
     CORRECTION = 16 #I don't know why but this convert it to legible character (most cases)
     mode = 0
     while i<len(s): #GO TO HELL, REALLY, I HAVE NO IDEA HOW THERE IS PEOPLE IN THE WORLD DOING THIS THING, DO YOU KNOW AN STANDARD ENCODING? YOU DOOOON'T!!!!
         seed = k[(i%len(k))]
         #logger.debug("seed: "+seed)
         primitive = ord(seed)^ord(s[i])
         #logger.debug("xorted: "+str(primitive))
         if len(r)==0 and str(primitive)!= '<':
             #tryes to check what fix is neccesary
             if str(primitive)=='15':
                 mode = 1
             elif str(primitive)=='14':
                 mode = 2
             elif str(primitive)=='4':
                 mode = 3
             elif str(primitive)=='7':
                 mode = 4
             elif str(primitive)=='9':
                 mode = 5
             else:
                 logger.debug("detected new start value: "+str(primitive)+", probably needs new encoding method")
         #mode 1 and mode 2
         if (str(primitive) == '1' and mode==1) or (mode==2 and str(primitive)=='0'):
             r += "."
         elif (str(primitive) == '2' and mode==1) or (mode==2 and (str(primitive)=='1' or str(primitive)=='113')):
             r += "/"
         elif (str(primitive) == '15' and mode==1) or (mode==2 and str(primitive)=='14') or (mode==3 and str(primitive)=='4') or (mode==4 and str(primitive)=='7') or (mode==5 and str(primitive)=='9'):
             r += "<"
         elif (str(primitive) == '112' and mode==1) or (mode==2 and str(primitive)=='15') or (str(primitive) == '5' and mode==3) or (str(primitive) == '8' and mode==4) or (mode==5 and str(primitive)=='10'):
             r += "="
         elif (str(primitive) == '113' and mode==1) or (mode==2 and str(primitive)=='112') or (str(primitive) == '6' and mode==3) or (str(primitive) == '9' and mode==4) or (mode==5 and str(primitive)=='11'):
             r += ">"
         elif (str(primitive) == '13' and mode==1) or (mode==2 and str(primitive)=='12') or (str(primitive) == '2' and mode==3) or (str(primitive) == '5' and mode==4) or (mode==5 and str(primitive)=='7'):
             r += ":"
         elif (int(str(primitive))-3<10 and mode==1):
             r += str(int(str(primitive))-3)
         elif (int(str(primitive))-2<10 and mode==2):
             r += str(int(str(primitive))-2)
         #mode 3
         elif (str(primitive) == '1' and mode==3) or (str(primitive) == '4' and mode==4):
             r += "9"
         elif (str(primitive) == '1' and mode==4) or (str(primitive) == '3' and mode==5):
             r += "6"
         elif (str(primitive) == '110' and mode==3):
             r += "f"
         elif (str(primitive) == '105' and mode==3) or (str(primitive) == '108' and mode==4) or (mode==5 and str(primitive)=='110'):
             r += "a"
         elif (str(primitive) == '109' and mode==3):
             r += "e"
         elif (str(primitive) == '40' and mode==3) or (str(primitive) == '43' and mode==4) or (mode==5 and str(primitive)=='45'):
             r += " "
         elif (str(primitive) == '108' and mode==3):
             r += "d"
         elif (str(primitive) == '42' and mode==3) or (str(primitive) == '45' and mode==4) or (mode==5 and str(primitive)=='47'):
             r += '"'
         elif (str(primitive) == '111' and mode==3):
             r += 'g'
         elif (str(primitive) == '81' and mode==3):
             r += 'i'
         elif (str(primitive) == '107' and mode==3) or (str(primitive) == '110' and mode==4):
             r += 'c'
         elif ((str(primitive) == '10' or str(primitive) == '106') and mode==3) or (str(primitive) == '109' and mode==4) or (mode==5 and str(primitive)=='111'):
             r += 'b'
         #mode 4
         elif mode==4 and str(primitive)=='105':
             r += 'a'
         elif  (str(primitive) == '111' and mode==4):
             r += 'd'
         #mode 5
         elif (mode==5 and str(primitive)=='1'):
             r += '4'
         elif (mode==5 and str(primitive)=='5'):
#.........這裏部分代碼省略.........
開發者ID:harddevelop,項目名稱:tvbox,代碼行數:103,代碼來源:cricfreetv.py


注:本文中的core.decoder.Decoder.rExtractWithRegex方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。