视频地址获取

软件具体名字就不说了哈,首先贴出视频的网页地址:http://www.365yg.com/a6542366077089743367/首先需要获取视频的videoId,直接请求该url,然后match匹配:Patternpattern=Pattern.compile("videoId:\'(.+)\’");Matchermatcher=pattern.ma…

大家好,又见面了,我是你们的朋友全栈君。

软件具体名字就不说了哈,首先贴出视频的网页地址:
http://www.365yg.com/a6542366077089743367/
首先需要获取视频的videoId,直接请求该url,然后match匹配:

   Pattern pattern = Pattern.compile("videoId: \'(.+)\'");
   Matcher matcher = pattern.matcher(response);
   if (matcher.find()) {
          String videoId = matcher.group(1);
          Log.i(TAG,videoId);
   }

获得videoId后开始获取r参数与s参数:

   String URL_VIDEO="/video/urls/v/1/toutiao/mp4/%s?r=%s";
   String HOST_VIDEO = "http://i.snssdk.com";
{
    String r = getRandom();
    CRC32 crc32 = new CRC32();
    String s = String.format(URL_VIDEO, videoId, r);
    //进行crc32加密。
    crc32.update(s.getBytes());
    String crcString = crc32.getValue() + "";
    //2.生成获取视频地址的url
    String url = HOST_VIDEO + s + "&s=" + crcString;
    Log.i(TAG,url);
}
private String getRandom() {
        Random random = new Random();
        StringBuilder result = new StringBuilder();
        for (int i = 0; i < 16; i++) {
            result.append(random.nextInt(10));
        }
        return result.toString();
    }

接下来访问生成的url,即可获得类似下面的json:
这里写图片描述
箭头所示的main_url即为我们需要的视频播放真实地址,但其实Base64编码的,解码即可得到真实地址:

  System.err.println( new String(Base64.getUrlDecoder()
                 .decode("main_url的值")));

视频地址有有效时间,意味每次播放都需要判断地址是否准确!

bak:关于videoId的获取:

 open fun test(url: String): String? {
        var client = OkHttpClient().newBuilder()
                .followRedirects(false)
                .followSslRedirects(false)
                .build();
        var mediaType = MediaType.parse("application/x-www-form-urlencoded");
        var body = RequestBody.create(mediaType,
                "checkCookiesEnabled=true&checkMobileDevice=false&checkStandaloneMode=false&checkTabletDevice=false&portalAccountUsername=username&portalAccountPassword=password");
        var request = Request.Builder()
                .url(url)
                .post(body)
                .addHeader("content-type", "application/x-www-form-urlencoded")
                .addHeader("cache-control", "no-cache")
                .build();

        var response = client.newCall(request).execute()
//        ALog.e(response.body()?.string())
        return response.body()?.string()
        }
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/126732.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • mysql 主键自增语句_MySQL 自增主键[通俗易懂]

    mysql 主键自增语句_MySQL 自增主键[通俗易懂]以下仅考虑InnoDB存储引擎。自增主键有两个性质需要考虑:单调性每次插入一条数据,其ID都是比上一条插入的数据的ID大,就算上一条数据被删除。连续性插入成功时,其数据的ID和前一次插入成功时数据的ID相邻。自增主键的单调性为何会有单调性的问题?这主要跟自增主键最大值的获取方式,以及存放位置有关系。如果最大值是通过计算获取的,并且在某些情况下需要重新获取时,会因为最新的数据被删…

    2022年6月30日
    33
  • HDU1754_I Hate It(线段树/单点更新)

    HDU1754_I Hate It(线段树/单点更新)

    2022年1月21日
    44
  • Linux读写执行(RWX)权限

    Linux读写执行(RWX)权限rwx权限对文件rwx权限 对文件的作用 读权限(r) 表示可读取此文件中的实际内容,例如,可以对文件执行cat、more、less、head、tail等文件查看命令。 写权限(w) 表示可以编辑、新增或者修改文件中的内容,例如,可以对文件执行vim、echo等修改文件数据的命令。注意,无权限不赋予用户删除文件的权利,除非用户对文件的上级目录拥有写权限才可以。 执行权限(x) 表示该文件具有被系统执行的权限。Window系统中查看一个文件是否为可执行文件,

    2022年6月7日
    1.0K
  • Header和Cookie相关内容

    Header和Cookie相关内容

    2021年10月26日
    50
  • 安全 | 几种wifi密码破解的思路

    从一个攻击者的视角,多种方案,讲述破解一台路由器进而控制对方网络的过程,以此提醒广大用户,提高安全意识,做好安全措施。

    2022年4月13日
    169
  • ubuntu怎么安装vim编辑器_vim配置大全

    ubuntu怎么安装vim编辑器_vim配置大全1.linux默认自带vi,一般使用升级版vim2.第一次使用需要安装vimsudoaptinstallvim如果没有安装的话会提示安装vim执行安装sudoaptinstallvim测试vima.txt出现下面界面则安装成功3.vim的三种模式1.普通模式当vim打开的时候就直接进入普通模式,在…

    2022年9月16日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号