Portlet.docx

上传人:b****5 文档编号:7645369 上传时间:2023-01-25 格式:DOCX 页数:11 大小:167.84KB
下载 相关 举报
Portlet.docx_第1页
第1页 / 共11页
Portlet.docx_第2页
第2页 / 共11页
Portlet.docx_第3页
第3页 / 共11页
Portlet.docx_第4页
第4页 / 共11页
Portlet.docx_第5页
第5页 / 共11页
点击查看更多>>
下载资源
资源描述

Portlet.docx

《Portlet.docx》由会员分享,可在线阅读,更多相关《Portlet.docx(11页珍藏版)》请在冰豆网上搜索。

Portlet.docx

Portlet

什么是Portlet?

本文探讨了以下内容:

1.        Portal页面的元素

2.        Portal是什么?

3.        Portlets是什么?

4.        开发“HelloWorld”Portlet

5.        在Pluto上部署HelloWorldPortlet

6.        如何创建Portal页面

7.        结束语

8.        资源

  Portlet规范将portlet定义为一种“基于Java技术的web组件,由处理请求和生成动态内容的portlet容器管理”。

这段话听起来是不是有些费解?

本文将说明portlets是什么以及能用它们做什么。

图1显示了在访问一个portal服务器时浏览器中页面的样子。

图1典型的portal服务器的页面(点击查看原图)

  如果仔细查看浏览器里的页面,就会看到页面是由不同的“窗口”组成的。

一个窗口用于刷新天气,另一个用于新闻,还有一个用于刷新股价,等等。

这里的每一个窗口都代表了一个portlets。

如果看得再仔细些,还会发现每个窗口都有一个标题条和一些按钮,包括最小化和最大化按钮。

  在系统里,这些窗口是相互独立开发、各不同的应用。

新闻portlet的开发者创建应用并打包成war格式的文件,随后portal服务器的管理员在服务器上部署该war文件并创建页面,接下来每个用户会选择在他的页面里有哪些应用。

例如,如果用户对股价不感兴趣而对体育感兴趣,他可以用“体育”窗口替换“股价”窗口。

  Portlet技术需要学习许多新概念,本文不可能全都涵盖,因此本文分为两部分。

在第一部分里我们详细说明portals和portlets,并开发一个简单的“HelloWorld”portlet;在第二部分我们将探讨一些高级主题。

  我们将用Apache的Pluto服务器(PortletAPI1.0规范的参考实现)来测试我们的示例portlets,我们还会花些时间探讨如何安装和使用Pluto服务器。

Portal页面的元素

图2显示了Portal页面的各种元素。

图2portal页面的元素

  每个portlet页面由一个或多个portlet窗口组成,每个portlet窗口又分为两部分:

一个是外观,它决定了portlet窗口的标题条、控制和边界的样式;另一个是portlet段,它由portlet应用填充。

  Portal服务器决定了portal页面的整体观感,像标识、标题条颜色、控制图标等。

通过修改几个JSP和css模板文件就可以改变portal的整个观感。

我们将在“如何创建portal页面”部分对此做深入讨论。

Portal是什么?

  在了解portlet之前有必要先了解portal。

在Portlet规范里是这样讲的:

“portal是一种web应用,通常用来提供个性化、单次登录、聚集各个信息源的内容,并作为信息系统表现层的宿主。

聚集是指将来自各个信息源的内容集成到一个web页面里的活动”。

  Portal的功能可以分为三个主要方面:

1.        Portlet容器:

Portlet容器与servlet容器非常类似,所有的portlet都部署在portlet容器里,portlet容器控制portlet的生命周期并为其提供必要的资源和环境信息。

Portlet容器负责初始化和销毁portlets,向portlets传送用户请求并合成响应。

2.        内容聚集:

Portlet规范中规定portal的主要工作之一是聚集由各种portlet应用生成的内容,我们将在“如何创建Portal页面”部分对此做进一步讨论。

3.        公共服务:

portlet服务器的一个强项是它所提供的一套公共服务。

这些服务并不是portlet规范所要求的,但portal的商业实现版本提供了丰富的公共服务以有别于它们的竞争者。

在大部分实现中都有望找到的几个公共服务有:

        o单次登录:

只需登录portal服务器一次就可以访问所有其它的应用,这意味着你无需再分别登录每一个应用。

例如一旦我登录了我的intranet网站,我就能访问mail应用、IM消息应用和其它的intranet应用,不必再分别登录这些应用。

  Portal服务器会为你分配一个通行证库。

