JSON-RPC-Java 由两个对用户可视化的组件构成,它们是JSONRPCBridge和JSONRPCServlet,二者的协调实现了JSON服务器端对请求对象的处理,并响应给用户。
JSONRPCBridge是一个拥有服务器端导出给特定客户端的对象的引用的session对象,它接收服务器(也就是JSONRPCServlet)传来的JSON-RPC请求,然后其把JSON对象解码(unmarshalling)为Java对象,再扮演方法调用的角色,还要把方法调用返回的Java对象结果组码(marshall)为JSON对象传给客户端处理。而具体的从Java对象到Javascript对象的类型转换由负责串行化的串行化类Serializer处理。
JSONRPCBridge必须放置在HttpSession对象中,并且注册属性名为“JSONRPCBridge”,以使JSONRPCServlet能够定位负责调用导出到客户端的Java对象的桥。为此,为了导出一个对象的所有实例和静态方法到客户端,应该有如下的代码: JSONRPCBridge.registerObject("myObject", myObject);
为了导出一个类的所有的静态方法,应该:JSONRPCBridge.registerClass(("myObject", myObject);
如果registerObject和registerClass被多次调用为有相同键值的对象使用,那么其将被最新赋值的对象所更新。
在JSON中,还可以使用单例模式的globalBridge来为所有的HTTP客户端导出所有的实例方法。其可以用来注册工厂类,但使用时要注意认证与安全问题。使用时如下标识:JSONRPCBridge.getGlobalBridge().registerObject("myObject",myObject); 同上其还可以导出所有的静态方法。
该协议中最重要的一部分还有就是Servlet了,现在就来简单的介绍一下:
在该协议中,JSONRPCServlet充当传送器,处理通过HTTP传输过来的JSON-RPC请求,并把它们分发给注册在HttpSession中的JSONRPCBridge实例处理。而JSONRPCBridge是自动由JSONRPCServlet以属性名"JSONRPCBridge"放入session(会话)中的,要使用JSON-RPC-Java,必须修改web.xml文件如下形式:
当然,对于上面的配置文件,可以根据具体需要作一定的修改。接下来只要写一下客户端jsp代码和js代码,再结合服务器端的Java程序就可以使用该协议了。
一开始代码如下
首先是把JSON-RPC的一个servlet配到web.xml里。
2:写一个后台的JAVA类,这样前台可以调用。
一定要继承JsonRpcObject类和实现序列化。
3:在页面注册
JSONRPCBridge是一个拥有服务器端导出给特定客户端的对象的引用的session对象,它接收服务器(也就是JSONRPCServlet)传来的JSON-RPC请求,然后其把JSON对象解码(unmarshalling)为Java对象,再扮演方法调用的角色,还要把方法调用返回的Java对象结果组码(marshall)为JSON对象传给客户端处理。而具体的从Java对象到Javascript对象的类型转换由负责串行化的串行化类Serializer处理。
JSONRPCBridge必须放置在HttpSession对象中,并且注册属性名为“JSONRPCBridge”,以使JSONRPCServlet能够定位负责调用导出到客户端的Java对象的桥。为此,为了导出一个对象的所有实例和静态方法到客户端,应该有如下的代码: JSONRPCBridge.registerObject("myObject", myObject);
为了导出一个类的所有的静态方法,应该:JSONRPCBridge.registerClass(("myObject", myObject);
如果registerObject和registerClass被多次调用为有相同键值的对象使用,那么其将被最新赋值的对象所更新。
在JSON中,还可以使用单例模式的globalBridge来为所有的HTTP客户端导出所有的实例方法。其可以用来注册工厂类,但使用时要注意认证与安全问题。使用时如下标识:JSONRPCBridge.getGlobalBridge().registerObject("myObject",myObject); 同上其还可以导出所有的静态方法。
该协议中最重要的一部分还有就是Servlet了,现在就来简单的介绍一下:
在该协议中,JSONRPCServlet充当传送器,处理通过HTTP传输过来的JSON-RPC请求,并把它们分发给注册在HttpSession中的JSONRPCBridge实例处理。而JSONRPCBridge是自动由JSONRPCServlet以属性名"JSONRPCBridge"放入session(会话)中的,要使用JSON-RPC-Java,必须修改web.xml文件如下形式:
- <servlet>
- <servlet-name>com.metaparadigm.jsonrpc.JSONRPCServlet</servlet-name>
- <servlet-class>com.metaparadigm.jsonrpc.JSONRPCServlet</servlet-class>
- </servlet>
- <servlet-mapping>
- <servlet-name>com.metaparadigm.jsonrpc.JSONRPCServlet</servlet-name>
- <url-pattern>/JSON-RPC</url-pattern>
- </servlet-mapping>
<servlet>
<servlet-name>com.metaparadigm.jsonrpc.JSONRPCServlet</servlet-name>
<servlet-class>com.metaparadigm.jsonrpc.JSONRPCServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>com.metaparadigm.jsonrpc.JSONRPCServlet</servlet-name>
<url-pattern>/JSON-RPC</url-pattern>
</servlet-mapping>
当然,对于上面的配置文件,可以根据具体需要作一定的修改。接下来只要写一下客户端jsp代码和js代码,再结合服务器端的Java程序就可以使用该协议了。
一开始代码如下
首先是把JSON-RPC的一个servlet配到web.xml里。
- <?xml version="1.0" encoding="UTF-8"?>
- <web-app version="2.4"
- xmlns="http://java.sun.com/xml/ns/j2ee"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
- http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
- <servlet>
- <servlet-name>JSONRPCServlet</servlet-name>
- <servlet-class>
- jcore.jsonrpc.servlet.JSONRPCServlet
- </servlet-class>
- <load-on-startup>2</load-on-startup>
- </servlet>
- <servlet-mapping>
- <servlet-name>JSONRPCServlet</servlet-name>
- <url-pattern>/JRPC</url-pattern>
- </servlet-mapping>
- </web-app>
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<servlet>
<servlet-name>JSONRPCServlet</servlet-name>
<servlet-class>
jcore.jsonrpc.servlet.JSONRPCServlet
</servlet-class>
<load-on-startup>2</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>JSONRPCServlet</servlet-name>
<url-pattern>/JRPC</url-pattern>
</servlet-mapping>
</web-app>
2:写一个后台的JAVA类,这样前台可以调用。
- package com.bean;
- import java.io.Serializable;
- import jcore.jsonrpc.common.JsonRpcObject;
- public class SelectBo extends JsonRpcObject implements Serializable{
- private static final long serialVersionUID = 1L;
- private String name;
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public Integer selectName(String name)
- {
- Integer i = name.length();
- return i;
- }
- }
package com.bean;
import java.io.Serializable;
import jcore.jsonrpc.common.JsonRpcObject;
public class SelectBo extends JsonRpcObject implements Serializable{
private static final long serialVersionUID = 1L;
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer selectName(String name)
{
Integer i = name.length();
return i;
}
}
一定要继承JsonRpcObject类和实现序列化。
3:在页面注册
- <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
- <%
- String path = request.getContextPath();
- String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
- //调用json-rpc进行注册,第二个参数是以后JS中用的。
- jcore.jsonrpc.common.JsonRpcRegister.registerObject(request, "myjsonrpc",com.bean.SelectBo.class);
- %>
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
- <html>
- <head>
- <base href="<%=basePath%>">
- <title>测试JSON-RPC for java</title>
- <meta http-equiv="pragma" content="no-cache">
- <meta http-equiv="cache-control" content="no-cache">
- <meta http-equiv="expires" content="0">
- <script type="text/javascript" src="JsonRpcClient.js"></script>
- <script type="text/javascript">
- //引用一个JS脚本,用他的JsonRpcClient方法获取一个对象(变量名JSON),
- 对象调用刚才注册时候的变量名,这时生成的就是后台的JAVA对象了。
- var json = JsonRpcClient("JRPC"), myjsonrpc = json.myjsonrpc;
- function test()
- {
- myjsonrpc.name = 'wangxiaowei';
- alert(myjsonrpc.name);
- var i = myjsonrpc.selectName(myjsonrpc.name);
- }
- </script>
- </head>
- <body>
- <input type="button" value="测试" onclick="test()"/>
- </body>
- </html>