Greasy Fork is available in English.

PotPlayer云盘-专供版

此脚本为《PotPlayer播放云盘视频》姊妹篇,需配合MediaPlayParse - PanVideo.as脚本使用。在potplayer中选择画质、字幕,迅雷云盘增加原画,阿里云盘增加时长。

< PotPlayer云盘-专供版 피드백

리뷰: 좋음 - 잘 동작함

§
작성: 2022-05-27

请问为什么老脚本能用,专供版这个一直报错呢?

bleu개발자
§
작성: 2022-05-27

你用的MediaPlayParse - PanVideo.as,是自己修改过的吧,你看它提示的错误行数修改一下

§
작성: 2022-05-28

没修改过,我不懂编程和代码的

bleu개발자
§
작성: 2022-05-28
수정: 2022-05-28

那你就在github页面重新下载一下文件,按照操作重新搞一下

§
작성: 2022-05-28

还是一样哥

bleu개발자
§
작성: 2022-05-28

到这个地址下载as文件

你的potplayer是我提供的吗,不是的话安装这个我在官网下载的 密码:4xke

§
작성: 2022-05-28

重下了,还是一样,好像就是as文件里有几个错误没解决

§
작성: 2022-05-28

ok可以了,我重启了下电脑,谢谢你哈

bleu개발자
§
작성: 2022-05-28

我的as脚本代码只有200多行,图中的错误都报到2000多行,重新复制内容全部替换as文件吧

/*
    PotPlayer云盘-专供版 bleu
*/

// void OnInitialize()
// void OnFinalize()
// string GetTitle()                                    -> get title for UI
// string GetVersion                                    -> get version for manage
// string GetDesc()                                     -> get detail information
// string GetLoginTitle()                               -> get title for login dialog
// string GetLoginDesc()                                -> get desc for login dialog
// string GetUserText()                                 -> get user text for login dialog
// string GetPasswordText()                             -> get password text for login dialog
// string ServerCheck(string User, string Pass)         -> server check
// string ServerLogin(string User, string Pass)         -> login
// void ServerLogout()                                  -> logout
//------------------------------------------------------------------------------------------------
// bool PlayitemCheck(const string &in)                                                             -> check playitem
// string PlayitemParse(const string &in path,dictionary &MetaData, array<dictionary> &QualityList) -> parse playitem
// bool PlaylistCheck(const string &in)                                                             -> check playlist
// array<dictionary> PlaylistParse(const string &in)                                                -> parse playlist

string GetTitle()
{
    return "PanVideo";
}

string GetVersion()
{
    return "1";
}

string GetDesc()
{
    return "https://github.com/Bleu404/PotplayerPanVideoSV";
}

string USERAGENT = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.4844.82 Safari/537.36";

JsonReader JSON;
JsonValue HEADERS;
int  quIndex;

string getData(string flag)
{
    if (flag == "xl_init") return "{\"client_id\":\"" + HEADERS['clientid'].asString() + "\",\"action\":\"get:/drive/v1/about\",\"device_id\":\"" + HEADERS['x-device-id'].asString() + "\",\"captcha_token\":\"" + HEADERS['x-captcha-token'].asString() + "\",\"meta\":{}}";
    if (flag == "al_item") return "{\"category\":\"live_transcoding\",\"template_id\":\"\",\"drive_id\":\""+HEADERS['drive_id'].asString()+"\",\"file_id\":\"";
    return "";
}