你只需要在mail应用里设定一次用户名和密码,这些信息将以加密的方式存储在通行证库中。

在你已登录到intranet网站并要访问mail应用的时候,portal服务器会从通行证库中读取你的通行证替你登录到mail服务器上。

你对其它应用的访问也将照此处理。

          o个性化:

个性化服务的基本实现使用户能从两方面个性化她的页面:

第一,用户可以根据她的自身喜好决定标题条的颜色和控制图标。

第二,用户可以决定在她的页面上有哪些portlets。

例如,如果我是个体育迷,我可能会用一个能提供我钟爱球队最新信息的portlet来取代股票和新闻portlets。

        一些在个性化服务方面领先的商业实现版本允许你建立为用户显示什么样的应用所依据的标准(如收入和兴趣)。

在这种情况下,可以设定一些像“对任何收入为X的用户显示馈赠商品的portlet”和“对任何收入为X的用户显示打折商品的portlet”这样的商业规则。

        此外还有一些公共服务,比如机器翻译,是由portal服务器将portlet生成的内容翻译为用户要求的语言。

大部分的商业portal服务器都支持手持设备访问并具有针对不同的浏览终端生成不同内容的能力。

Portlets是什么?

  与servlets类似,portlets是部署在容器内用来生成动态内容的web组件。

从技术角度讲portlet是一个实现了javax.portlet.Portlet接口的类,它被打包成war文件格式部署到portlet容器里。

  Portlets在以下方面与servlets相似:

1.        portlets由特定的容器管理。

2.        portlets生成动态内容。

3.        portlet的生命周期由容器管理。

4.        portlets通过请求/响应模式与web客户端交互。

  Portlets在以下方面与servlets相异:

1.        portlets只能生成标记段,而不是整个文档。

2.        portlets没有可供直接访问的URL地址。

不过你还是能够让别人通过URL访问到portlet,你可以把包含该portlet的页面的URL发给他。

3.        portlets不能随意地生成内容,这是因为portlet生成的内容最终要成为portal页面的一部分。

如果portal服务器要求的是html/text类型,那么所有的portlets都应生成html/text类型的内容。

再比方说,如果portal服务器要求的是WML类型,那么所有的portlets都应生成WML类型的内容。

  portlets还提供了一些附加的功能:

1.        设置参数的持久化存储:

portlets提供了一个PortletPreferences对象用来保存用户的设置参数。

这些参数被存入一个持久化数据库,这样服务器重启后数据依然有效。

开发者不必关心这些数据存储的具体实现机制。

2.        请求处理:

portlets提供了更为细粒度的请求处理。

对于用户在portlet上动作时向该portlet发出的请求(一种称为活跃期的状态),或者因用户在其它portlet上动作而引发的刷新页面请求,Portal服务器提供了两种不同的回调方法来处理。

3.        Portlet模式:

portlets用模式的概念来表示用户在做什么。

在使用mail应用的时候,你可能会用它来读信、写信或检查信件――这些都是mail应用的预定功能,Portlets通常以VIEW模式提供这些功能。

但还有一些活动,像指定刷新时间或(重新)设置用户名和密码,这些活动允许用户定制应用的行为,因此它们用的是EDIT模式。

Mail应用的帮助功能用的是HELP模式。

  如果仔细想想其实这里面并没有什么新东西,它们反而大部分都是普通的业务需求。

Portlet规范的作用在于它提供了一个抽象层,这才是它对所有与之相关的人-最终用户、开发者和管理员-的价值所在。

  作为一个开发者,我会将所有与VIEW模式有关的业务逻辑放入doView()方法,将与应用配置有关的业务逻辑放入doEdit()方法,将与帮助有关的逻辑放入doHelp()方法

  这就简化了管理员对portlet应用的访问控制管理,因为他只需改变portlet的访问权限就能决定用户能做什么。

例如,如果mail应用的一个用户能够在EDIT模式下设定用户名和密码,那么就可以断定他具有EDIT模式访问权限。

  不妨考虑这样一种情形:

我是一个intranet网站的管理员,我的公司买了一个能显示新闻信息的第三方portlet应用,该应用允许用户指定跟踪新闻更新的URL地址,我想借助它为用户显示公司的内部新闻。

另一个需求是我不想让用户通过该应用来跟踪任何其它的新闻信息来源。

