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


Python bencode.bdecode方法代碼示例

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


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

示例1: from_torrent_url

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bdecode [as 別名]
def from_torrent_url(url):
    import base64
    import bencode
    import hashlib
    import urllib
    from kmediatorrent.utils import url_get
    torrent_data = url_get(url)
    metadata = bencode.bdecode(torrent_data)
    hashcontents = bencode.bencode(metadata['info'])
    digest = hashlib.sha1(hashcontents).digest()
    b32hash = base64.b32encode(digest)
    params = {
        'dn': metadata['info']['name'],
        'tr': metadata['announce'],
    }
    plugin.log.info(params)
    paramstr = urllib.urlencode(params)
    return 'magnet:?%s&%s' % ('xt=urn:btih:%s' % b32hash, paramstr) 
開發者ID:jmarth,項目名稱:plugin.video.kmediatorrent,代碼行數:20,代碼來源:magnet.py

示例2: scrape_http

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bdecode [as 別名]
def scrape_http(announce, info_hash, peer_id, length):
    params = {'info_hash': info_hash,
               'peer_id': peer_id,
               'left': length}

    response = requests.get(announce, params=params)


    if response.status_code > 400:
            errorMsg = ("Failed to connect to tracker.\n"
                        "Status Code: %s \n"
                        "Reason: %s") % (response.status_code, response.reason)
            raise RuntimeError(errorMsg)

    results =  bencode.bdecode(response.content)
    return results['peers'] 
開發者ID:alyakhtar,項目名稱:Katastrophe,代碼行數:18,代碼來源:scrape.py

示例3: torrent_metainfo

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bdecode [as 別名]
def torrent_metainfo(torrent):
    logger.debug('def torrent_metainfo started')
    with open(torrent, 'rb') as f:
        torrent_data = f.read()
    metainfo = bencode.bdecode(torrent_data)
    name = metainfo['info']['name']
    return name 
開發者ID:piejanssens,項目名稱:premiumizer,代碼行數:9,代碼來源:premiumizer.py

示例4: torrent2magnet

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bdecode [as 別名]
def torrent2magnet(self, paths):
        def trans(tpath):
            if tpath.lower().endswith('torrent'):
                string = open(tpath).read()
                try:
                    dd = bencode.bdecode(string)
                except Exception as e:
                    print s % (1, 91, '  !! torrent is wrong:'), e
                    return None
                info = bencode.bencode(dd['info'])
                hh = sha1(info).hexdigest()
                print '# %s' % tpath
                print 'magnet:?xt=urn:btih:%s' % hh, '\n'

        for path in paths:
            if os.path.exists(path):
                if os.path.isdir(path):
                    for a, b, c in os.walk(path):
                        for i in c:
                            tpath = os.path.join(a, i)
                            trans(tpath)
                elif os.path.isfile(path):
                    tpath = path
                    trans(tpath)
            else:
                print s % (1, 91, '  !! file doesn\'t existed'), \
                    s % (1, 93, '--'), path 
開發者ID:PeterDing,項目名稱:iScript,代碼行數:29,代碼來源:bt.py

示例5: playlistdata

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bdecode [as 別名]
def playlistdata(self):
        self.playlist = []
        try:
            filelist = [x for x in os.listdir(str(config.directory)) if x.endswith(('.torrent','.torrent.added'))]
        except:
            self.logger.error("Can't load torrent files from %s" % config.directory)
            return False

        for filename in filelist:
            infohash = None
            idx = 0
            try:
               with open('%s/%s' % (config.directory, filename), "rb") as torrent_file: metainfo = bencode.bdecode(torrent_file.read())
               infohash = hashlib.sha1(bencode.bencode(metainfo['info'])).hexdigest()
            except: self.logger.error('The file %s may be corrupted. BencodeDecodeError!' % filename)
            else:
               self.logger.debug('%s' % filename)
               if 'files'in metainfo['info']:
                  try:
                     for files in metainfo['info']['files']:
                        if ''.join(files['path']).endswith(self.videoextdefaults):
                           self.playlist.append([''.join(files['path']).translate({ord(c): None for c in '%~}{][^$#@*,-!?&`|><+='}), infohash, str(idx), metainfo['info']['name']])
                           idx+=1
                  except Exception as e:
                     self.logger.error("Can't decode content of: %s\r\n%s" % (filename,repr(e)))
               else:
                    try:
                       self.playlist.append([metainfo['info']['name'].translate({ord(c): None for c in '%~}{][^$#@*,-!?&`|><+='}), infohash, '0', 'Other'])
                    except:
                       try:
                           self.playlist.append([filename.decode('utf-8').translate({ord(c): None for c in '%~}{][^$#@*,-!?&`|><+='}), infohash, '0', 'Other'])
                       except AttributeError:
                           self.playlist.append([filename.translate({ord(c): None for c in '%~}{][^$#@*,-!?&`|><+='}), infohash, '0', 'Other'])

        self.playlist.sort(key=lambda data: (data[3], data[0]))
        return True 
