背景:原先的b/s设计中在一个jsp界面中实现多个复杂的工作流。。。

为实现移动接口的调用保证工作流的正常webproject特别给提供了该虚拟浏览器的方案

原理:通过该方案实现虚拟浏览器后台运行jsp脚本,以达到我们要求

要求:

1、session保持。不然总会跳转到login界面

2、jsp脚本必须被运行,不能仅仅是单纯的发起一个请求

先上

private String submitHandler(HttpServletRequest request,String msg,String sessionid,String pathjsp) throws IOException{
//虚拟浏览器 模拟提交jsp
URL url = null;
//添加浏览器版本号 去掉try catch
WebClient client = new WebClient(BrowserVersion.INTERNET_EXPLORER_10); client.getOptions().setJavaScriptEnabled(true);
client.getOptions().setCssEnabled(false); client.getOptions().setThrowExceptionOnFailingStatusCode(false);
client.getOptions().setThrowExceptionOnScriptError(false);
client.getOptions().setRedirectEnabled(true); url = new URL("http://localhost:"+ request.getServerPort()+pathjsp); System.out.println("sfq--url====" + url);
//跳转登录查看cookie
//HtmlPage page = client.getPage(url);
WebRequest webRequest2 = new WebRequest(url, HttpMethod.POST); List<NameValuePair> reqParam2 = new ArrayList<NameValuePair>(); reqParam2.add(new NameValuePair("paramters", msg));
System.out.println("sfq--url====msg:" + msg); webRequest2.setAdditionalHeader("Cookie", "JSESSIONID="+sessionid); webRequest2.setRequestParameters(reqParam2);
//client.getOptions().setThrowExceptionOnScriptError(true);
HtmlPage page2 = (HtmlPage) client.getPage(webRequest2); System.out.println("sfq--pageasText====" + page2.asText());
WebResponse webResponse = page2.getWebResponse();
int status21 = webResponse.getStatusCode();
System.out.println("sfq--status21====" + status21);
if(status21==200){
return "1";
}else{
return status21+"";
} }

几点说明:

1、由于项目中的jsp原来仅仅是为web服务的。改装成移动端交互使用难免各种报错,仅仅要不影响流程。我选择忽略他们。

所以去掉了当中的try catch异常捕获。(捕获真的非常碍事。

。)、