作为管理员,我可以为所有的用户指定一个用于内部新闻更新的URL地址,同时通过改变portlet应用的部署描述符来取消其它人修改该地址的权限。

  由于所有的portlet应用都具有相似的UI界面,因此采用portlets可使网站对最终用户更具吸引力。

如果她想阅读任何一个应用的帮助信息,她可以点击帮助按钮;她也知道点击编辑按钮能让她进入应用的配置屏。

标准化的用户界面使你的portlet应用更引人。

4.        窗口状态:

窗口状态决定了portal页面上留给portlet生成内容的空间。

如果点击最大化按钮,portlet将占据整个屏幕,成为用户唯一可用的portlet;而在最小化状态,portlet只显示为标题条。

作为开发者应当根据可用空间的大小来定做内容。

5.        用户信息:

通常portlets向发出请求的用户提供个性化的内容,为了能更加行之有效,portlets需要访问用户的属性信息,如姓名、email、电话等。

PortletAPI为此提供了用户属性的概念,开发者能够用标准的方式访问这些属性,并由管理员负责在这些属性与真实的用户信息数据库(通常是LDAP服务器)之间建立映射关系。

  我们将在本文的第二部分深入讨论这些特点-请求处理、用户信息和portlet模式。

开发"HelloWorld"Portlet

  现在我们就来开发一个简单的HelloWorldportlet。

1.        创建一个名为HelloWorld的web项目,它与通常的servlet项目类似,有一个/WEB-INF/web.xml文件作为项目的部署描述符。

2.        在buildpath里加入portlet-api-1.0.jar文件,该jar文件是Pluto发行包的一部分。

3.        在Source文件夹中按如下内容创建HelloWorld.java文件:

publicclassHelloWorldextendsGenericPortlet{

  protectedvoiddoView(RenderRequestrequest,

  RenderResponseresponse)throws

  PortletException,IOException{

        response.setContentType("text/html");

        response.getWriter().println("HelloPortlet");

        }

}

  每个portlet都要实现Portlet接口,该接口为portlet定义了生命周期方法。

由于不想覆盖所有这些方法,我们只对GenericPortlet类进行扩展,它是一个实现了Portlet接口的适配器类。

GenericPortlet类提供了所有生命周期方法的默认实现,所以我们只需实现我们所需要的方法。

  我们在HelloWorldportlet里要做的只是显示“HelloPortlet”,所以我们将覆盖GenericPortlet类的doView()方法,该方法以PortletRequest和PortletResponse作为参数。

在doView()方法中首先调用response.setContentType()以通知portlet容器该portlet将要生成何种类型的内容-如果不这样做就会导致IllegalStateException异常。

一旦设置了内容的类型,就可以从response对象中获得PrintWriter并开始写入。

4.        每个portlet应用在/WEB-INF文件夹中都有一个portlet.xml文件,它是portlet应用的部署描述符。

按以下内容创建portlet.xml文件:

  HelloWorldDescription

        

    HelloWorld

        

    HelloWorld

        

    com.test.HelloWorld

        

    -1

        

        

          text/html

      VIEW

          

        

    en

        

        

          HelloWorld

          HelloWorld

          

          Hello,pluto

      

  元素声明了portlet的名字,元素指定了portlet的全限定类名,元素以秒为单位指定了内容超期的时间。

这里面有一点需要注意:

你在portlet上的某些动作可能会导致内容刷新,这与缓存时间无关。

  元素指定对于给定的有哪些模式可供支持。

在示例中我们假定HelloWorld只能生成text/html类型的内容,且只有view模式可支持该内容类型。

如果要增加对其它内容类型的支持,需要添加新的元素并指定支持该MIME类型的模式有哪些。

通常portlet对于text/html类型有VIEW、EDIT和HELP模式可供支持,而对于WMLMIME类型则只有VIEW模式。

  还可以用元素来指定portlet支持哪些本地化。

