Buffalo ajax实例
Buffalo是国人开发的Ajax框架,它可以使用户在js中方便的调用java代码里的方法。
后台配置方法:
1. web.xml中配置相关servlet 如下:
<!–buffalo ajax–>
<servlet>
<servlet-name>buffalo</servlet-name>
<servlet-class>net.buffalo.web.servlet.ApplicationServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>buffalo</servlet-name>
<url-pattern>/buffalo/*</url-pattern>
</servlet-mapping>
2. 需要引入的jar包为:
加入两个jar包:buffalo-2.0.jar和commons-logging-api-1.0.4.jar(下载包里有,下载地址见文章最后)。
注:若commons-logging-api-1.0.4.jar不加入,会抛出异常。
3. 编写需要调用的业务类。
如:
1. desktopService.java
package oa.ajax; /** * Created by IntelliJ IDEA. * User: wizzer * Date: 2010-7-15 * Time: 16:08:22 * To change this template use File | Settings | File Templates. */ public class desktopService { public String getInfoCount(String userId,String depId){ return "0|1|2"; } }
4. 配置文件中配置业务类
配置文件为:buffalo-service.properties 位置在classes下
内容如下:
desktopService=oa.ajax.desktopService
多个类则配置多个: 格式 名称=业务类全名
注意:js里则通过 desktopService来代替oa.ajax.desktopService类执行其中的业务方法
到此后台代码结束
下面为前台调用
5. 在jsp中引入js文件:prototype.js 和 buffalo.js 文件
<script type=”text/javascript” src=”js/prototype.js”></script>
<script type=”text/javascript” src=”js/buffalo.js”></script>
6. 编写调用js代码
注意:helloService这个是配置文件中配置的名称
<script type="text/javascript"> var endPoint = "<%=request.getContextPath()%>/buffalo"; var buffalo = new Buffalo(endPoint); var userId= "wizzer"; var deptId = "HITS"; function getEventCount() { try { var buffalo = new Buffalo(endPointTop); buffalo.remoteCall("desktopService.getInfoCount", [userId, deptId], function(reply) { var str = reply.getResult(); var ary = str.split("|"); document.getElementById("msg").innerHTML = "(" + ary[0] + ")"; document.getElementById("mail").innerHTML = "(" + ary[1] + ")"; document.getElementById("wait").innerHTML = "(" + ary[2] + ")"; }); } catch (ex) { } } </script>
<input type=”button” value=”Buffalo远程调用” onclick=”getEventCount();”/>
消息<div id=”msg”></div>
信箱<div id=”mail”></div>
待办<div id=”wait”></div>
Buffalo ajax 最新版下载地址:http://buffalo.sourceforge.net/download.html
本文地址:https://wizzer.cn/archives/232 , 转载请保留.