開發者ID:pepsik-kiev,項目名稱:HTTPAceProxy,代碼行數:38,代碼來源:torrentfilms_plugin.py

示例6: run

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bdecode [as 別名]
def run(self):
        self.re_join_DHT()
        while True:
            try:
                (data, address) = self.ufd.recvfrom(65536)
                msg = bdecode(data)
                self.on_message(msg, address)
            except Exception:
                pass 
開發者ID:xgfone,項目名稱:snippet,代碼行數:11,代碼來源:startCrawler.py

示例7: parse_metadata

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bdecode [as 別名]
def parse_metadata(self, data): #解析種子
        info = {}
        self.encoding = 'utf8'
        try:
            torrent = bdecode(data) #編碼後解析
            if not torrent.get('name'):
                return None
        except:
            return None
        detail = torrent
        info['name'] = self.decode_utf8(detail, 'name')
        if 'files' in detail:
            info['files'] = []
            for x in detail['files']:
                if 'path.utf-8' in x:
                    v = {'path': self.decode('/'.join(x['path.utf-8'])), 'length': x['length']}
                else:
                    v = {'path': self.decode('/'.join(x['path'])), 'length': x['length']}
                if 'filehash' in x:
                    v['filehash'] = x['filehash'].encode('hex')
                info['files'].append(v)
            info['length'] = sum([x['length'] for x in info['files']])
        else:
            info['length'] = detail['length']
        info['data_hash'] = hashlib.md5(detail['pieces']).hexdigest()
        return info 
開發者ID:xgfone,項目名稱:snippet,代碼行數:28,代碼來源:startCrawler.py

示例8: download_metadata

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bdecode [as 別名]
def download_metadata(address, infohash, metadata_queue, timeout=5):
    metadata = None
    start_time = time()
    try:
        the_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        the_socket.settimeout(timeout)
        the_socket.connect(address)

        # handshake
        send_handshake(the_socket, infohash)
        packet = the_socket.recv(4096)

        # handshake error
        if not check_handshake(packet, infohash):
            return

        # ext handshake
        send_ext_handshake(the_socket)
        packet = the_socket.recv(4096)

        # get ut_metadata and metadata_size
        ut_metadata, metadata_size = get_ut_metadata(packet), get_metadata_size(packet)
        #print 'ut_metadata_size: ', metadata_size

        # request each piece of metadata
        metadata = []
        for piece in range(int(math.ceil(metadata_size / (16.0 * 1024)))):
            request_metadata(the_socket, ut_metadata, piece)
            packet = recvall(the_socket, timeout)  #the_socket.recv(1024*17) #
            metadata.append(packet[packet.index("ee") + 2:])

        metadata = "".join(metadata)
        #print 'Fetched', bdecode(metadata)["name"], "size: ", len(metadata)

    except socket.timeout:
        pass
    except Exception:
        pass
    finally:
        the_socket.close()
        metadata_queue.put((infohash, address, metadata, 'pt', start_time)) 
開發者ID:xgfone,項目名稱:snippet,代碼行數:43,代碼來源:simMetadata.py

示例9: mask_file

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bdecode [as 別名]
def mask_file(torrent_file):
    '''
    混淆種子文件
    :param torrent_file: 種子文件
    :return: (混淆後的種子文件內容,混淆字典)
    '''
    with open(torrent_file, 'r') as fp:
        torrent_data = bencode.bdecode(fp.read())
    return mask(torrent_data) 
開發者ID:deadblue,項目名稱:baidupan_shell,代碼行數:11,代碼來源:bt.py