2、session保持问题纠结了非常久,尝试 网上的方法时大概人品出现了严重的问题,不好使(下面方法真的不好使。。。。

private void setCookies(WebClient webClient,String domain, Map<String, String> cookies) {
if (cookies != null && cookies.size() > 0) {
webClient.getCookieManager().setCookiesEnabled(true);// enable
// cookies
for (Entry<String, String> c : cookies.entrySet()) {
Cookie cookie = new Cookie(domain, c.getKey(), c.getValue());
webClient.getCookieManager().addCookie(cookie);
}
}
}

3、在我们领导的指点下使用requet的方法成功

webRequest2.setAdditionalHeader("Cookie", "JSESSIONID="+sessionid);

当然,你也能够在请求你要的目的jsp之前先做一步模拟登录。从而获得了cookie......当然这就影响运行效率了

4、还不easy在本地測试通过了,搬移到外网server以后直接连接超时,终于通过更换url的ip地址为locslhost,问题解决

补充下:

localhoost  、 127.0.0.1 和本地ip的差别(网络基础太差了。。。

。。

。。)

no1:

localhost也叫local ,正确的解释是:本地server

127.0.0.1在windows等系统的正确解释是:本机地址(本机server)

他们的解析通过本机的host文件,windows自己主动将localhost解析为127.0.0.1

no2:

localhot(local)是不经网卡传输。这点非常重要,它不受网络防火墙和网卡相关的的限制。

127.0.0.1是通过网卡传输,依赖网卡。并受到网络防火墙和网卡相关的限制。

本机IP 也是通过网卡传输的。依赖网卡,并受到网络防火墙和网卡相关的限制。

可是本机IP与127.0.0.1的差别是:

127.0.0.1 仅仅能通过本机訪问

本机IP 通过本机訪问也能通过外部訪问

 

一般设置程序时本地服务用localhost是最好的,localhost不会解析成ip,也不会占用网卡、网络资源。

有时候用localhost能够,但用127.0.0.1就不能够的情况就是在于此。

猜想localhost訪问时,系统带的本机当前用户的权限去訪问,而用ip的时候。等于本机是通过网络再去訪问本机。用的到网络用户的权限。

总结下:

1、訪问本地server不管从效率还是有用上来讲直接使用localhost肯定是上上之选,不受其它问题的干扰

2、在公司法人项目中无知的选择了本机ip,效率最低的选择。訪问要经过外网、防火墙、不啦不啦在找到自己。。。

很多其它參考资料;

1、hmlunit  http://shenbai.iteye.com/blog/1985844

2、http://blog.csdn.net/lu8000/article/details/10693091

3、http://shihlei.iteye.com/blog/2067707

4、localho相关

Android与webserver数据交互编程---3网络爬虫项目实现虚拟浏览器的jsp后台执行的更多相关文章

  1. android json解析及简单例子+Android与服务器端数据交互+Android精彩案例【申明:来源于网络】

    android json解析及简单例子+Android与服务器端数据交互+Android精彩案例[申明:来源于网络] android json解析及简单例子:http://www.open-open. ...

  2. Python即时网络爬虫项目启动说明

    作为酷爱编程的老程序员,实在按耐不下这个冲动,Python真的是太火了,不断撩拨我的心. 我是对Python存有戒备之心的,想当年我基于Drupal做的系统,使用php语言,当语言升级了,推翻了老版本 ...

  3. Python即时网络爬虫项目: 内容提取器的定义

    1. 项目背景 在python 即时网络爬虫项目启动说明中我们讨论一个数字:程序员浪费在调测内容提取规则上的时间,从而我们发起了这个项目,把程序员从繁琐的调测规则中解放出来,投入到更高端的数据处理工作 ...

  4. Python即时网络爬虫项目: 内容提取器的定义(Python2.7版本)

    1. 项目背景 在Python即时网络爬虫项目启动说明中我们讨论一个数字:程序员浪费在调测内容提取规则上的时间太多了(见上图),从而我们发起了这个项目,把程序员从繁琐的调测规则中解放出来,投入到更高端 ...

  5. C语言Linix服务器网络爬虫项目(一)项目初衷和网络爬虫概述

    一.项目初衷和爬虫概述 1.项目初衷 本人的大学毕设就是linux上用c写的一个爬虫,现在我想把它完善起来,让他像一个企业级别的项目.为了重复发明轮子来学习轮子的原理,我们不使用第三方框架(这里是说的 ...

  6. 关于网络爬虫项目的项目建议(NABCD)

    Need 我们小组的研究课题是编写一个更快捷,更安全的爬虫软件,编写时会应用到学长的部分代码并在其基础上完善创新. 初步阅读了学长们的博客上面的几个版本的测试情况和源代码,发现学长们在实现基础功能的条 ...

  7. C语言Linix服务器网络爬虫项目(二)项目设计和通过一个http请求抓取网页的简单实现

    我们通过上一篇了解了爬虫具体要实现的工作之后,我们分析得出的网络爬虫的基本工作流程如下: 1.首先选取一部分精心挑选的种子URL: 2.将这些URL放入待抓取URL队列: 3.从待抓取URL队列中取出 ...

  8. Android与服务器端数据交互(http协议整合struts2+android)

    在android中有时候我们不需要用到本机的SQLite数据库提供数据,更多的时候是从网络上获取数据,那么Android怎么从服务器端获取数据呢?有很多种,归纳起来有 一:基于Http协议获取数据方法 ...

  9. Android - 服务器json数据交互.

    一,服务器端 服务器端使用的是Servlet,封装json对象使用的 'json-lib-2.2.2-jdk15.jar,ezmorph-1.0.4.jar,commons-logging-1.1.j ...

随机推荐

  1. prezi,mfc,toefl,java

    1 用prezi做ppt然后讲 2 用mfc把算法封起来 3 做tpo,背单词 4 写java 哪个任务都很难办.而且脚还没好.

  2. Sublime Text 3破解

    ----- BEGIN LICENSE ----- sgbteam Single User License EA7E- 8891CBB9 F1513E4F 1A3405C1 A865D53F 115F ...

  3. Display Video

    ###chromium webrtc视频显示 ###两个数据源:本地数据源: MediaStreamRemoteVideoSource(content/renderer/media/webrtc/me ...

  4. 【Git 一】Linux安装Git

    一.Git 的优势 #简单说一下 Git 的优势. 1.版本库本地化,支持离线提交,相对独立不影响协同开发. 2.支持快速切换分支方便合并,比较合并性能好. 3.分布式管理,适应不同的业务场景. 4. ...

  5. 用Python爬取影视网站,直接解析播放地址。

    记录时刻! 写这个爬虫主要是想让自己的爬虫实用,把脚本放到了服务器,成为可随时调用的接口. 思路算是没思路吧!把影视名带上去请求影视网站,然后解析出我们需要的播放地址. 我也把自己的接口分享出来.接口 ...

  6. 洛谷 P2083 找人

    P2083 找人 题目背景 无 题目描述 小明要到他的同学家玩,可他只知道他住在某一单元,却不知住在哪个房间.那个单元有N层(1,2……N),每层有M(1,2……M)个房间. 小明会从第一层的某个房间 ...

  7. 用eclipse 检索SVN 上 myEclipse 建的web项后,成java项目解决方法

    用eclipse 检索SVN 上 myEclipse 建的web项后,成java项目解决方法 在网上找了非常多,都无论用. 说添加.project 文件几个属性.但我发现里面都有,在我这里无论什么用. ...

  8. Mongo集群之主从复制

    上线的系统.数据存储是重要部位.若一个公司的数据库部署还是待用单点部署,那若是宕机或是机器被损坏则是多糟糕的事情呀. 主从复制的部署方式为下图 主从复制是一个简单的数据库同步备份集群技术.这样的方式简 ...

  9. HDFS中的命令行

    HDFS中的命令行 本文介绍了HDFS以命令行执行的时候.几个经常使用的命令行的作用和怎样使用~ 1. fs fs是启动命令行动作,该命令用于提供一系列子命令. 使用形式为hadoop fs –cmd ...

  10. iOS开发系列之四 - UITextView 使用方法小结

    // 初始化输入框并设置位置和大小 UITextView *textView = [[UITextView alloc] initWithFrame:CGRectMake(10, 10, 300, 1 ...