string getHeaders(string flag)
{
    if (flag == "xl_0") return "content-type: text/plain;charset=UTF-8\r\n";
    if (flag == "xl_1") return "authorization: " + HEADERS['Authorization'].asString() + "\r\n" + "content-type: " + HEADERS['content-type'].asString() + "\r\n" + "x-captcha-token: " + HEADERS['x-captcha-token'].asString() + "\r\n" + "x-device-id: " + HEADERS['x-device-id'].asString();
    if (flag == "al_0") return "authorization: " + HEADERS['authorization'].asString() + "\r\n" + "referer: https://www.aliyundrive.com/\r\nx-canary: client=web,app=adrive,version=v2.4.0";
    else return "";
}
bool setQuality(string name,string url,array < dictionary > & QualityList)
{
    array<string> qualities = {"搁置","360", "480","540","720", "1080"};
    dictionary item;
    if(name == "FHD")name = "超清 1080p";
    if(name == "HD")name = "高清 720p";
    if(name == "SD")name = "标清 540p";
    if(name == "LD")name = "流畅 360p";
    string temp = HostRegExpParse(name,"([0-9]+)");
    HostPrintUTF8(temp);
    if (temp!="" && qualities.find(temp) > 0) {
        quIndex = qualities.find(temp);
    } else {
        quIndex++;
    }
    item["itag"] = quIndex;
    item["url"] = url;
    item["quality"] = name;
    QualityList.insertLast(item);
    return true;
}

bool PlayitemCheck(const string & in path)
{
    if(path.find("panvideo") == 0)
    {
        if(HEADERS.isNull()){
            HostPrintUTF8("重新获取头信息");
            string tempstr = HostFileRead(HostFileOpen("Extension\\Media\\PlayParse\\panvideo.txt"), 500);
            tempstr.replace(" ","");
            array < string > temp = tempstr.split("\r\n");
            tempstr = HostUrlGetStringWithAPI("https://"+temp[0]+"/PanPlaylist/panvideo.txt", USERAGENT, "authorization: Basic "+HostBase64Enc(temp[1]+":"+temp[2]), getData(""), false);
            JSON.parse(tempstr, HEADERS);
            HEADERS = HEADERS["header"];
        }
        return true;
    }
    return false;
}

//从opensubtitles.com获取字幕,注册账号并开启API之后每个api每天100(或更多)个字幕
array <dictionary> searchSubtitle(string subname)
{
    array <string> apikey ={};//api用户信息必填
    int subcount = 0;//每个视频获取字幕个数,设置过多,可能无法加载视频
    dictionary subitem;
    array <dictionary> sub;
    JsonValue userjv,fileinfo;
    string subURL,retString;
    if(subcount == 0||apikey.size() == 0)return sub;
    subURL = "https://api.opensubtitles.com/api/v1/subtitles/?languages=en&query="+subname;
    retString = HostUrlGetString(subURL, "PotplayerPanVideoSV", "Content-Type: application/json\r\nApi-Key: "+apikey[0],getData(""), false);
    if(retString == "")return sub;
    JSON.parse(retString,userjv);
    HostPrintUTF8("搜索字幕完毕");
    for(int i = 0;i<subcount;i++)
    {
        int index = i%apikey.size();
        string fileid = userjv["data"][i]["attributes"]["files"][0]["file_id"].asString();
        retString = HostUrlGetString("https://api.opensubtitles.com/api/v1/download", "PotplayerPanVideoSV", "Content-Type: application/json\r\nApi-Key: "+apikey[index],"{\"file_id\":"+fileid+"}", false);
        if(retString == "")continue;
        JSON.parse(retString,fileinfo);
        subitem["name"] = fileinfo["file_name"].asString();
        subitem["url"] = fileinfo["link"].asString();       
        HostPrintUTF8(string(subitem["name"]));
        sub.insertLast(subitem);
        HostPrintUTF8("还剩下:"+fileinfo["remaining"].asString());
        HostSleep(100);
    }
    return sub;
}

