使用python编写的爬虫给X站视频增加一个播放量

这篇具有很好参考价值的文章主要介绍了使用python编写的爬虫给X站视频增加一个播放量。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

前言

一、增加播放量的请求分析

1.请求网址:

 2.请求分析:

 3.对cookie分析:

4. 对荷载分析:

二、代码实现

总结拓展


前言

在平时观看X站视频的过程中,一个视频的播放量需要点击播放来增加,而在代码中如何实现播放量的增加呢,本篇文章就带你实现在代码中增加一个播放量。


提示:以下是本篇文章正文内容,下面案例可供参考

一、增加播放量的请求分析

1.请求网址:

video_url = b'aHR0cHM6Ly93d3cuYmlsaWJpbGkuY29tL3ZpZGVvL0JWMXZNNHkxQzdGUS8='

 2.请求分析:

经过多次验证X站中视频播放量增加的请求为h5这个请求,其截图如图:

使用python编写的爬虫给X站视频增加一个播放量,爬虫,python,开发语言

使用python编写的爬虫给X站视频增加一个播放量,爬虫,python,开发语言

 3.对cookie分析:

使用python编写的爬虫给X站视频增加一个播放量,爬虫,python,开发语言

4. 对荷载分析:

使用python编写的爬虫给X站视频增加一个播放量,爬虫,python,开发语言

二、代码实现

代码如下(示例):

python代码:

import os
import re
import time
import json
import datetime

import uuid
import execjs
import shutil
import requests
import subprocess
from loguru import logger
from functools import partial


class generated_parameter():

    def __init__(self, video_url):
        self.video_url = video_url
        self.my_log()

    def my_log(self):
        """
        日志模块
        :return:
        """
        logger.add("logs/{time:YYYY-MM-DD}.log",
                   format="{time:YYYY-MM-DD HH:mm:ss.SSS} |{level:8}| {name} : {module}:{line:4} | - {message} |({file}:{line})",
                   rotation="00:00", compression="zip")
        # 超过七天自动压缩
        logs_dir = "../bilibili/logs"
        for filename in os.listdir(logs_dir):
            filepath = os.path.join(logs_dir, filename)
            if os.path.isfile(filepath):
                creation_time = datetime.datetime.fromtimestamp(os.path.getctime(filepath))
                if (datetime.datetime.now() - creation_time).days > 7:
                    shutil.make_archive(filepath, "zip", logs_dir, filename)
                    os.remove(filepath)

    def get_a(self):
        """
        aid、cid提取
        :return: 包含aid、cid的字典
        """
        url = self.video_url
        headers = {
            "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/115.0.0.0 Safari/537.36"
        }
        req = requests.get(url=url, headers=headers)

        data_list = re.findall(r'__INITIAL_STATE__=(.+);\(function', req.text)
        data_dict = json.loads(data_list[0])

        return data_dict

    def gen_uuid(self):
        """
        uuid生成
        """
        uuid_sec = str(uuid.uuid4())
        time_sec = str(int(time.time() * 1000 % 1e5))
        time_sec = time_sec.rjust(5, "0")
        return "{}{}infoc".format(uuid_sec, time_sec)

    def open_js(self, method_names):
        """
        js调用
        :param method_names: 要调用的js方法名
        :return: js调用的结果
        """
        subprocess.Popen = partial(subprocess.Popen, encoding="utf-8")
        with open("bili.js", mode="r", encoding="utf-8") as f:
            ex_js = execjs.compile(f.read())
        return ex_js.call(f"{method_names}")

    def get_bt34(self):
        """
        b_nut、buvid3、buvid4三个参数提取
        :return: 包含b_nut、buvid3、buvid4三个的列表
        """
        url = self.video_url
        session = requests.Session()
        session.headers.update({
            "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/115.0.0.0 Safari/537.36"})
        req = session.get(url=url)

        spi_url = 'https://api.bilibili.com/x/frontend/finger/spi'
        spi_rep = session.get(spi_url)

        b_nut = dict(req.cookies)['b_nut']
        buvid3 = dict(req.cookies)['buvid3']
        buvid4 = spi_rep.json()['data']['b_4'].replace('/', '%2F').replace('=', '%3D%3D')

        return [b_nut, buvid3, buvid4]