示例10: download_metadata

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bdecode [as 別名]
def download_metadata(address, infohash, timeout=5):
    try:
        the_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        the_socket.settimeout(5)
        the_socket.connect(address)

        # handshake
        send_handshake(the_socket, infohash)
        packet = the_socket.recv(4096)

        # handshake error
        if not check_handshake(packet, infohash):
            return

        # ext handshake
        send_ext_handshake(the_socket)
        packet = the_socket.recv(4096)

        # get ut_metadata and metadata_size
        ut_metadata, metadata_size = get_ut_metadata(packet), get_metadata_size(packet)
        print 'ut_metadata_size: ', metadata_size

        # request each piece of metadata
        metadata = []
        for piece in range(int(math.ceil(metadata_size/(16.0*1024)))):
            request_metadata(the_socket, ut_metadata, piece)
            packet = recvall(the_socket, timeout) #the_socket.recv(1024*17) #
            metadata.append(packet[packet.index("ee")+2:])

        metadata = "".join(metadata)

        print bdecode(metadata)["name"], "size: ", len(metadata)
        # with open(infohash.encode("hex")+'.txt', 'w') as f:
        #     f.write(metadata)
        # print 'write metadata, length:', len(metadata)

    except socket.timeout:
        pass
    except Exception, e:
        print e 
開發者ID:CreateChen,項目名稱:simDownloader,代碼行數:42,代碼來源:simMetadata.py

示例11: datagramReceived

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bdecode [as 別名]
def datagramReceived(self, data, address):
        """
        數據接收
        """
        try:
            res = bdecode(data)
            self.actionSwitch[res["y"]](res, address)     
        except(BTL.BTFailure, KeyError):
            pass 
開發者ID:wuzhenda,項目名稱:simDHT,代碼行數:11,代碼來源:krpc.py

示例12: __init__

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bdecode [as 別名]
def __init__(self, trackerFile):
        self.peer_id = '0987654321098765432-'
        self.peers = []
        self.pieces = deque([])
        self.tracker = bencode.bdecode(open(trackerFile,'rb').read())
        bencodeInfo = bencode.bencode(self.tracker['info'])
        self.infoHash = hashlib.sha1(bencodeInfo).digest()
        self.getPeers()
        self.generatePieces()
        self.numPiecesSoFar = 0 
開發者ID:alyakhtar,項目名稱:Katastrophe,代碼行數:12,代碼來源:peers.py

示例13: transfer

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bdecode [as 別名]
def transfer(self, string, tpath, foo=None, bar=None):
        self.dir_dict = {}
        self.sub_dir_index = 0

        dstring = bencode.bdecode(string)
        files = []
        file_index = 0

        ## change files' name
        if dstring['info'].get('files'):
            for fl in dstring['info']['files']:
                filename = fl['path'][-1]
                if args.type_ == 'n':
                    newfilename = re.sub(foo, bar, filename, re.I) \
                        if foo and bar else filename
                    if filename != newfilename:
                        print filename, s % (1, 92, '==>'), newfilename
                        path = [self._get_sub_dir_index(i) \
                                for i in fl['path'][:-1]]  + [newfilename]
                    else:
                        ext = os.path.splitext(filename)[-1]
                        ext = self._check_ext(ext)
                        path = [self._get_sub_dir_index(i) \
                                for i in fl['path'][:-1]] \
                                + ['%s%s' % (file_index, ext)]
                    file_index += 1
                    fl['path'] = path

                elif args.type_ == 'be64':
                    fn, ext = os.path.splitext(filename)
                    ext = self._check_ext(ext)
                    tfn = '/'.join(fl['path'][:-1] + [fn])
                    e_fn = base64.urlsafe_b64encode(tfn)
                    fl['path'] = [e_fn + '.base64' + ext]

                for item in fl.keys():
                    #if item not in ['path', 'length', 'filehash', 'ed2k']:
                    if item not in ['path', 'length', 'filehash']:
                        del fl[item]

                files.append(fl)
            dstring['info']['files'] = files

        ## change top directory
        for i in dstring['info'].keys():
            if i not in ['files', 'piece length', 'pieces', 'name', 'length']:
                del dstring['info'][i]
            elif 'name' in i:
                if args.name:
                    dstring['info'][i] = args.name

        ## delete comment and creator
        for i in dstring.keys():
            if i not in ['creation date', 'announce', 'info', 'encoding']:
                del dstring[i]

        c = bencode.bencode(dstring)
        with open(tpath, 'w') as g:
            g.write(c) 