string PlayitemParse(const string & in path, dictionary & MetaData, array < dictionary > & QualityList)
{
    string ret;
    JsonValue jsonVal;
    array < string > temp = path.split("##");
    if (!PlayitemCheck(path)) return ret;
    string tempstr;
    quIndex = 5;

    //HostOpenConsole();
    if(temp[1]=="xunlei")
    {
        ret = HostUrlGetString(temp[2], USERAGENT, getHeaders("xl_1"), getData(""), false);
        if(ret==""||ret.find("error")>=0)
        {
            string initUrl = "https://xluser-ssl.xunlei.com/v1/shield/captcha/init";
            tempstr = HostUrlGetString(initUrl, USERAGENT, getHeaders("xl_0"),getData("xl_init"), false);
            JSON.parse(tempstr,jsonVal);
            if(jsonVal["captcha_token"].asString()!="")HEADERS['x-captcha-token'] = jsonVal["captcha_token"];
            ret = HostUrlGetString(temp[2], USERAGENT, getHeaders("xl_1"), getData(""), false);
        }
        JSON.parse(ret, jsonVal);

        setQuality("原画 300KB/s",jsonVal["web_content_link"].asString(),QualityList);
        for (int i = 0; i < jsonVal["medias"].size(); i++)
        {
            JsonValue mary = jsonVal["medias"][i];
            if (!mary["link"].canString())
            {
                setQuality(mary["media_name"].asString(),mary["link"]["url"].asString(),QualityList);
                if(i == jsonVal["medias"].size()-1)
                {
                    ret = mary["link"]["url"].asString();
                }
            } 
        }
    }
    if(temp[1]=="aliyun")
    {
        temp[2].replace("https://","");

        string url = "https://api.aliyundrive.com/v2/file/get_download_url";
        tempstr = HostUrlGetString(url, USERAGENT, getHeaders("al_0"),getData("al_item")+temp[2]+"\"}", false);
        JSON.parse(tempstr,jsonVal);
        //HostPrintUTF8(jsonVal["url"].asString());
        HostSetUrlHeaderHTTP(jsonVal["url"].asString(), "referer: https://www.aliyundrive.com/");
        setQuality("原画",jsonVal["url"].asString(),QualityList);

        url = "https://api.aliyundrive.com/v2/file/get_video_preview_play_info";
        tempstr = HostUrlGetString(url, USERAGENT, getHeaders("al_0"),getData("al_item")+temp[2]+"\"}", false);
        JSON.parse(tempstr,jsonVal);
        JsonValue templist = jsonVal["video_preview_play_info"]["live_transcoding_task_list"];
        for (int i = 0; i < templist.size(); i++)
        {
            HostSetUrlHeaderHTTP(templist[i]["url"].asString(), "referer: https://www.aliyundrive.com/");
            setQuality(templist[i]["template_id"].asString(),templist[i]["url"].asString(),QualityList);
            if(i == templist.size()-1)
            {
                ret = templist[i]["url"].asString();
            }
        }
    }
    MetaData["subtitle"] = searchSubtitle(temp[3]);
    return ret;
}

bool PlaylistCheck(const string & in path)
{
    array < string > temp = path.split("##");
    if (path.find("panvideo") == 0) 
    {
        JSON.parse(HostUrlDecode(temp[2]), HEADERS); 
        return true;
    }
    return false;
}

array < dictionary > PlaylistParse(const string & in path)
{
    //HostOpenConsole();
    array < dictionary > ret;
    array < string > temp = path.split("##");
    JsonValue Itemlist;
    string tempstr;
    //HostPrintUTF8(temp[3]);
    tempstr = HostUrlGetStringWithAPI(temp[3], USERAGENT, "authorization: Basic "+HostBase64Enc(temp[4]+":"+temp[5]), getData(""), false);
    JSON.parse(tempstr, Itemlist);
    Itemlist = Itemlist["list"];
    //HostPrintUTF8(tempstr);
    for (int i = 0; i < Itemlist.size(); i++) 
    {
        dictionary item,subitem;
        item["url"] = "panvideo##"+temp[1]+"##"+Itemlist[i]["url"].asString()+"##"+Itemlist[i]["title"].asString();
        item["title"] = Itemlist[i]["title"].asString();
        ret.insertLast(item);
    }
    return ret;
}
bleu개발자
§
작성: 2022-05-28

好的

댓글 남기기

댓글을 남기려면 로그인하세요.