def post_h5(bvid, buvid4, buvid3, b_nut, b_lsid, my_uuid, buvid_fp, aid, cid, now_time):
    """
    请求h5网址
    """
    url = 'https://api.bilibili.com/x/click-interface/click/web/h5'
    headers = {
        "Referer": f"https://www.bilibili.com/video/{bvid}/",
        "Cookie": f"buvid4={buvid4}; buvid3={buvid3}; b_nut={b_nut}; CURRENT_FNVAL=4048; sid=g6e519i7; b_lsid={b_lsid}; _uuid={my_uuid}; buvid_fp={buvid_fp}",
        "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/115.0.0.0 Safari/537.36"
    }
    params = {
        "aid": aid,
        "cid": cid,
        "part": "1",
        "lv": "0",
        "ftime": now_time,
        "stime": now_time,
        "type": "3",
        "sub_type": "0",
        "refer_url": '',
        "spmid": "333.788.0.0",
        "from_spmid": "",
        "csrf": "",
    }
    req = requests.post(url=url, headers=headers, params=params)

    return req


def task(video_url):
    """
    生成参数,调用视频播放量增加的网址
    :return:
    """

    bvid = video_url.rsplit("/")

    if not bvid[-1]:
        bvid = bvid[-2]
    else:
        bvid = bvid[-1]

    gen_par = generated_parameter(video_url)

    data_dict = gen_par.get_a()
    aid = data_dict['aid']
    cid = data_dict['videoData']['cid']
    now_time = int(time.time())

    my_uuid = gen_par.gen_uuid()
    b_lsid = gen_par.open_js("b_lsid")
    buvid_fp = gen_par.open_js("buvid_fp")

    b_nut = gen_par.get_bt34()[0]
    buvid3 = gen_par.get_bt34()[1]
    buvid4 = gen_par.get_bt34()[2]

    post_h5(bvid, buvid4, buvid3, b_nut, b_lsid, my_uuid, buvid_fp, aid, cid, now_time)
    # 运行成功网址写进日志
    logger.info(f"Info 视频网址:{video_url}")


if __name__ == '__main__':
    video_url = ""
    task(video_url)

 js代码:

function b_lsid() {
    function splitDate(e) {
        var t = new Date(e || Date.now())
            , r = t.getDate()
            , n = t.getHours()
            , e = t.getMinutes()
            , t = t.getTime();
        return {
            day: r,
            hour: n,
            minute: e,
            second: Math.floor(t / 1e3),
            millisecond: t
        }
    }

    function hr(e) {
        return Math.ceil(e).toString(16).toUpperCase()
    }

    function s(e, t) {
        var r = "";
        if (e.length < t)
            for (var n = 0; n < t - e.length; n++)
                r += "0";
        return r + e
    }

    function l(e) {
        for (var t = "", r = 0; r < e; r++)
            t += hr(16 * Math.random());
        return s(t, e)
    }

    var e = splitDate()
        , t = hr(e.millisecond)
    return "".concat(l(8), "_").concat(t)

}