開發者ID:PeterDing,項目名稱:iScript,代碼行數:61,代碼來源:bt.py

示例14: _open

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bdecode [as 別名]
def _open(self, url, silent = False):
        try:
            self.tries += 1
            if self.tries > MAX_REDIRECTS:
                raise IOError, ('http error', 500, 'Internal Server Error: Redirect Recursion')
            scheme, netloc, path, pars, query, fragment = urlparse(url)
            if scheme != 'http' and scheme != 'https':
                raise IOError, ('url error',
                 'unknown url type',
                 scheme,
                 url)
            wanturl = path
            if pars:
                wanturl += ';' + pars
            if query:
                wanturl += '?' + query
            proxyhost = find_proxy(url)
            if proxyhost is None:
                desthost = netloc
                desturl = wanturl
            else:
                desthost = proxyhost
                desturl = scheme + '://' + netloc + wanturl
            try:
                self.response = None
                if scheme == 'http':
                    self.connection = btHTTPcon(desthost)
                else:
                    self.connection = btHTTPScon(desthost)
                self.connection.request('GET', desturl, None, {'Host': netloc,
                 'User-Agent': VERSION,
                 'Accept-Encoding': 'gzip'})
                self.response = self.connection.getresponse()
            except HTTPException as e:
                raise IOError, ('http error', str(e))

            status = self.response.status
            if status in (301, 302):
                try:
                    self.connection.close()
                except:
                    pass

                self._open(self.response.getheader('Location'))
                return
            if status != 200:
                try:
                    data = self._read()
                    d = bdecode(data)
                    if d.has_key('failure reason'):
                        self.error_return = data
                        return
                except:
                    pass

                raise IOError, ('http error', status, self.response.reason)
        except Exception as e:
            if not silent:
                print_exc()
                print >> sys.stderr, 'zurllib: URL was', url, e 
開發者ID:alesnav,項目名稱:p2ptv-pi,代碼行數:62,代碼來源:zurllib.py

示例15: parse_metadata

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bdecode [as 別名]
def parse_metadata(data):
    info = {}
    encoding = 'utf8'
    try:
        torrent = bdecode(data)
        if not torrent.get('name'):
            return None
    except:
        return None
    try:
        info['create_time'] = datetime.datetime.fromtimestamp(float(torrent['creation date']))
    except:
        info['create_time'] = datetime.datetime.utcnow()

    if torrent.get('encoding'):
        encoding = torrent['encoding']
    if torrent.get('announce'):
        info['announce'] = decode_utf8(encoding, torrent, 'announce')
    if torrent.get('comment'):
        info['comment'] = decode_utf8(encoding, torrent, 'comment')[:200]
    if torrent.get('publisher-url'):
        info['publisher-url'] = decode_utf8(encoding, torrent, 'publisher-url')
    if torrent.get('publisher'):
        info['publisher'] = decode_utf8(encoding, torrent, 'publisher')
    if torrent.get('created by'):
        info['creator'] = decode_utf8(encoding, torrent, 'created by')[:15]

    if 'info' in torrent:
        detail = torrent['info']
    else:
        detail = torrent
    info['name'] = decode_utf8(encoding, detail, 'name')
    if 'files' in detail:
        info['files'] = []
        for x in detail['files']:
            if 'path.utf-8' in x:
                v = {'path': decode(encoding, '/'.join(x['path.utf-8'])), 'length': x['length']}
            else:
                v = {'path': decode(encoding, '/'.join(x['path'])), 'length': x['length']}
            if 'filehash' in x:
                v['filehash'] = x['filehash'].encode('hex')
            info['files'].append(v)
        info['length'] = sum([x['length'] for x in info['files']])
    else:
        info['length'] = detail['length']
    info['data_hash'] = hashlib.md5(detail['pieces']).hexdigest()
    if 'profiles' in detail:
        info['profiles'] = detail['profiles']
    return info 
開發者ID:xgfone,項目名稱:snippet,代碼行數:51,代碼來源:metadata.py


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