如何使用HttpClient
这里举几个应用。
1. 读取网页(HTTP/HTTPS)内容
下面是我们给出的一个简单的例子用来访问某个页面
Created on 2003-12-14 by skydong
/
package httpdemo;
import javaioIOException;
import orgapachecommonshttpclient;
import orgapachecommonshttpclientmethods;
/ //
最简单的HTTP客户端,用来演示通过GET或者POST方式访问某个页面
@author skydong
/
public class SimpleClient {
public static void main(String[] args) throws IOException
{
HttpClient client = new HttpClient();
//设置代理服务器地址和端口
//clientgetHostConfiguration()setProxy("proxy_host_addr",proxy_port);
//使用GET方法,如果服务器需要通过HTTPS连接,那只需要将下面URL中的http换成https
HttpMethod method = new GetMethod("http://javasuncom";);
//使用POST方法
//HttpMethod method = new PostMethod("http://javasuncom";);
clientexecuteMethod(method);
//打印服务器返回的状态
Systemoutprintln(methodgetStatusLine());
//打印返回的信息
Systemoutprintln(methodgetResponseBodyAsString());
//释放连接
methodreleaseConnection();
}
}
在这个例子中首先创建一个HTTP客户端(HttpClient)的实例,然后选择提交的方法是GET或者POST,最后在HttpClient实例上执行提交的方法,最后从所选择的提交方法中读取服务器反馈回来的结果。这就是使用HttpClient的基本流程。其实用一行代码也就可以搞定整个请求的过程,非常的简单!
2. 以GET或者POST方式向网页提交参数
其实前面一个最简单的示例中我们已经介绍了如何使用GET或者POST方式来请求一个页面,本小节与之不同的是多了提交时设定页面所需的参数,我们知道如果是GET的请求方式,那么所有参数都直接放到页面的URL后面用问号与页面地址隔开,每个参数用&隔开,例如:http://javasuncomname=liudong&mobile=123456,但是当使用POST方法时就会稍微有一点点麻烦。本小节的例子演示向如何查询手机号码所在的城市,代码如下:
Created on 2009-7-9 by skydong
/
package httpdemo;
import javaioIOException;
import orgapachecommonshttpclient;
import orgapachecommonshttpclientmethods;
/ //
提交参数演示
该程序连接到一个用于查询手机号码所属地的页面
以便查询号码段1330227所在的省份以及城市
@author skydong
/
public class SimpleHttpClient {
public static void main(String[] args) throws IOException
{
HttpClient client = new HttpClient();
clientgetHostConfiguration()setHost("wwwimobilecomcn", 80, "http");
HttpMethod method = getPostMethod();//使用POST方式提交数据
clientexecuteMethod(method);
//打印服务器返回的状态
Systemoutprintln(methodgetStatusLine());
//打印结果页面
String response = new String(methodgetResponseBodyAsString()getBytes("8859_1"));
//打印返回的信息
Systemoutprintln(response);
methodreleaseConnection();
}
/ //
使用GET方式提交数据
@return
/
private static HttpMethod getGetMethod(){
return new GetMethod("/simcardphpsimcard=1330227");
}
/ //
使用POST方式提交数据
@return
/
private static HttpMethod getPostMethod(){
PostMethod post = new PostMethod("/simcardphp");
NameValuePair simcard = new NameValuePair("simcard","1330227");
postsetRequestBody(new NameValuePair[] { simcard});
return post;
}
}
在上面的例子中页面http://wwwimobilecomcn/simcardphp需要一个参数是simcard,这个参数值为手机号码段,即手机号码的前七位,服务器会返回提交的手机号码对应的省份、城市以及其他详细信息。GET的提交方法只需要在URL后加入参数信息,而POST则需要通过NameValuePair类来设置参数名称和它所对应的值
3. 处理页面重定向
在JSP/Servlet编程中responsesendRedirect方法就是使用HTTP协议中的重定向机制。它与JSP中的的区别在于后者是在服务器中实现页面的跳转,也就是说应用容器加载了所要跳转的页面的内容并返回给客户端;而前者是返回一个状态码,这些状态码的可能值见下表,然后客户端读取需要跳转到的页面的URL并重新加载新的页面。就是这样一个过程,所以我们编程的时候就要通过HttpMethodgetStatusCode()方法判断返回值是否为下表中的某个值来判断是否需要跳转。如果已经确认需要进行页面跳转了,那么可以通过读取HTTP头中的location属性来获取新的地址。
状态码
对应HttpServletResponse的常量
详细描述
301
SC_MOVED_PERMANENTLY
页面已经永久移到另外一个新地址
302
SC_MOVED_TEMPORARILY
页面暂时移动到另外一个新的地址
303
SC_SEE_OTHER
客户端请求的地址必须通过另外的URL来访问
307
SC_TEMPORARY_REDIRECT
同SC_MOVED_TEMPORARILY
下面的代码片段演示如何处理页面的重定向
clientexecuteMethod(post);
Systemoutprintln(postgetStatusLine()toString());
postreleaseConnection();
//检查是否重定向
int statuscode = postgetStatusCode();
if ((statuscode == HttpStatusSC_MOVED_TEMPORARILY) ||
(statuscode == HttpStatusSC_MOVED_PERMANENTLY) ||
(statuscode == HttpStatusSC_SEE_OTHER) ||
(statuscode == HttpStatusSC_TEMPORARY_REDIRECT))
{//读取新的URL地址
Header header = postgetResponseHeader("location");
if (header != null) {
String newuri = headergetValue();
if ((newuri == null) || (newuriequals("")))
newuri = "/";
GetMethod redirect = new GetMethod(newuri);
clientexecuteMethod(redirect);
Systemoutprintln("Redirect:"+ redirectgetStatusLine()toString());
redirectreleaseConnection();
} else {
Systemoutprintln("Invalid redirect");
}
我们可以自行编写两个JSP页面,其中一个页面用responsesendRedirect方法重定向到另外一个页面用来测试上面的例子。
本小节应该说是HTTP客户端编程中最常碰见的问题,很多网站的内容都只是对注册用户可见的,这种情况下就必须要求使用正确的用户名和口令登录成功后,方可浏览到想要的页面。因为HTTP协议是无状态的,也就是连接的有效期只限于当前请求,请求内容结束后连接就关闭了。在这种情况下为了保存用户的登录信息必须使用到Cookie机制。以JSP/Servlet为例,当浏览器请求一个JSP或者是Servlet的页面时,应用服务器会返回一个参数,名为jsessionid(因不同应用服务器而异),值是一个较长的唯一字符串的Cookie,这个字符串值也就是当前访问该站点的会话标识。浏览器在每访问该站点的其他页面时候都要带上jsessionid这样的Cookie信息,应用服务器根据读取这个会话标识来获取对应的会话信息。
对于需要用户登录的网站,一般在用户登录成功后会将用户资料保存在服务器的会话中,这样当访问到其他的页面时候,应用服务器根据浏览器送上的Cookie中读取当前请求对应的会话标识以获得对应的会话信息,然后就可以判断用户资料是否存在于会话信息中,如果存在则允许访问页面,否则跳转到登录页面中要求用户输入帐号和口令进行登录。这就是一般使用JSP开发网站在处理用户登录的比较通用的方法。
这样一来,对于HTTP的客户端来讲,如果要访问一个受保护的页面时就必须模拟浏览器所做的工作,首先就是请求登录页面,然后读取Cookie值;再次请求登录页面并加入登录页所需的每个参数;最后就是请求最终所需的页面。当然在除第一次请求外其他的请求都需要附带上Cookie信息以便服务器能判断当前请求是否已经通过验证。说了这么多,可是如果你使用httpclient的话,你甚至连一行代码都无需增加,你只需要先传递登录信息执行登录过程,然后直接访问想要的页面,跟访问一个普通的页面没有任何区别,因为类HttpClient已经帮你做了所有该做的事情了,太棒了!下面的例子实现了这样一个访问的过程
Created on 2009-7-9 by skydong
/
package httpdemo;
import orgapachecommonshttpclient;
import orgapachecommonshttpclientcookie;
import orgapachecommonshttpclientmethods;
/ //
用来演示登录表单的示例
@author skydong
/
public class FormLoginDemo {
static final String LOGON_SITE = "localhost";
static final int LOGON_PORT = 8080;
public static void main(String[] args) throws Exception{
HttpClient client = new HttpClient();
clientgetHostConfiguration()setHost(LOGON_SITE, LOGON_PORT);
//模拟登录页面loginjsp->mainjsp
PostMethod post = new PostMethod("/mainjsp");
NameValuePair name = new NameValuePair("name", "ld");
NameValuePair pass = new NameValuePair("password", "ld");
postsetRequestBody(new NameValuePair[]{name,pass});
int status = clientexecuteMethod(post);
Systemoutprintln(postgetResponseBodyAsString());
postreleaseConnection();
//查看cookie信息
CookieSpec cookiespec = CookiePolicygetDefaultSpec();
Cookie[] cookies = cookiespecmatch(LOGON_SITE, LOGON_PORT, "/", false, clientgetState()getCookies());
if (cookieslength == 0) {
Systemoutprintln("None");
} else {
for (int i = 0; i < cookieslength; i++) {
Systemoutprintln(cookies[i]toString());
}
}
//访问所需的页面main2jsp
GetMethod get = new GetMethod("/main2jsp");
clientexecuteMethod(get);
Systemoutprintln(getgetResponseBodyAsString());
getreleaseConnection();
}
}
1、打开Tableau软件。
2、在连接中,找到红框位置的MySQL,点击开始连接Mysql。
3、在弹出的连接界面,输入Mysql服务器地址、端口、用户名、密码。
4、输入完成后,点击红框位置 确认 进行连接。
5、此时已经连接到MySQL服务器上,为了测试 我们点击红框位置 选择数据库查看一下。
什么方式提供密码,看HTTP SERVER的。
如果是HTTP的认证,就要先POST用户、密码进行认证,再使用session去进行普通的HTTP访问;没做,就会有这样的错误提示了 403之类
请参考 http://wenkubaiducom/view/11b0200cf12d2af90242e654html
虽然只有十分
但是还是给你写一段 android中测试 跑得了 加点分可以继续追问我哦 呵呵~~~~
public static String getHtml( String urlpath,String encoding) throws Exception {
URL url = new URL(urlpath);
//实例化一个HTTP连接对象conn
HttpURLConnection conn = (HttpURLConnection)urlopenConnection();
//定义请求方式为GET,其中GET的格式需要注意
connsetRequestMethod("GET");
//定义请求时间,在ANDROID中最好是不好超过10秒。否则将被系统回收。
connsetConnectTimeout(61000);
if(conngetResponseCode()== 200){
InputStream inStream = conngetInputStream();
byte[] data = readStream(inStream);
return new String(data,encoding);
}
return null;
}
public static byte[] readStream(InputStream inStream) throws Exception{
ByteArrayOutputStream outStream = new ByteArrayOutputStream();
byte[] buffer = new byte[1024];
int len= -1;
//将输入流不断的读,并放到缓冲区中去。直到读完
while((len=inStreamread(buffer))!=-1){
//将缓冲区的数据不断的写到内存中去。
outStreamwrite(buffer, 0, len);
}
outStreamclose();
inStreamclose();
return outStreamtoByteArray();
}
解答:初步判断,json解析有问题。一般情况下,解析json必须要明确json字符串的内容。通俗地来讲,就是说你要知道整个json字符串的结构组成,有几个大括号{},包括嵌套的大括号{},有几个中括号[],包括嵌套的[]。然后由外及内,最外层肯定是大括号{},就是一个json对象,也就是JsonObject,接着再在这一层,看看有没有中括号[],有的话就是json数组,也就是JsonArray,当前层的字段值可以根据当前层的json对象和字段名获取。如此,往内再走下一层json对象,也就是说查看第二个大括号{},依此类推。
httpClientgetHostConfiguration()setProxy(dynamicIpgetIp(), dynamicIpgetPort());
这样可以,我这里dynamicIp是从redis里随机取的,有个定时任务去取代理IP放redis里面
0条评论