function buvid_fp() {
    var e = [
        {
            "key": "userAgent",
            "value": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/115.0.0.0 Safari/537.36"
        },
        {
            "key": "webdriver",
            "value": false
        },
        {
            "key": "language",
            "value": "zh-CN"
        },
        {
            "key": "colorDepth",
            "value": 24
        },
        {
            "key": "deviceMemory",
            "value": 8
        },
        {
            "key": "hardwareConcurrency",
            "value": 12
        },
        {
            "key": "screenResolution",
            "value": [
                2048,
                1152
            ]
        },
        {
            "key": "availableScreenResolution",
            "value": [
                2048,
                1112
            ]
        },
        {
            "key": "timezoneOffset",
            "value": -480
        },
        {
            "key": "timezone",
            "value": "Asia/Shanghai"
        },
        {
            "key": "sessionStorage",
            "value": true
        },
        {
            "key": "localStorage",
            "value": true
        },
        {
            "key": "indexedDb",
            "value": true
        },
        {
            "key": "addBehavior",
            "value": false
        },
        {
            "key": "openDatabase",
            "value": true
        },
        {
            "key": "cpuClass",
            "value": "not available"
        },
        {
            "key": "platform",
            "value": "Win32"
        },
        {
            "key": "plugins",
            "value": [
                [
                    "PDF Viewer",
                    "Portable Document Format",
                    [
                        [
                            "application/pdf",
                            "pdf"
                        ],
                        [
                            "text/pdf",
                            "pdf"
                        ]
                    ]
                ],
                [
                    "Chrome PDF Viewer",
                    "Portable Document Format",
                    [
                        [
                            "application/pdf",
                            "pdf"
                        ],
                        [
                            "text/pdf",
                            "pdf"
                        ]
                    ]
                ],
                [
                    "Chromium PDF Viewer",
                    "Portable Document Format",
                    [
                        [
                            "application/pdf",
                            "pdf"
                        ],
                        [
                            "text/pdf",
                            "pdf"
                        ]
                    ]
                ],
                [
                    "Microsoft Edge PDF Viewer",
                    "Portable Document Format",
                    [
                        [
                            "application/pdf",
                            "pdf"
                        ],
                        [
                            "text/pdf",
                            "pdf"
                        ]
                    ]
                ],
                [
                    "WebKit built-in PDF",
                    "Portable Document Format",
                    [
                        [
                            "application/pdf",
                            "pdf"
                        ],
                        [
                            "text/pdf",
                            "pdf"
                        ]
                    ]
                ]
            ]
        },
        {
            "key": "canvas",
            "value": [
                "canvas winding:yes",
                "canvas fp:"
            ]
        },
        {
            "key": "webgl",
            "value": [
                "",
                "extensions:ANGLE_instanced_arrays;EXT_blend_minmax;EXT_color_buffer_half_float;EXT_disjoint_timer_query;EXT_float_blend;EXT_frag_depth;EXT_shader_texture_lod;EXT_texture_compression_bptc;EXT_texture_compression_rgtc;EXT_texture_filter_anisotropic;EXT_sRGB;KHR_parallel_shader_compile;OES_element_index_uint;OES_fbo_render_mipmap;OES_standard_derivatives;OES_texture_float;OES_texture_float_linear;OES_texture_half_float;OES_texture_half_float_linear;OES_vertex_array_object;WEBGL_color_buffer_float;WEBGL_compressed_texture_s3tc;WEBGL_compressed_texture_s3tc_srgb;WEBGL_debug_renderer_info;WEBGL_debug_shaders;WEBGL_depth_texture;WEBGL_draw_buffers;WEBGL_lose_context;WEBGL_multi_draw",
                "webgl aliased line width range:[1, 1]",
                "webgl aliased point size range:[1, 1024]",
                "webgl alpha bits:8",
                "webgl antialiasing:yes",
                "webgl blue bits:8",
                "webgl depth bits:24",
                "webgl green bits:8",
                "webgl max anisotropy:16",
                "webgl max combined texture image units:32",
                "webgl max cube map texture size:16384",
                "webgl max fragment uniform vectors:1024",
                "webgl max render buffer size:16384",
                "webgl max texture image units:16",
                "webgl max texture size:16384",
                "webgl max varying vectors:30",
                "webgl max vertex attribs:16",
                "webgl max vertex texture image units:16",
                "webgl max vertex uniform vectors:4095",
                "webgl max viewport dims:[32767, 32767]",
                "webgl red bits:8",
                "webgl renderer:WebKit WebGL",
                "webgl shading language version:WebGL GLSL ES 1.0 (OpenGL ES GLSL ES 1.0 Chromium)",
                "webgl stencil bits:0",
                "webgl vendor:WebKit",
                "webgl version:WebGL 1.0 (OpenGL ES 2.0 Chromium)",
                "webgl unmasked vendor:Google Inc. (NVIDIA)",
                "webgl unmasked renderer:ANGLE (NVIDIA, NVIDIA GeForce GTX 1660 Ti Direct3D11 vs_5_0 ps_5_0, D3D11)",
                "webgl vertex shader high float precision:23",
                "webgl vertex shader high float precision rangeMin:127",
                "webgl vertex shader high float precision rangeMax:127",
                "webgl vertex shader medium float precision:23",
                "webgl vertex shader medium float precision rangeMin:127",
                "webgl vertex shader medium float precision rangeMax:127",
                "webgl vertex shader low float precision:23",
                "webgl vertex shader low float precision rangeMin:127",
                "webgl vertex shader low float precision rangeMax:127",
                "webgl fragment shader high float precision:23",
                "webgl fragment shader high float precision rangeMin:127",
                "webgl fragment shader high float precision rangeMax:127",
                "webgl fragment shader medium float precision:23",
                "webgl fragment shader medium float precision rangeMin:127",
                "webgl fragment shader medium float precision rangeMax:127",
                "webgl fragment shader low float precision:23",
                "webgl fragment shader low float precision rangeMin:127",
                "webgl fragment shader low float precision rangeMax:127",
                "webgl vertex shader high int precision:0",
                "webgl vertex shader high int precision rangeMin:31",
                "webgl vertex shader high int precision rangeMax:30",
                "webgl vertex shader medium int precision:0",
                "webgl vertex shader medium int precision rangeMin:31",
                "webgl vertex shader medium int precision rangeMax:30",
                "webgl vertex shader low int precision:0",
                "webgl vertex shader low int precision rangeMin:31",
                "webgl vertex shader low int precision rangeMax:30",
                "webgl fragment shader high int precision:0",
                "webgl fragment shader high int precision rangeMin:31",
                "webgl fragment shader high int precision rangeMax:30",
                "webgl fragment shader medium int precision:0",
                "webgl fragment shader medium int precision rangeMin:31",
                "webgl fragment shader medium int precision rangeMax:30",
                "webgl fragment shader low int precision:0",
                "webgl fragment shader low int precision rangeMin:31",
                "webgl fragment shader low int precision rangeMax:30"
            ]
        },
        {
            "key": "webglVendorAndRenderer",
            "value": "Google Inc. (NVIDIA)~ANGLE (NVIDIA, NVIDIA GeForce GTX 1660 Ti Direct3D11 vs_5_0 ps_5_0, D3D11)"
        },
        {
            "key": "hasLiedLanguages",
            "value": false
        },
        {
            "key": "hasLiedResolution",
            "value": false
        },
        {
            "key": "hasLiedOs",
            "value": false
        },
        {
            "key": "hasLiedBrowser",
            "value": false
        },
        {
            "key": "touchSupport",
            "value": [
                0,
                false,
                false
            ]
        },
        {
            "key": "fonts",
            "value": [
                "Arial",
                "Arial Black",
                "Arial Narrow",
                "Book Antiqua",
                "Bookman Old Style",
                "Calibri",
                "Cambria",
                "Cambria Math",
                "Century",
                "Century Gothic",
                "Century Schoolbook",
                "Comic Sans MS",
                "Consolas",
                "Courier",
                "Courier New",
                "Georgia",
                "Helvetica",
                "Impact",
                "Lucida Bright",
                "Lucida Calligraphy",
                "Lucida Console",
                "Lucida Fax",
                "Lucida Handwriting",
                "Lucida Sans",
                "Lucida Sans Typewriter",
                "Lucida Sans Unicode",
                "Microsoft Sans Serif",
                "Monotype Corsiva",
                "MS Gothic",
                "MS PGothic",
                "MS Reference Sans Serif",
                "MS Sans Serif",
                "MS Serif",
                "Palatino Linotype",
                "Segoe Print",
                "Segoe Script",
                "Segoe UI",
                "Segoe UI Light",
                "Segoe UI Semibold",
                "Segoe UI Symbol",
                "Tahoma",
                "Times",
                "Times New Roman",
                "Trebuchet MS",
                "Verdana",
                "Wingdings",
                "Wingdings 2",
                "Wingdings 3"
            ]
        },
        {
            "key": "audio",
            "value": "124.04347527516074"
        }
    ]

    var t = e.map(function (e) {
        return e.value
    }).join("")

    var g = function (e, t) {
        e = [e[0] >>> 16, 65535 & e[0], e[1] >>> 16, 65535 & e[1]],
            t = [t[0] >>> 16, 65535 & t[0], t[1] >>> 16, 65535 & t[1]];
        var r = [0, 0, 0, 0];
        return r[3] += e[3] * t[3],
            r[2] += r[3] >>> 16,
            r[3] &= 65535,
            r[2] += e[2] * t[3],
            r[1] += r[2] >>> 16,
            r[2] &= 65535,
            r[2] += e[3] * t[2],
            r[1] += r[2] >>> 16,
            r[2] &= 65535,
            r[1] += e[1] * t[3],
            r[0] += r[1] >>> 16,
            r[1] &= 65535,
            r[1] += e[2] * t[2],
            r[0] += r[1] >>> 16,
            r[1] &= 65535,
            r[1] += e[3] * t[1],
            r[0] += r[1] >>> 16,
            r[1] &= 65535,
            r[0] += e[0] * t[3] + e[1] * t[2] + e[2] * t[1] + e[3] * t[0],
            r[0] &= 65535,
            [r[0] << 16 | r[1], r[2] << 16 | r[3]]
    }
        , v = function (e, t) {
        return [e[0] ^ t[0], e[1] ^ t[1]]
    }
        , e = {
        preprocessor: null,
        audio: {
            timeout: 1e3,
            excludeIOS11: !0
        },
        fonts: {
            swfContainerId: "fingerprintjs2",
            swfPath: "flash/compiled/FontList.swf",
            userDefinedFonts: [],
            extendedJsFonts: !1
        },
        screen: {
            detectScreenOrientation: !0
        },
        plugins: {
            sortPluginsFor: [/palemoon/i],
            excludeIE: !1
        },
        extraComponents: [],
        excludes: {
            enumerateDevices: !0,
            pixelRatio: !0,
            doNotTrack: !0,
            fontsFlash: !0,
            adBlock: !0
        },
        NOT_AVAILABLE: "not available",
        ERROR: "error",
        EXCLUDED: "excluded"
    }
        , m = function (e, t) {
        if (Array.prototype.forEach && e.forEach === Array.prototype.forEach)
            e.forEach(t);
        else if (e.length === +e.length)
            for (var r = 0, n = e.length; r < n; r++)
                t(e[r], r, e);
        else
            for (var o in e)
                e.hasOwnProperty(o) && t(e[o], o, e)
    }
        , i = function (e) {
        for (var t = !1, r = 0, n = e.plugins.sortPluginsFor.length; r < n; r++) {
            var o = e.plugins.sortPluginsFor[r];
            if (navigator.userAgent.match(o)) {
                t = !0;
                break
            }
        }
        return t
    }
        , a = function () {
        var e = document.createElement("canvas");
        return !(!e.getContext || !e.getContext("2d"))
    }
        , f = function (e) {
        var t = document.createElement("div");
        t.setAttribute("id", e.fonts.swfContainerId),
            document.body.appendChild(t)
    }
        , y = function () {
        var e = document.createElement("canvas")
            , t = null;
        try {
            t = e.getContext("webgl") || e.getContext("experimental-webgl")
        } catch (e) {
        }
        return t = t || null
    }
        , b = function (e) {
        e = e.getExtension("WEBGL_lose_context");
        null != e && e.loseContext()
    }

    function d(e, t) {
        return 32 === (t %= 64) ? [e[1], e[0]] : t < 32 ? [e[0] << t | e[1] >>> 32 - t, e[1] << t | e[0] >>> 32 - t] : [e[1] << (t -= 32) | e[0] >>> 32 - t, e[0] << t | e[1] >>> 32 - t]
    }

    function l(e, t) {
        e = [e[0] >>> 16, 65535 & e[0], e[1] >>> 16, 65535 & e[1]],
            t = [t[0] >>> 16, 65535 & t[0], t[1] >>> 16, 65535 & t[1]];
        var r = [0, 0, 0, 0];
        return r[3] += e[3] + t[3],
            r[2] += r[3] >>> 16,
            r[3] &= 65535,
            r[2] += e[2] + t[2],
            r[1] += r[2] >>> 16,
            r[2] &= 65535,
            r[1] += e[1] + t[1],
            r[0] += r[1] >>> 16,
            r[1] &= 65535,
            r[0] += e[0] + t[0],
            r[0] &= 65535,
            [r[0] << 16 | r[1], r[2] << 16 | r[3]]
    }

    function p(e, t) {
        return 0 === (t %= 64) ? e : t < 32 ? [e[0] << t | e[1] >>> 32 - t, e[1] << t] : [e[1] << t - 32, 0]
    }

    function h(e) {
        return e = v(e, [0, e[0] >>> 1]),
            e = g(e, [4283543511, 3981806797]),
            e = v(e, [0, e[0] >>> 1]),
            e = g(e, [3301882366, 444984403]),
            e = v(e, [0, e[0] >>> 1])
    }

    function s(e, t) {
        for (var r = (e = e || "").length % 16, n = e.length - r, o = [0, t = t || 0], i = [0, t], a = [0, 0], s = [0, 0], u = [2277735313, 289559509], c = [1291169091, 658871167], f = 0; f < n; f += 16)
            a = [255 & e.charCodeAt(f + 4) | (255 & e.charCodeAt(f + 5)) << 8 | (255 & e.charCodeAt(f + 6)) << 16 | (255 & e.charCodeAt(f + 7)) << 24, 255 & e.charCodeAt(f) | (255 & e.charCodeAt(f + 1)) << 8 | (255 & e.charCodeAt(f + 2)) << 16 | (255 & e.charCodeAt(f + 3)) << 24],
                s = [255 & e.charCodeAt(f + 12) | (255 & e.charCodeAt(f + 13)) << 8 | (255 & e.charCodeAt(f + 14)) << 16 | (255 & e.charCodeAt(f + 15)) << 24, 255 & e.charCodeAt(f + 8) | (255 & e.charCodeAt(f + 9)) << 8 | (255 & e.charCodeAt(f + 10)) << 16 | (255 & e.charCodeAt(f + 11)) << 24],
                a = g(a, u),
                a = d(a, 31),
                a = g(a, c),
                o = v(o, a),
                o = d(o, 27),
                o = l(o, i),
                o = l(g(o, [0, 5]), [0, 1390208809]),
                s = g(s, c),
                s = d(s, 33),
                s = g(s, u),
                i = v(i, s),
                i = d(i, 31),
                i = l(i, o),
                i = l(g(i, [0, 5]), [0, 944331445]);
        switch (a = [0, 0],
            s = [0, 0],
            r) {
            case 15:
                s = v(s, p([0, e.charCodeAt(f + 14)], 48));
            case 14:
                s = v(s, p([0, e.charCodeAt(f + 13)], 40));
            case 13:
                s = v(s, p([0, e.charCodeAt(f + 12)], 32));
            case 12:
                s = v(s, p([0, e.charCodeAt(f + 11)], 24));
            case 11:
                s = v(s, p([0, e.charCodeAt(f + 10)], 16));
            case 10:
                s = v(s, p([0, e.charCodeAt(f + 9)], 8));
            case 9:
                s = v(s, [0, e.charCodeAt(f + 8)]),
                    s = g(s, c),
                    s = d(s, 33),
                    s = g(s, u),
                    i = v(i, s);
            case 8:
                a = v(a, p([0, e.charCodeAt(f + 7)], 56));
            case 7:
                a = v(a, p([0, e.charCodeAt(f + 6)], 48));
            case 6:
                a = v(a, p([0, e.charCodeAt(f + 5)], 40));
            case 5:
                a = v(a, p([0, e.charCodeAt(f + 4)], 32));
            case 4:
                a = v(a, p([0, e.charCodeAt(f + 3)], 24));
            case 3:
                a = v(a, p([0, e.charCodeAt(f + 2)], 16));
            case 2:
                a = v(a, p([0, e.charCodeAt(f + 1)], 8));
            case 1:
                a = v(a, [0, e.charCodeAt(f)]),
                    a = g(a, u),
                    a = d(a, 31),
                    a = g(a, c),
                    o = v(o, a)
        }
        return o = v(o, [0, e.length]),
            i = v(i, [0, e.length]),
            o = l(o, i),
            i = l(i, o),
            o = h(o),
            i = h(i),
            o = l(o, i),
            i = l(i, o),
        ("00000000" + (o[0] >>> 0).toString(16)).slice(-8) + ("00000000" + (o[1] >>> 0).toString(16)).slice(-8) + ("00000000" + (i[0] >>> 0).toString(16)).slice(-8) + ("00000000" + (i[1] >>> 0).toString(16)).slice(-8)
    }

    return s(t, 31)
}

