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>  

 

相关文章
|
7月前
|
缓存 网络协议 安全
49. 【Android教程】HTTP 使用详解
49. 【Android教程】HTTP 使用详解
111 1
|
7月前
|
XML API 网络安全
【安卓】在安卓中使用HTTP协议的最佳实践
【安卓】在安卓中使用HTTP协议的最佳实践
163 4
|
5月前
|
Java Spring
成功解决Initialization failed for ‘https://start.spring.io‘ Please check URL, network and proxy settings
这篇文章提供了解决Spring Initializr网站初始化失败问题的方法,包括检查URL、网络和代理设置。
成功解决Initialization failed for ‘https://start.spring.io‘ Please check URL, network and proxy settings
|
5月前
|
Android开发
Android 利用MediaPlayer实现音乐播放
本文提供了一个简单的Android MediaPlayer音乐播放示例,包括创建PlayerActivity、配置AndroidManifest.xml和activity_player.xml布局,以及实现播放和暂停功能的代码。
56 0
Android 利用MediaPlayer实现音乐播放
|
6月前
|
数据采集 缓存 安全
http proxy 协议的工作原理与常见用途
在这篇博客文章中,我们将深入探讨HTTP代理协议的工作原理,揭示它如何在客户端和服务器之间传递HTTP请求和响应,并讨论它在各种应用场景中的常见用途。
http proxy 协议的工作原理与常见用途
|
5月前
|
XML 安全 Android开发
Flutter配置Android和IOS允许http访问
Flutter配置Android和IOS允许http访问
187 3
|
5月前
|
Java Android开发 UED
安卓scheme_url调端:如果手机上多个app都注册了 http或者https 的 intent。 调端的时候,调起哪个app呢?
当多个Android应用注册了相同的URL Scheme(如http或https)时,系统会在尝试打开这类链接时展示一个选择对话框,让用户挑选偏好应用。若用户选择“始终”使用某个应用,则后续相同链接将直接由该应用处理,无需再次选择。本文以App A与App B为例,展示了如何在`AndroidManifest.xml`中配置对http与https的支持,并提供了从其他应用发起调用的示例代码。此外,还讨论了如何在系统设置中管理这些默认应用选择,以及建议开发者为避免冲突应注册更独特的Scheme。
|
7月前
|
缓存 网络协议 安全
Android网络面试题之Http基础和Http1.0的特点
**HTTP基础:GET和POST关键差异在于参数传递方式(GET在URL,POST在请求体),安全性(POST更安全),数据大小限制(POST无限制,GET有限制),速度(GET较快)及用途(GET用于获取,POST用于提交)。面试中常强调POST的安全性、数据量、数据类型支持及速度。HTTP 1.0引入了POST和HEAD方法,支持多种数据格式和缓存,但每个请求需新建TCP连接。**
64 5
|
7月前
|
安全 网络协议 算法
Android网络基础面试题之HTTPS的工作流程和原理
HTTPS简述 HTTPS基于TCP 443端口,通过CA证书确保服务器身份,使用DH算法协商对称密钥进行加密通信。流程包括TCP握手、证书验证(公钥解密,哈希对比)和数据加密传输(随机数加密,预主密钥,对称加密)。特点是安全但慢,易受特定攻击,且依赖可信的CA。每次请求可能复用Session ID以减少握手。
77 2
|
7月前
|
缓存 网络协议 Android开发
Android网络面试题之Http1.1和Http2.0
HTTP/1.1 引入持久连接和管道机制提升效率,支持分块传输编码和更多请求方式如PUT、PATCH。Host字段指定服务器域名,RANGE用于断点续传。HTTP/2变为二进制协议,实现多工处理,头信息压缩和服务器推送,减少延迟并优化资源加载。HTTP不断发展,从早期的简单传输到后来的高效交互。
87 0
Android网络面试题之Http1.1和Http2.0

热门文章

最新文章