`
jgsj
  • 浏览: 1001497 次
文章分类
社区版块
存档分类
最新评论

struts2实战:全文搜索引擎

 
阅读更多
转载请注明出处:http://blog.csdn.net/zbf8441372
本文对自己开发的基于lucene和J2EE技术的搜索引擎开发经验进行简单总结。今后可能会从性能的角度总结lucene开发经验。当数据上TB级别后,分布式lucene以及结合分布式文件系统(如HDFS)或NoSQL等问题应该会成为我的技术关键点。而本文主要介绍struts2.0的关键特性和实践经验。


1. struts如何获得前台参数?

struts2通过struts.xml,使struts中的action或者intercepter与某一jsp对应

<package name="main" extends="struts-default">
       
       <global-results>
          <result name="search">/test.jsp</result>
        </global-results>
        
        <action name="DoSearch" class="action.searchAciton" method="searchResult">
          	<result name="success">/search.jsp</result>
          	<result name="error">/nobook.jsp</result>
        </action>
    
   </package>  

最简单的是前台可以是一个form表单。这个表单可以是用html的标签写,也可以是用struts的标签写。表达对应一个action,并传回一个带参数的url。

前台的url通过 ActionName?var1=xx&var2=yy 的形式传给特定action如:

/DoSearch?sk=物理&type=title

这里的ActionName会在struts.xml里匹配,找到对应的action.java。

传进去的参数,如sk和type,需要在action.java里以同一名称声明,并设置getter, setter函数。区别于servlet通过request.getParameterName()的后台读取前台参数方式,struts的getter和setter将完成这些步骤。


2. 前台如何读取struts内容?

第一种:struts标签传。

<li>总共花费 <font color="red" ><s:text name="time"></s:text></font> ms, 找到 <font color="red" ><s:text name="count"></s:text></font>条记录</li>

<s:iterator id="BookAttributes" value="booklist" >
作者:${BookAttributes.creator} <br />
分类:${BookAttributes.CRC}<br />
ISBN:${BookAttributes.ISBN}<br />
出版日期:${BookAttributes.date}<br />
  <!--  do something-->
</s:iterator>

以上两种是常用的通过struts标签来传输变量到前台的方式。但是,有时候无法满足我们的需求。

比如:如何在一个iterator内,加入另一个遍历?action的两个list需要在一个遍历内输出结果,而且list里每一个对象又是一个类。

我的解决方法是用request来处理。

有几点要知道的是:

1. struts的变量是如何用标签付到前台的?

是用setter函数,或者说本质上就是request来做的。

2. 标签不是完全可以满足action变量往前台输送吗?

不是的。这里涉及到Java对象, Js对象, Action内的对象在同一个jsp页面内到底能怎样互通。每个action对应唯一一个jsp,action的标签按上面第一个问题说的,本质上是reuqest根据setter函数来回传的,同时,这个回传标签也可以赋给一个html标签的value值:

<input id="js" type=hidden value="<s:text name='sk'></s:text>" ></input>
(用hidden的原因是,这个是我藏起来让js代码去用的方式,可能比较蠢,但是很简单好操作)

但是,struts标签无法赋给js变量,无法赋给<% %>内的java变量,他永远只是个setter方法,当你的值是一个对象,比如一个List时,你这样赋的结果,就是一个list.toString()的值,对象的属性不能获取,对象在标签下就死掉了。有的人会说,那就用iterator啊。是的,但是我遇到的问题是iterator下,我需要得到两个list的遍历

所以我的方法是结合request,把action中第二个list变量读给java,处理之后传给需要的vaue。见下文。

第二种:用request。

一般可以用struts标签传就用struts标签传。因为那是struts的特性。这种request的方式是最原始的方式。

记得要在jsp声明导入包

<%@page import="org.apache.struts2.ServletActionContext"%>
然后因为action只唯一在一个jsp里书写,所以
request.getAttribute()

直接获得值。

iterator下,我需要得到两个list的遍历的时候,我就在iterator之前,先声明一个计数值

<% int i = 0; %>
<s:iterator id="BookAttributes" value="booklist" >

<%
    i ++;
%>

</s:iterator>

这样就可以对action中任意多的list进行同时遍历,并且java代码来直接操作各种动作。

看个实例:

<%
	// 通过循环变量i和request,从action读取list,用java处理成正确的url。struts标签没办法做双重循环,也取不了list内的类的某个变量
	List<BookAttributes> ba = (ArrayList<BookAttributes>)request.getAttribute("booklist");
	String cata1 = ba.get(i).getCRC().substring(0, 1);
	String cata2 = ba.get(i).getCRC().substring(0, 2);
	String cata3 = ba.get(i).getCRC().substring(0, 3);
	String url1 = "Classify.action?CateId=" + cata1;
	String url2 = "Classify.action?CateId=" + cata2;
	String url3 = "Classify.action?CateId=" + cata3;
	i ++;
 %>

<span id=m_fl><a class="l" href=<%=url1%>>${BookAttributes.firstCat}</a>-><a class="l" href=<%=url2%>>${BookAttributes.secondCat}</a>-><a class="l" href=<%=url3%>>${BookAttributes.thirdCat}</a></span><br>


第三种:异步json取。

这种方法在下面叙述。


3. struts2如何实现异步交互?

struts配置里可以把action以json格式返回,不指定jsp页面。

<package name="test" extends="json-default">

       <action name="ShowAddup" class="action.addupAction">
        	<result type="json"></result>      
        </action>
        
        <action name="ShowBaidu" class="action.baiduAction">
        	<result type="json"></result>      
        </action>

</package>  

同时,前台可以用Ajax或者Jquery封装过的Ajax来提交url,并且在回调函数的data内获得action里所有的标量

下面代码演示了getJSON方法传参并且通过DOM或者jquery等操作把回调函数内的data里的相应变量写到js的某些特定标签内。这里面对于js,jquery的灵活操作和使用就不介绍了,例子中可以看到一些处理方式。

$.getJSON(
   		 url3 ,function(data,state){
   		 	var pagelist = data.pagelist;
   		 	var pagecontentlist = data.pagecontentlist;
   		 	
   		 	var num = pagecontentlist.length;
   		 	
   		 	$("#listbooks").hide();
   		 	//$("#pagecontent").innerHTML = '';
   		 	document.getElementById("pagecontent").innerHTML=" "; // 清空处理
   		 	document.getElementById("pagecontent").style.marginLeft="35px";
   		 	document.getElementById("pagecontent").style.marginRight="20px";
   		 	for (var i = 0; i < num; i ++) {
  		 		$("#pagecontent").append("<font color=blue style='font-size:13px;'><b>出现的书页在: " + pagelist[i].substring(0,7) + "页<b/></color>");
   		 		$("#pagecontent").append("<br/>");
   		 		if (pagecontentlist[i].length > 450) {
   		 			pagecontentlist[i] = pagecontentlist[i].substring(0, 450);
   		 			$("#pagecontent").append("<font color=Chocolate>该页的内容为: </font><font color=darkgrey style='font-size:12px; letter-spacing:0px;'><br />" + pagecontentlist[i] + "</color> " );
   		 			$("#pagecontent").append("<font color=LightSkyBlue style='font-size:13px;'><b><u>more(阅读全文)...</u></b></font> <br/> <br/>");
   		 			
   		 		} else {
   		 		
   		 		$("#pagecontent").append("<font color=lightblue>该页的内容为: </font><font color=darkgrey style='font-size:12px; letter-spacing:0px;'><br />" + pagecontentlist[i] + "</color> <br/> <br/>" );
   		 			
   		 		}
   		 		yit(document.body, sk); // 再加亮下
   		 	} 
   		 }
   	, "json");

jquery是js的库。提供一篇介绍比较清楚的文章, 你就可以很清楚了解到jquery可以为前台做什么:Jquery学习笔记


上面的

$.getJSON();

只是一种,其他方法详见:深入理解jQuery中$.get、$.post、$.getJSON和$.ajax的用法

异步方法,第一,带来了更好的用户体验。第二,我在搜索的时候,form形式的直接传递只能处理一个action,当我需要进行搜索的同时进行别的操作,比如对搜索结果进行统计的时候,我就不能把两件事放在同一个action里做,因为统计会延时搜索结果的输出,搜索结果必定是ms内的事。这时候,就需要一个请求,对应多个action做。

当时在解决这个问题的时候,绕了很多弯路。简单的说,action唯一对应一个书写jsp,而jsp内可以有映射多个action,当然多个action可以指定写在一个jsp里。这个基本出发点一定要清晰。这样的话,异步,同步的调用,返回的结果如何在前台显示都可迎刃而解,具体各种方式我也在前面说明了。



对struts,jquery,js,ajax的使用是一边开发一边学着用的,以上是我开发过程中总结的一些使用方式和注意点。struts的action同样可以用spring的bean来管理,struts的intercepter也是一块内容,我是没有涉及到的。详见:Struts2拦截器的使用 或者大家可以查别的资料。

对struts2.0的总体使用感觉是,代码比servlet少很多,配置很灵活,各种标签需要熟练掌握,比如上面没有提到,可以用这样的方式来传递url给action:

<s:url id='url' action='Classify'>
	<s:param name="CateId" value="%{'N'}"></s:param>
</s:url>
	<s:a href="%{url}">自然科学总论</s:a>

<s:url id='url' action='Classify'>
	<s:param name="CateId" value="%{'O'}"></s:param>
</s:url>
<s:a href="%{url}">数理化</s:a>

<s:url id='url' action='Classify'>
	<s:param name="CateId" value="%{'P'}"></s:param>
</s:url>
<s:a href="%{url}">天文、地球</s:a>

展示上的问题都克服了之后,再从性能的角度来分析lucene的使用。

最后再给一篇比较简明易懂的文章:struts2+jquery+json集成



鉴于我拙劣的表达,附上上面的几份参考资料:

Jquery学习笔记

深入理解jQuery中$.get、$.post、$.getJSON和$.ajax的用法

Struts2拦截器的使用

struts2+jquery+json集成


分享到:
评论

相关推荐

    Lucene4.6+Solr4.6实战开发垂直搜索引擎视频课程

    51.搜索引擎实战(2) 52.搜索引擎实战(3) 53.搜索引擎实战(4) 54.搜索引擎实战(5) 55.搜索引擎实战(6) 56.搜索引擎实战(7) 57.搜索引擎实战(8) 58.搜索引擎实战(9) 59.搜索引擎实战(10) 60.搜索引擎实战(11) 61.搜索...

    基于Lucene4.6+Solr4.6+S2SH实战开发垂直搜索引擎

    对于实际搜索引擎所涉及的各种核心技术都有全面细致的介绍,除了作为搜索系统核心的网络爬虫、索引系统、排序系统、链接分析及用户分析外,还包括网页反作弊、缓存管理、网页去重技术等实际搜索引擎必须关注的技术,...

    Struts 2+Hibernate+Spring整合开发技术详解随书源码

    Struts 2、Hibernate 和 Spring 是Java开发中的三大框架,它们在企业级应用开发中扮演着重要的角色。Struts 2 提供了MVC(Model-View-Controller)设计模式的实现,帮助开发者构建可维护性和扩展性良好的Web应用程序...

    项目实战——————网站

    在本项目实战中,我们构建了一个通用的WEB应用系统,主要涵盖了两个子系统:交易系统和管理系统。这两个系统是相互独立的,旨在提供一个全面的在线业务平台。以下是关于项目中涉及的技术栈及其具体应用的详细说明: ...

    JAVA WEB典型模块与项目实战大全

    第9章 搜索引擎(lucene+web spider)  9.1 关于搜索引擎的基本概念  9.2 网络蜘蛛(web spider)  9.3 下载和分析lucene全文搜索组件  9.4 初步使用lucene全文搜索组件  9.5 新闻搜索引擎具体实现  9.6 ...

    基于Java的搜索引擎系统设计与实现(项目报告+开题报告+答辩PPT+源代码+数据库+部署视频).zip

    《基于Java的搜索引擎系统设计与实现》是一个典型的Java毕业设计项目,涵盖了搜索引擎系统的基本概念、设计原则、技术选型以及实际开发过程中的关键步骤。在这个项目中,学生将深入理解如何构建一个能够处理大规模...

    google对lpsht网站的站内搜索功能代码.rar

    标题 "google对lpsht网站的站内搜索功能代码.rar" 暗示这是一个关于集成Google搜索引擎到一个名为"LPSHT"的网站的站内搜索功能的代码资源。描述中的".rar"表明这是一个压缩文件,可能包含源代码、配置文件或其他相关...

    自学java学习的路线

    5. **搜索引擎与 Lucene**: 探索全文搜索引擎的基本原理和 Lucene 库的应用。 6. **Jboss、WebLogic**: 熟悉两种主流应用服务器的配置和管理。 **面试技巧和项目实战** 1. **面试准备**: 学习如何回答常见的 Java ...

    真实项目网络硬盘【完整】

    5. **搜索功能**:实现对文件名、内容的搜索功能,可能需要用到全文搜索引擎或者自定义的搜索算法。 6. **版本控制**:高级功能可能包括文件版本管理,允许用户恢复到历史版本。 7. **性能优化**:为了提高用户...

    网络安全培训方案.pdf

    * HTTP应用:黑帽SEO之搜索引擎劫持 第二天:信息刺探 * Google hack * Nmap详细讲解 * Dirbuster介绍 * 指纹识别 第三天:漏洞扫描 * Burpsuit * WVS介绍 * Appscan * OpenVAS 第四天:系统安全 * 密码破解 *...

    Java开发工程师简历模板(二十九)

    - **Solr全文检索**:理解搜索引擎技术,可以提升应用的搜索功能。 - **Nginx、Redis、Dubbo、Zookeeper**:用于负载均衡、缓存、分布式服务治理和协调,提升系统的可扩展性和性能。 3. **个人能力与经历**: - ...

    北大青鸟java课程的学习大纲.docx

    6. **Elasticsearch**:全文搜索引擎,用于大数据分析。 7. **cobar**:分布式数据库中间件,实现数据库的水平扩展。 8. **Quartz**:任务调度框架,用于定时任务。 9. **Nginx反向代理和负载均衡**:理解其工作原理...

    java+大数据(1).pdf

    - **Lucene/Solr/Elasticsearch**(10天):全文搜索引擎的原理和应用。 - **Scala/Python**(各5天):大数据处理常用编程语言。 - **Mina/Netty**(通信框架):高性能网络编程库。 - **Spark**(10天):...

    java核心技术

    - **《开发自己的搜索引擎 Lucene+Heritrix》**:中国首部详解Lucene的书,但部分内容可能已过时。 **SOA** - **《精通SOA:基于服务总线的整合开发应用》**:引导读者进入SOA的世界,推荐给希望深入理解SOA的人。 ...

    Lucene教程

    2. **大数据搜索**: 结合Hadoop或Elasticsearch,构建分布式搜索引擎,处理海量数据。 3. **企业级搜索**: 在企业信息管理、文档检索系统中,Lucene能提供高效、精准的搜索体验。 4. **移动应用**: 在Android或iOS...

    java学习路线

    - **搜索引擎与Lucene**:了解全文搜索引擎的实现原理。 - **Jboss、WebLogic**:熟悉主流的应用服务器。 #### 八、面试技巧 - **简历准备**:编写一份高质量的简历。 - **技术面试**:准备常见的技术面试题目。 -...

    java学习过程资源

    Lucene是全文搜索引擎库,Solr是基于Lucene的搜索服务器。学习如何实现高效的文本搜索功能。 【学习阶段16】就业指导(79天): 这个阶段可能包含简历撰写、面试技巧、职业规划等内容,帮助你更好地准备进入IT行业...

Global site tag (gtag.js) - Google Analytics