Android MediaPlayer与Http Proxy结合之基础篇

简介: 本文来自http://blog.csdn.net/hellogv/ ,引用.              最近半年都忙着Android TV项目,在春节假期才有时间写点东西。


本文来自http://blog.csdn.net/hellogv/ ,引用.      

       最近半年都忙着Android TV项目,在春节假期才有时间写点东西。先在这里给大家拜个年,祝大家龙年快乐...

       直接进入主题:本文将会教大家如何实现一个简单的代理服务器(仅支持Http Get),与Android的MediaPlayer结合,从而可以扩展出“播放 防盗链的媒体文件”,“边播放边保存”等的功能。

       本文的代码可以到这里下载:http://download.csdn.net/detail/hellogv/4047134,代码分为两个工程:

  1. J2SE工程:HttpGetProxy,在PC上实现简单的代理服务器,核心类是HttpGetProxy.java,非常容易使用,这里就不唠叨了直接贴出运行效果图:
  2. Android工程:本文重点,必须唠叨一下。MediaPlayer播放网络音频(http://blog.csdn.net/hellogv/article/details/6406732)与HttpGetProxy.java结合,通过代理服务器播放网络音频。

   接下来贴出HttpGetProxy.java的原理图:

 接下来贴出HttpGetProxy.java的源码:

通过RemoteSocket的out_remoteSocket可以访问防盗链资源,HttpGetProxy通过2个线程来实现转发,可以在两个线程内实现保存的功能。

[java]  view plain copy print ?
  1. <span style="font-family:Comic Sans MS;font-size:18px;">package com.musicplayer;  
  2.   
  3. import java.io.IOException;  
  4. import java.io.InputStream;  
  5. import java.io.OutputStream;  
  6. import java.net.InetAddress;  
  7. import java.net.InetSocketAddress;  
  8. import java.net.ServerSocket;  
  9. import java.net.Socket;  
  10. import java.net.SocketAddress;  
  11. import java.net.UnknownHostException;  
  12.   
  13. import android.util.Log;  
  14.   
  15. public class HttpGetProxy {  
  16.     final private String LOCAL_IP_ADDRESS = "127.0.0.1";  
  17.     final private int HTTP_PORT = 80;  
  18.   
  19.     private ServerSocket localServer = null;  
  20.     private Socket localSocket = null;  
  21.     private Socket remoteSocket = null;  
  22.     private String remoteIPAddress;  
  23.   
  24.     private InputStream in_remoteSocket;  
  25.     private OutputStream out_remoteSocket;  
  26.     private InputStream in_localSocket;  
  27.     private OutputStream out_localSocket;  
  28.       
  29.     private interface OnFinishListener {  
  30.         void onFinishListener();  
  31.     }  
  32.       
  33.     public HttpGetProxy(int localport) {  
  34.   
  35.         // --------建立代理中转服务器-----------//  
  36.         try {  
  37.             localServer = new ServerSocket(localport, 1,  
  38.                     InetAddress.getByName(LOCAL_IP_ADDRESS));  
  39.         } catch (UnknownHostException e) {  
  40.             // TODO Auto-generated catch block  
  41.             e.printStackTrace();  
  42.         } catch (IOException e) {  
  43.             // TODO Auto-generated catch block  
  44.             e.printStackTrace();  
  45.         }  
  46.     }  
  47.   
  48.     /** 
  49.      * 结束时,清除所有资源 
  50.      */  
  51.     private OnFinishListener finishListener =new OnFinishListener(){  
  52.   
  53.         @Override  
  54.         public void onFinishListener() {  
  55.             System.out.println("..........release all..........");  
  56.             Log.e("---->","..........release all..........");  
  57.             try {  
  58.                 in_localSocket.close();  
  59.                 out_remoteSocket.close();  
  60.                   
  61.                 in_remoteSocket.close();  
  62.                 out_localSocket.close();  
  63.                   
  64.                 localSocket.close();  
  65.                 remoteSocket.close();  
  66.             } catch (IOException e) {  
  67.                 // TODO Auto-generated catch block  
  68.                 e.printStackTrace();  
  69.             }  
  70.         }  
  71.     };  
  72.       
  73.     public void startProxy(String remoteIpAddr) throws IOException {  
  74.         remoteIPAddress = remoteIpAddr;  
  75.         SocketAddress address = new InetSocketAddress(remoteIPAddress,HTTP_PORT);  
  76.   
  77.         // --------连接目标服务器---------//  
  78.         remoteSocket = new Socket();  
  79.         remoteSocket.connect(address);  
  80.         System.out.println("..........remote Server connected..........");  
  81.         Log.e("---->","..........remote Server connected..........");  
  82.         in_remoteSocket = remoteSocket.getInputStream();  
  83.         out_remoteSocket = remoteSocket.getOutputStream();  
  84.         System.out.println("..........init remote Server I/O..........");  
  85.         /** 
  86.          * 接收本地request,并转发到远程服务器 
  87.          */  
  88.         new Thread() {  
  89.             public void run() {  
  90.                 int bytes_read;  
  91.                 byte[] local_request = new byte[5120];  
  92.                 try {  
  93.                     // 本地Socket  
  94.                     localSocket = localServer.accept();  
  95.                     System.out.println("..........localSocket connected..........");  
  96.                     Log.e("---->","..........localSocket connected..........");  
  97.                     in_localSocket = localSocket.getInputStream();  
  98.                     out_localSocket = localSocket.getOutputStream();  
  99.   
  100.                     System.out.println("..........init local Socket I/O..........");  
  101.                     Log.e("---->","..........init local Socket I/O..........");  
  102.                     String buffer = "";  
  103.                     while ((bytes_read = in_localSocket.read(local_request)) != -1) {  
  104.                         String str = new String(local_request);  
  105.                         System.out.println("localSocket     " + str);  
  106.                         Log.e("localSocket---->",str);  
  107.                         buffer = buffer + str;  
  108.                         if (buffer.contains("GET")  
  109.                                 && buffer.contains("\r\n\r\n")) {  
  110.                             //---把request中的本地ip改为远程ip---//  
  111.                             buffer = buffer.replace(LOCAL_IP_ADDRESS,remoteIPAddress);  
  112.                             System.out.println("已经替换IP");  
  113.                             out_remoteSocket.write(buffer.getBytes());  
  114.                             out_remoteSocket.flush();  
  115.                             continue;  
  116.                         } else{  
  117.                             out_remoteSocket.write(buffer.getBytes());  
  118.                             out_remoteSocket.flush();  
  119.                         }  
  120.                     }  
  121.                     System.out.println("..........local finish receive...........");  
  122.                     Log.e("---->","..........local finish receive..........");  
  123.                     finishListener.onFinishListener();  
  124.                 } catch (IOException e) {  
  125.                     // TODO Auto-generated catch block  
  126.                     e.printStackTrace();  
  127.                 }  
  128.             }  
  129.         }.start();  
  130.   
  131.         /** 
  132.          * 接收远程服务器reply,并转发到本地客户端 
  133.          */  
  134.         new Thread() {  
  135.             public void run() {  
  136.                 int bytes_read;  
  137.                 byte[] remote_reply = new byte[5120];  
  138.                 try {  
  139.                     System.out.println("..........remote start to receive...........");  
  140.                     Log.e("---->","..........remote start to receive..........");  
  141.                     while ((bytes_read = in_remoteSocket.read(remote_reply)) != -1) {  
  142.                           
  143.                         //System.out.println("remoteSocket     " + remote_reply.length);  
  144.                         //System.out.println("remoteSocket     " + new String(remote_reply));  
  145.                         out_localSocket.write(remote_reply, 0, bytes_read);  
  146.                         out_localSocket.flush();  
  147.                     }  
  148.                     System.out.println("..........remote finish receive...........");  
  149.                     Log.e("---->","..........remote finish receive..........");  
  150.                 } catch (IOException e) {  
  151.                     // TODO Auto-generated catch block  
  152.                     e.printStackTrace();  
  153.                 }  
  154.             }  
  155.         }.start();  
  156.     }  
  157. }  
  158. </span>  

 

相关文章
|
1月前
|
缓存 网络协议 安全
49. 【Android教程】HTTP 使用详解
49. 【Android教程】HTTP 使用详解
34 1
|
1月前
|
XML API 网络安全
【安卓】在安卓中使用HTTP协议的最佳实践
【安卓】在安卓中使用HTTP协议的最佳实践
38 4
|
2月前
|
监控 Unix 应用服务中间件
Android-音视频学习系列-(八)基于-Nginx-搭建(rtmp、http)直播服务器
Android-音视频学习系列-(八)基于-Nginx-搭建(rtmp、http)直播服务器
|
2月前
|
安全 Android开发
Android之OKHttp基本使用和OKHttp发送https请求安全认证
Android之OKHttp基本使用和OKHttp发送https请求安全认证
76 0
|
26天前
|
缓存 网络协议 安全
Android网络面试题之Http基础和Http1.0的特点
**HTTP基础:GET和POST关键差异在于参数传递方式(GET在URL,POST在请求体),安全性(POST更安全),数据大小限制(POST无限制,GET有限制),速度(GET较快)及用途(GET用于获取,POST用于提交)。面试中常强调POST的安全性、数据量、数据类型支持及速度。HTTP 1.0引入了POST和HEAD方法,支持多种数据格式和缓存,但每个请求需新建TCP连接。**
28 5
|
24天前
|
安全 网络协议 算法
Android网络基础面试题之HTTPS的工作流程和原理
HTTPS简述 HTTPS基于TCP 443端口,通过CA证书确保服务器身份,使用DH算法协商对称密钥进行加密通信。流程包括TCP握手、证书验证(公钥解密,哈希对比)和数据加密传输(随机数加密,预主密钥,对称加密)。特点是安全但慢,易受特定攻击,且依赖可信的CA。每次请求可能复用Session ID以减少握手。
25 2
|
25天前
|
缓存 网络协议 Android开发
Android网络面试题之Http1.1和Http2.0
HTTP/1.1 引入持久连接和管道机制提升效率,支持分块传输编码和更多请求方式如PUT、PATCH。Host字段指定服务器域名,RANGE用于断点续传。HTTP/2变为二进制协议,实现多工处理,头信息压缩和服务器推送,减少延迟并优化资源加载。HTTP不断发展,从早期的简单传输到后来的高效交互。
25 0
Android网络面试题之Http1.1和Http2.0
|
1月前
|
存储 Android开发 Kotlin
开发安卓app OKhttp下载后使用MediaPlayer播放
在Android Jetpack Compose应用程序中,要使用OkHttp下载远程音频文件并在本地播放,你需要完成以下几个步骤: 1. **添加依赖**:确保`build.gradle`文件包含OkHttp和Jetpack Compose的相关依赖。 2. **下载逻辑**:创建一个`suspend`函数,使用OkHttp发起网络请求下载音频文件到本地。 3. **播放逻辑**:利用`MediaPlayer`管理音频播放状态。 4. **Compose UI**:构建用户界面,包含下载和播放音频的按钮。
|
1月前
|
存储 Android开发
安卓app,MediaPlayer播放本地音频 | 按钮控制播放和停止
在Jetpack Compose中,不直接操作原生Android组件如`Button`和`MediaPlayer`,而是使用Compose UI构建器定义界面并结合ViewModel管理音频播放逻辑。以下示例展示如何播放本地音频并用按钮控制播放/停止:创建一个`AudioPlayerViewModel`管理`MediaPlayer`实例和播放状态,然后在Compose UI中使用`Button`根据`isPlaying`状态控制播放。记得在`MainActivity`设置Compose UI,并处理相关依赖和权限。
101 3
|
2月前
|
Android开发 数据安全/隐私保护 iOS开发
ios和安卓测试包发布网站http://fir.im的注册与常用功能
ios和安卓测试包发布网站http://fir.im的注册与常用功能
41 0
ios和安卓测试包发布网站http://fir.im的注册与常用功能

热门文章

最新文章