Android代码中实现WAP方式联网
无论是移动、联通还是电信,都至少提供了两种类型的的APN:WAP方式和NET方式。其中NET方式跟WIFI方式一样,无需任何设置,可自由访问所有类型网站,而WAP方式,需要手机先设置代理服务器和端口号等信息,并且只能访问HTTP协议类型的网站。
1) 移动的WAP名称是CMWAP,NET名称是CMNET;
2) 联通的WAP名称是UNIWAP,NET名称是UNINET;联通3G的WAP名称是3GWAP,NET名称是3GNET;
3) 电信的WAP名称是CTWAP,NET名称是CTNET;
其中,移动和联通的WAP代理服务器都是10.0.0.172,端口号是80;而电信的WAP代理服务器是10.0.0.200,端口号是80。
Android系统中,对于APN网络的API是隐藏的,因此获取手机的APN设置,需要通过ContentProvider来进行数据库查询,查询的URI地址是:
取得全部的APN列表:content://telephony/carriers;
取得当前设置的APN:content://telephony/carriers/preferapn;
取得current=1的APN:content://telephony/carriers/current;
下面我们的代码就是获取当前首选的APN设置,并继承HttpClient,实现我们自己的代理HttpClient类。首先来看下APN的管理类的实现,这个类的主要功能是获得APN的代理服务器和端口号,查询用的URI如下:
由这个URI使用ContentResolver获得游标对象,之后就是查询操作了,分别查处当前手机所设置的APN、Proxy和Port,而如果手机的Proxy没有设置,则需要根据APN来决定当前应该连接的代理服务器地址和端口号,详细代码如下所示:
通过APNManager类获取到当前手机的WAP设置的代理和端口之后,就可以构造我们自己的代理HttpClient了,这个类定义为ProxyHttpClient,在该类的构造函数中,首先获得APNManager的实例,然后获取代理服务器proxy和端口值port,通过这两个参数构造HttpHost实例,并将host实例设置为ConnRouteParams.DEFAULT_PROXY的值,详细代码截图如下所示:
APNManager类完整定义如下:
package com.hust.iprai;import android.content.Context;import android.text.TextUtils;import android.util.Log;import org.apache.http.HttpHost;import org.apache.http.conn.params.ConnRouteParams;import org.apache.http.impl.client.DefaultHttpClient;import org.apache.http.params.HttpConnectionParams;import org.apache.http.params.HttpParams;import org.apache.http.params.HttpProtocolParams;public class ProxyHttpClient extends DefaultHttpClient { private static final int HTTP_TIMEOUT_MS = 30 * 1000; private static final int BUFFER_SIZE = 1024 * 8; private static final String TAG = ProxyHttpClient.class.getSimpleName(); private RuntimeException mLeakedException = new IllegalStateException("ProxyHttpClient created and never closed"); private String mPort; private String mProxy; private boolean mUseWap; public ProxyHttpClient(Context context) { this(context, null, null); } public ProxyHttpClient(Context context, APNManager manager) { this(context, null, manager); } public ProxyHttpClient(Context context, String userAgent) { this(context, userAgent, null); } public ProxyHttpClient(Context context, String userAgent, APNManager manager) { if (manager == null) { manager = new APNManager(context); } this.mUseWap = manager.isWapNetwork(); this.mProxy = manager.getProxy(); this.mPort = manager.getProxyPort(); if (this.mUseWap) { HttpHost host = new HttpHost(this.mProxy, Integer.valueOf(this.mPort).intValue()); getParams().setParameter(ConnRouteParams.DEFAULT_PROXY, host); // 设置代理 } HttpConnectionParams.setConnectionTimeout(getParams(), HTTP_TIMEOUT_MS); HttpConnectionParams.setSoTimeout(getParams(), HTTP_TIMEOUT_MS); HttpConnectionParams.setSocketBufferSize(getParams(), BUFFER_SIZE); if (!TextUtils.isEmpty(userAgent)) { HttpProtocolParams.setUserAgent(getParams(), userAgent); } } public void close() { if (this.mLeakedException != null) { getConnectionManager().shutdown(); this.mLeakedException = null; } } protected HttpParams createHttpParams() { HttpParams params = super.createHttpParams(); HttpProtocolParams.setUseExpectContinue(params, false); return params; } protected void finalize() throws Throwable { super.finalize(); if (this.mLeakedException != null) { Log.e(TAG, "Leak found", this.mLeakedException); } }}