元素用来指定portlet的标题。</p><p>如果要对标题做国际化处理,可以用元素<resource-bundle>指定资源(比例properties文件)的文件名。</p><p>在这种情况下,容器将根据用户所在的地区从适当的properties文件中选择标题。</p><p>5.        每个portlet应用都是一个web应用,因此除了portlet.xml文件之外还需要有web.xml文件。</p><p><web-app></p><p>  <display-name>HelloWorldPortlet</p><p>  </display-name></p><p>  <welcome-file-list</p><p>    <welcome-file>index.jsp</p><p>        </welcome-file></p><p>  </welcome-file-list></p><p></web-app></p><p>6.        接下来将这些文件进行编译并打包为war文件。</p><p>你可以自己完成这些工作,或者下载带有build.xml的示例代码(参见“资源”部分)来创建war文件。</p><p>在Pluto上部署HelloWorldPortlet</p><p>  Pluto尚处于开发阶段的早期,因此还没有一套易于使用的管理工具。</p><p>为了能使用Pluto服务器,需要将编译和源代码两个版本都下载。</p><p>需要注意的是以下说明是针对Windows平台的,Unix用户通过修改斜杠符号和执行shshell脚本(不是bat批命令文件)会得到类似的结果。</p><p>1.        创建一个文件夹,比如C:</p><p>\PlutoInstallation。</p><p>2.        从Pluto的网站下载pluto-1.0.1-rc1.zip和pluto-src-1.0.1-rc1.zip。</p><p>3.        将pluto-1.0.1-rc1.zip解压到C:</p><p>\PlutoInstallation.文件夹,它应被解压到C:</p><p>\PlutoInstallation\pluto-1.0.1-rc1文件夹下。</p><p>4.        执行C:</p><p>\PlutoInstallation\pluto-1.0.1-rc1\bin\startup.bat启动Pluto,现在可以通过地址http:</p><p>//localhost:</p><p>8080/pluto/portal访问Pluto服务器。</p><p>5.        将pluto-src-1.0.1-rc1.zip解压到C:</p><p>\PlutoInstallation\PlutoSrc文件夹。</p><p>6.        进入C:</p><p>\PlutoInstallation\PlutoSrc文件夹,执行mavendistribute:</p><p>all.,编译并下载运行常规管理任务所必需的相关资源文件。</p><p>现在可以将HelloWorldPortlet.war作为portlet进行安装了。</p><p>7.        首先将HelloWorldPortlet.war文件拷贝到C:</p><p>\PlutoInstallation\portlets目录,如果没这个目录就创建它。</p><p>8.        将C:</p><p>\PlutoInstallation\plutosrc\build.properties.sample更名为build.properties。</p><p>9.        编辑build.properties,将maven.tomcat.home指向Pluto编译版的安装位置,在本例中应改为maven.tomcat.home=C:</p><p>/PlutoInstallation/pluto-1.0.1-rc1。</p><p>10.        为了安装portlet,进入C:</p><p>\plutoInstallation\plutosrc\deploy文件夹,执行mavendeploy-Ddeploy=c:</p><p>\PlutoInstallation\portlets\HelloWorldPortlet.war,应能看到“buildsuccessful”信息。</p><p>11.        在C:</p><p>\PlutoInstallation\pluto-1.0.1-rc1\webapps文件夹下,应该有一个HelloWorldPortlet文件夹。</p><p>12.        现在进入C:</p><p>\PlutoInstallation\pluto-1.0.1-rc1\webapps\HelloWorld\WEB-INF\folder文件夹,打开portlet的web.xml文件,你会发现里面自动多了几行,如下所示:</p><p><servlet></p><p>  <servlet-name>HelloWorld</servlet-name></p><p>    <display-name>HelloWorldWrapper</display-name></p><p>      <description>Automatedgenerated</p><p>      PortletWrapper</description></p><p>      <servlet-class>org.apache.pluto.core.PortletServlet</p><p>      </servlet-class></p><p>      <init-param></p><p>        <param-name>portlet-class</param-name></p><p>        <param-value>com.test.HelloWorld</p><p>        </param-value></p><p>      </init-param></p><p>      <init-param></p><p>        <param-name>portlet-guid</param-name></p><p>        <param-value>HelloPluto.HelloWorld</p><p>        </param-value></p><p>      </init-param></p><p></servlet></p><p>13.        接下来我们将该portlet加到页面里。</p><p>进入C:</p><p>\PlutoInstallation\pluto-1.0.1-rc1\webapps\pluto\WEB-INF\data文件夹,可以看到有两个XML文件:</p><p>pageregistry.xml和portletentityregistry.xml。</p><p>14.        portletentityregistry.xml包含了portlet的定义,在该文件中加入以下几行:</p><p><applicationid="5"></p><p>  <definition-id>HelloWorld</definition-id></p><p>    <portletid="1"></p><p>      <definition-id>HelloWorld.HelloWorld</definition-id></p><p>    </portlet></p><p></application></p><p>  应用的<definition-id>应为web应用所在文件夹的名字,portlet的<definition-id>应与web.xml中生成的portlet-guid相一致。</p><p>15.        pageregistry.xml定义了页面中包含了哪些portlets,对该文件做如下改动:</p><p>  <fragmentname="p2"type="portlet"></p><p>    <propertyname="portlet"value="5.1"/></p><p></fragment></p><p>16.        执行shutdown命令和startup命令重启Pluto服务器,返回到地址http:</p><p>//localhost:</p><p>8080/pluto/portal并点击“TestLink”-此时页面中将出现我们的</p><p>HelloWorld</p> </div> <div class="readmore" onclick="showmore()" style="background-color:transparent; height:auto; margin:0px 0px; padding:20px 0px 0px 0px;"><span class="btn-readmore" style="background-color:transparent;"><em style=" font-style:normal">展开</em>阅读全文<i></i></span></div> <script> function showmore() { $(".readmore").hide(); $(".detail-article").css({ "height":"auto", "overflow": "hidden" }); } $(document).ready(function() { var dh = $(".detail-article").height(); if(dh >100) { $(".detail-article").css({ "height":"100px", "overflow": "hidden" }); } else { $(".readmore").hide(); } }); </script> </div> <script> var defaultShowPage = parseInt("5"); var id = "7645369"; var total_page = "11"; var mfull = false; var mshow = false; function DownLoad() { window.location.href='https://m.bdocx.com/down/7645369.html'; } function relate() { var reltop = $('#relate').offset().top-50; $("html,body").animate({ scrollTop: reltop }, 500); } </script> <script> var pre = "https://file1.bdocx.com/fileroot1/2023-1/21/16efc036-0831-435c-a4d6-eaa5b46f9d0a/16efc036-0831-435c-a4d6-eaa5b46f9d0a"; var freepage = parseInt('11'); var total_c = parseInt('11'); var start = defaultShowPage; var adcount = 0; var adindex = 0; var adType_list = ";0;1;2;3;4;5;6;7;8;9;10;"; var end = start; function ShowSvg() { end = start + defaultShowPage; if (end > freepage) end = freepage; for (var i = start; i < end; i++) { var imgurl = pre + (i + 1) + '.gif'; var html = "<img src='" + imgurl + "' onerror=\"this.src='/images/s.gif'\" alt=\"Portlet.docx_第" + (i + 1) + "页\" width='100%'/>"; $("#page").append("<div class='page'>" + html + "</div>"); $("#page").append("<div class='pageSize'>第" + (i + 1) + "页 / 共" + total_c + "页</div>"); if(adcount > 0 && adType_list.indexOf(";"+(i+1)+";")>-1) { if(adindex > (adcount-1)) adindex = 0; $("#page").append("<div class='pagead' id='addiv"+(i + 1)+"'></div>"); document.getElementById("addiv"+(i + 1)+"").innerHTML =document.getElementById("adpre" + adindex).outerHTML; adindex += 1; } } start = end; if (start > (freepage - 1)) { if (start < total_c) { $("#pageMore").removeClass("btnmore"); $("#pageMore").html("亲,该文档总共" + total_c + "页,到这儿已超出免费预览范围,如果喜欢就下载吧!"); } else { $("#pageMore").removeClass("btnmore"); $("#pageMore").html("亲,该文档总共" + total_c + "页全部预览完了,如果喜欢就下载吧!"); } } } //$(document).ready(function () { // ShowSvg(); //}); </script> <div id="relate" class="container" style="padding:0px 0px 15px 0px; margin-top:20px; border:solid 1px #dceef8"> <div style=" font-size: 16px; background-color:#e5f0f7; margin-bottom:5px; font-weight: bold; text-indent:10px; line-height: 40px; height:40px; padding-bottom: 0px;">相关资源</div> <div id="relatelist" style="padding-left:5px;"> <ul> <li><em class="pptx"/></em><a target="_parent" href="https://m.bdocx.com/doc/30848072.html" title="教育测量与评价第三版全套完整教学课件.pptx">教育测量与评价第三版全套完整教学课件.pptx</a> </li><li><em class="xls"/></em><a target="_parent" href="https://m.bdocx.com/doc/30848010.html" title="数控车床合格证明书.xls">数控车床合格证明书.xls</a> </li><li><em class="pptx"/></em><a target="_parent" href="https://m.bdocx.com/doc/30847944.html" title="防诈骗安全教育主题班会防诈骗安全教育课件ppt.pptx">防诈骗安全教育主题班会防诈骗安全教育课件ppt.pptx</a> </li><li><em class="pptx"/></em><a target="_parent" href="https://m.bdocx.com/doc/30847904.html" title="中职新生入学教育中专入学开学第一课教育课件下载.pptx">中职新生入学教育中专入学开学第一课教育课件下载.pptx</a> </li><li><em class="pptx"/></em><a target="_parent" href="https://m.bdocx.com/doc/30847893.html" title="-(完整版)-幼儿园端午节介绍PPT模板.pptx">-(完整版)-幼儿园端午节介绍PPT模板.pptx</a> </li><li><em class="ppt"/></em><a target="_parent" href="https://m.bdocx.com/doc/30847868.html" title="高频电子线路-曾兴雯4.ppt">高频电子线路-曾兴雯4.ppt</a> </li><li><em class="pptx"/></em><a target="_parent" href="https://m.bdocx.com/doc/30847789.html" title="最新人教版九年级数学下册-全册教学课件全集(8.pptx">最新人教版九年级数学下册-全册教学课件全集(8.pptx</a> </li><li><em class="pptx"/></em><a target="_parent" href="https://m.bdocx.com/doc/30847788.html" title="(本科)财务管理2全套教学课件完整版PPT.pptx">(本科)财务管理2全套教学课件完整版PPT.pptx</a> </li><li><em class="xls"/></em><a target="_parent" href="https://m.bdocx.com/doc/30847536.html" title="内部审核检查表GMPC.xls.xls">内部审核检查表GMPC.xls.xls</a> </li><li><em class="xls"/></em><a target="_parent" href="https://m.bdocx.com/doc/30847532.html" title="GRR-ANOVA-3771005J02-(1..xls">GRR-ANOVA-3771005J02-(1..xls</a> </li> </ul> </div> </div> <div class="container" style="padding:0px 0px 15px 0px; margin-top:20px; border:solid 1px #dceef8"> <div style=" font-size: 16px; background-color:#e5f0f7; margin-bottom:5px; font-weight: bold; text-indent:10px; line-height: 40px; height:40px; padding-bottom: 0px;">猜你喜欢</div> <div id="relatelist" style="padding-left:5px;"> <ul> <li><em class="docx"></em> <a href="https://m.bdocx.com/doc/3191704.html" target="_parent" title="语文1316课教案.docx">语文1316课教案.docx</a></li> <li><em class="docx"></em> <a href="https://m.bdocx.com/doc/3191705.html" target="_parent" title="重庆南开初级初三半期 英语.docx">重庆南开初级初三半期 英语.docx</a></li> <li><em class="docx"></em> <a href="https://m.bdocx.com/doc/3191706.html" target="_parent" title="语文s版小学三年级上语文教案.docx">语文s版小学三年级上语文教案.docx</a></li> <li><em class="docx"></em> <a href="https://m.bdocx.com/doc/3191707.html" target="_parent" title="小学五年级数学下册填空判断选择.docx">小学五年级数学下册填空判断选择.docx</a></li> <li><em class="docx"></em> <a href="https://m.bdocx.com/doc/3191708.html" target="_parent" title="语文语文骆驼祥子名著阅读的专项培优练习题含答案.docx">语文语文骆驼祥子名著阅读的专项培优练习题含答案.docx</a></li> <li><em class="docx"></em> <a href="https://m.bdocx.com/doc/3191709.html" target="_parent" title="夏夷贝市场分析报告.docx">夏夷贝市场分析报告.docx</a></li> <li><em class="docx"></em> <a href="https://m.bdocx.com/doc/3191710.html" target="_parent" title="推优工作总结3篇.docx">推优工作总结3篇.docx</a></li> <li><em class="docx"></em> <a href="https://m.bdocx.com/doc/3191711.html" target="_parent" title="雨具项目可行性研究报告.docx">雨具项目可行性研究报告.docx</a></li> <li><em class="docx"></em> <a href="https://m.bdocx.com/doc/3191712.html" target="_parent" title="摄影爱好者必读 旅拍摄影师创作秘籍 在路上拍出好照片.docx">摄影爱好者必读 旅拍摄影师创作秘籍 在路上拍出好照片.docx</a></li> </ul> </div> </div> <div style=" font-size: 16px; background-color:#e5f0f7; margin-top:20px; font-weight: bold; text-indent:10px; line-height: 40px; height:40px; padding-bottom: 0px; margin-bottom:10px;"> 相关搜索</div> <div class="widget-box pt0" style="border: none; padding:0px 5px;"> <ul class="taglist--inline multi"> <li class="tagPopup"><a target="_parent" class="tag tagsearch" rel="nofollow" href="https://m.bdocx.com/search.html?q=Portlet">Portlet</a></li> </ul> </div> <br /> <div > 当前位置:<a target="_parent" href="https://m.bdocx.com/">首页</a> > <a href="https://m.bdocx.com/booklist-00005.html">农林牧渔</a><span> > </span><a href="https://m.bdocx.com/booklist-0000500001.html">林学</a> </div> <br /> <div class="cssnone"> <iframe title="来源" src="https://m.bdocx.com/BookRead.aspx?id=%7c%7cK%2fVLVy5fo%3d&parto=twsk%2bRS0LENbtVtFP%2bTHIvO%2fhyI0lKDaopm1d%2fOOVL%2ftjB5zwnlWt9eML3t5oAKGWlTe9eCZ6zeWW8eEkw0g2B1scbXsyoea5fr3kypmO6PMUJiY4kovHyHhnAUJTKnAV7Kt0rY4IBiDounpkrgb2W5VwqB3B8rkdXpi0IRYkqAoY%2ba5VipTnMvkya0O0Hij6CEedFS6CbVKqCc8oBNWvRI3%2fFT8IDkp" frameborder="0" style="width: 0px; height: 0px"> </iframe> </div> <span id="LabelScript"></span> <script src="https://mstatic.bdocx.com/JS/bootstrap-collapse.js"></script> </form> <div class="siteInner_bg" style="margin-top: 40px; border: solid 0px red; margin-left: 0px; margin-right: 0px;"> <div class="siteInner"> <p style="text-align: center;">copyright@ 2008-2022 冰豆网网站版权所有</p><p style="text-align: center;">经营许可证编号:<a href="http://beian.miit.gov.cn/" target="_blank">鄂ICP备2022015515号-1</a></p><script>var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?2e77bd3f6fe91b0e21d3f22267249ee3"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })();</script><script>(function(){ var el = document.createElement("script"); el.src = "https://lf1-cdn-tos.bytegoofy.com/goofy/ttzz/push.js?81476e42bf626128cf29544ee216a8ed7deb9487dce7ed62313212129c4244a219d1c501ebd3301f5e2290626f5b53d078c8250527fa0dfd9783a026ff3cf719"; el.id = "ttzz"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(el, s); })(window)</script> </div> </div> <div class="trnav clearfix" id="navcontent" style="display: none; background-color:#3a71b1; "> <div class="trlogoside" id="navlogo" style="display: none;"> <a href="https://m.bdocx.com/" title="冰豆网"><img src="https://www.bdocx.com/images/logo_bd.png" alt="冰豆网"></a> <div class="trnavclose" id="navclose"> <span></span> </div> </div> <div class="navcontainer"> <div class="row"> <ul class="nav navbar-nav trnavul headercontent" id="navigation" style="margin:20px 0 0px;"> <li><a target="_parent"href="https://m.bdocx.com/login.aspx">登录</a></li> <li><a target="_parent"href="https://m.bdocx.com/">首页 </a></li> <li><a target="_parent"href="https://m.bdocx.com/booklist-0.html">资源分类 </a></li> <li><a target="_parent"href="https://m.bdocx.com/UserManage/Recharge.aspx?f=0"><img src="https://m.bdocx.com/images/s.gif" alt="new" class="hottip1">升级会员 <img src="https://www.bdocx.com/FileUpload/Images/48520fea-bc98-41ae-b183-84689c7075c9.gif" alt="new" class="hottip"></a></li> <li><a target="_parent"href="https://m.bdocx.com/newslist.html">通知公告 </a></li> <li><a target="_parent"href="https://m.bdocx.com/h-0.html">帮助中心 </a></li> </ul> </div> </div> </div> <script type="text/javascript"> function stopPropagation(e) { var ev = e || window.event; if (ev.stopPropagation) { ev.stopPropagation(); } else if (window.event) { window.event.cancelBubble = true;//兼容IE } } $("#navmore").click(function (e) { $("#navcontent").show(); $("#navlogo").show(); stopPropagation(e); var navcontentwidth = $("#navcontent").width(); $('#navcontent').css({ 'right': '-' + navcontentwidth + 'px' }); $("#navcontent").show().animate({ "right": 0 }, 300); }); $(document).bind('click', function () { var navcontentwidth = $("#navcontent").width(); $("#navcontent").animate({ 'right': '-' + navcontentwidth + 'px' }, 300, function () { $("#navcontent").hide(); }); $("#navlogo").fadeOut(300); }); $("#navcontent").click(function (e) { stopPropagation(e); }); $("#navclose").click(function (e) { var navcontentwidth = $("#navcontent").width(); $("#navcontent").animate({ 'right': '-' + navcontentwidth + 'px' }, 300, function () { $("#navcontent").hide(); }); $("#navlogo").fadeOut(300); }); </script> <script> function BaseShare(title, desc, imgUrl) { var link = "https://m.bdocx.com/doc/7645369.html"; if (wx) { wx.config({ debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId: 'wx4f717640abfd1120', // 必填,公众号的唯一标识 timestamp: '1719368544', // 必填,生成签名的时间戳 nonceStr: 'FE73F687E5BC5280214E0486B273A5F9', // 必填,生成签名的随机串 signature: '732350508619be2b8c84cdac738cb8c43afc9289',// 必填,签名,见附录1 jsApiList: ['onMenuShareAppMessage', 'onMenuShareTimeline', 'updateAppMessageShareData', 'updateTimelineShareData', 'hideMenuItems'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 //openTagList: ["wx-open-launch-weapp"]//H5打开小程序 }); wx.ready(function () { //需在用户可能点击分享按钮前就先调用 wx.hideMenuItems({// 要隐藏的菜单项,只能隐藏“传播类”和“保护类”按钮,所有menu项见附录3 menuList: ['menuItem:share:qq', 'menuItem:favorite', 'menuItem:share:QZone', 'menuItem:share:email', 'menuItem:originPage', 'menuItem:readMode', 'menuItem:delete', 'menuItem:editTag', 'menuItem:share:facebook', 'menuItem:share:weiboApp', 'menuItem:share:brand'] }); var shareData = { title: title, // 分享标题 desc: desc,//这里请特别注意是要去除html link: link, // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致 imgUrl: imgUrl, // 分享图标 }; wx.updateAppMessageShareData(shareData);//1.4 分享到朋友 wx.updateTimelineShareData(shareData);//1.4分享到朋友圈 }); } } function BaseShare(title, desc, imgUrl, link) { if (link=="") link = "https://m.bdocx.com/doc/7645369.html"; if (wx) { wx.config({ debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId: 'wx4f717640abfd1120', // 必填,公众号的唯一标识 timestamp: '1719368544', // 必填,生成签名的时间戳 nonceStr: 'FE73F687E5BC5280214E0486B273A5F9', // 必填,生成签名的随机串 signature: '732350508619be2b8c84cdac738cb8c43afc9289',// 必填,签名,见附录1 jsApiList: ['onMenuShareAppMessage', 'onMenuShareTimeline', 'updateAppMessageShareData', 'updateTimelineShareData', 'hideMenuItems'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 //openTagList: ["wx-open-launch-weapp"]//H5打开小程序 }); wx.ready(function () { //需在用户可能点击分享按钮前就先调用 wx.hideMenuItems({// 要隐藏的菜单项,只能隐藏“传播类”和“保护类”按钮,所有menu项见附录3 menuList: ['menuItem:share:qq', 'menuItem:favorite', 'menuItem:share:QZone', 'menuItem:share:email', 'menuItem:originPage', 'menuItem:readMode', 'menuItem:delete', 'menuItem:editTag', 'menuItem:share:facebook', 'menuItem:share:weiboApp', 'menuItem:share:brand'] }); var shareData = { title: title, // 分享标题 desc: desc,//这里请特别注意是要去除html link: link, // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致 imgUrl: imgUrl, // 分享图标 }; wx.updateAppMessageShareData(shareData);//1.4 分享到朋友 wx.updateTimelineShareData(shareData);//1.4分享到朋友圈 }); } } </script> <script> $(document).ready(function () { var arr = $(".headercontent"); for (var i = 0; i < arr.length; i++) { (function (index) { var url = "https://m.bdocx.com/header.aspx"; $.get(url + "?t=" + (new Date()).valueOf(), function (d) { try { arr.eq(index).empty().html(d); } catch (e) { } try { arr.html(d); } catch (e) { } }); })(i); } }); </script> <script src="https://mstatic.bdocx.com/js/jquery.lazyload.js"></script> <script charset="utf-8"> $("img.lazys").lazyload({ threshold: 200, effect: "fadeIn" }); </script> </body> </html>