总结拓展

1.总结

cookie中的参数uuid使用第三方库生成,b_lsid、buvid_fp使用js生成。在程序运行的过程中运行的运行过网址会保存在日志中,超过七天的日志则自动打包压缩。

2.拓展

本文只增加了视频的播放量,与之相应的还有完播率,完播率的请求为heartbeat请求实现。

要给一个视频增加多个播放量需要使用代理ip实现,同一个ip只能给一个视频增加极少的播放量。

3.源码下载

码云:bilibili: bilibili播放量增加爬虫文章来源地址https://www.toymoban.com/news/detail-755238.html

到了这里,关于使用python编写的爬虫给X站视频增加一个播放量的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Web前端开发技术课程实验一——制作一个视频播放页面(可控制播放/暂停)

    学习Web前端中的视频网页制作 学会html和js相结合 学会视频播放/暂停/放缩大小的功能 掌握 html 基本语法 掌握javascript基本语法 掌握条件语句 周一至周五晚上 7 点—晚上9点

    2024年02月16日
    浏览(38)
  • <Python>PyQt5+ffmpeg,简单视频播放器的编写(解码器:K-lite)

    更新日志: 202211251640:第一版,基本功能:视频导入,播放、暂停、播放时间显示、音量控制 概述:本文是利用PyQt5加上ffmpeg来编写一个具备基本功能的视频播放器(播放、暂停、进度调整、音量调整、视频播放列表、文件夹导入视频等) 实现步骤设想:PyQt制作UI界面,利

    2024年02月16日
    浏览(40)
  • Python爬虫:给我一个链接,西瓜视频随便下载

    1.实现原理 首先,我们需要来到西瓜视频的官网,链接为:西瓜视频,随便点击其中一个视频进入,点击电脑键盘的F12来到开发者模式,按ctrl+F进行搜索,输入video,如下: 我们可以发现,这里有一个视频链接,我们点击这个链接进入,依旧按电脑F12键来到开发者模式,继续

    2024年02月14日
    浏览(69)
  • 使用Python开发一个自动给抖音视频点赞的功能

    目录 1、解释说明: 2、使用示例: 3、注意事项: Python是一种高级编程语言,广泛应用于软件开发、数据分析、人工智能等领域。在抖音这样的短视频平台上,用户可以对喜欢的视频进行点赞。本模块将介绍如何使用Python开发一个自动给抖音视频点赞的功能。 首先,需要安

    2024年02月04日
    浏览(42)
  • kotlin 编写一个简单的天气预报app(二)增加搜索城市功能

    在activity_main.xml里增加输入框来输入城市,在输入款旁边增加搜索按钮来进行查询。 然后原来显示helloworld的TextView用来显示结果。 增加搜索按钮 使用broadcast的方式把收到的天气信息发送到界面显示。 Android的广播机制是一种用于在应用程序内和应用程序之间传递消息和事件的

    2024年02月14日
    浏览(32)
  • 使用Python编写搜索引擎关键词排名监测爬虫

    目录 1. 了解排名监测的重要性 2. 选择合适的搜索引擎 3. 构建排名监测爬虫

    2024年02月09日
    浏览(45)
  • 测试C#调用Aplayer播放视频(3:编写简易播放器)

      学习了参考文献1中的示例代码,也找出了前一篇文章中自己测试控件但无法播放视频的问题(没有将解码库文件复制到可执行程序所在的codecs文件夹内),本文基于APlayer组件编写简单的视频播放器,主要实现以下功能: 序号 功能 说明 1 自定义logo 调用SetCustomLogo函数设

    2024年02月05日
    浏览(56)
  • 使用Python编写一个渗透测试探测工具

    本篇将会涉及: 资源探测 一个有用的字典资源 第一个暴力探测器 资源探测 资源探测在渗透测试中还是属于资源的映射和信息的收集阶段。 主要有以下三个类型: 字典攻击 暴力破解 模糊测试 字典攻击,在破解密码或密钥的时候,通过自定义的字典文件,有针对性地尝试字

    2024年01月16日
    浏览(35)
  • 求助 爬虫视频无法播放,显示文件已损坏

    import requests import json #数据抓取 base_url=\\\"https://haokan.baidu.com/haokan/ui-search/pc/search/video?pn=1rn=10type=videoquery=%E9%93%81%E8%BD%A8%E4%B8%8B%E9%9B%A8sign=d0fa20768e3d07642df1ae7734d1793cversion=1timestamp=1688716281831\\\" headers={ \\\'user-agent\\\':\\\'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.

    2024年02月08日
    浏览(50)
  • 音视频开发:ffplay使用ffmpeg滤镜实现倍速播放

    曾经为实现倍速播放使用过ffmpeg,对音频使用atempo滤镜即可实现变速不变调。但是当时效果并不是特别好,和soundtouch相比处理后的音质有明显的区别。最近用新版本的ffmpeg滤镜重新实现了倍速播放,发现效果变好,已经达到可接受的程度,所以在此分享具体实现。 ffmpeg倍速

    2024年02月03日
    浏览(68)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包