jsonrpc环境搭建和简单实例

一、环境准备

  下载需要的jar包和js文件,下载地址:https://yunpan.cn/cxvbm9DhK9tDq  访问密码 6a50

二、新建一个web工程,jsonrpc-1.0.jar复制到lib目录下,jsonrpc.js放到WebContent目录下,如下图所示:

 jsonrpc环境搭建和简单实例_第1张图片

到此,环境已经准备完毕。

简单实例:

一、新建RPC远程调用的类,RPCTest.java,如下图所示:

jsonrpc环境搭建和简单实例_第2张图片

源码如下:

package com.cvicse.ump.rpc;

import java.util.HashMap;
import java.util.Map;

public class RPCTest {
	
	public String TestStringRpc(String rpcString){
		return "rpc字符串:"+rpcString;
	}
	
	public Map TestMapRpc(String schoolName){
		Map map = new HashMap<String, String>();
		map.put("初一","好好学习,努力上初二");
		map.put("初二","好好学习,努力上初三");
		map.put("初三","好好学习,努力上大学");
		
		return map;
	}

}

  代码分析:函数TestStringRpc返回一个字符串;函数TestMapRpc返回一个map。

二、新建jsp,调用远程接口,如下图所示:

jsonrpc环境搭建和简单实例_第3张图片

源码如下:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<jsp:useBean id="JSONRPCBridge" scope="session" class="com.metaparadigm.jsonrpc.JSONRPCBridge" />
<jsp:useBean id="RPCTest" scope="request" class="com.cvicse.ump.rpc.RPCTest" ></jsp:useBean>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>RPC TEST</title>
<script type="text/javascript" src="jsonrpc.js"></script>
<%
JSONRPCBridge.registerObject("RPCTest", RPCTest);
%>
<script type="text/javascript">
    var jsonrpc = new JSONRpcClient("JSON-RPC");
    function callback(result, exception){
        if (exception == null) {
            alert(result);
        } else {
            alert(exception.message);
        }
    }
    function getRPCName(){
        jsonrpc.RPCTest.TestStringRpc(callback,"你好,祖国!");
    }
    function getRPCMap(){
        jsonrpc.RPCTest.TestMapRpc(receive,"实验中学");
    }
    function receive(result, exception){
        if (exception == null) {
            var mid = result.map;
            for(var key in mid){
                alert(key+":"+mid[key]);
            }

        }else {
            alert(exception.message);
        }
    }
</script>
</head>
<body>
<input type="button" value="rpc字符串测试" onclick="getRPCName()">
<input type="button" value="rpcMap测试" onclick="getRPCMap()">
</body>
</html>

源码分析:

生成一个JSONRPCBridge对象:<jsp:useBean id="JSONRPCBridge" scope="session" class="com.metaparadigm.jsonrpc.JSONRPCBridge" />;

生成一个RPCTest对象:<jsp:useBean id="RPCTest" scope="request" class="com.cvicse.ump.rpc.RPCTest" ></jsp:useBean>;

引入jsonrpc.js文件:<script type="text/javascript" src="jsonrpc.js"></script>

把要远程调用的对象注册:JSONRPCBridge.registerObject("RPCTest", RPCTest);

定义远程调用的客户端:var jsonrpc = new JSONRpcClient("JSON-RPC");函数参数"JSON-RPC"调用servlet的url,和后面Web.xml中定义的servlet中url对应;

真正的远程调用:jsonrpc.RPCTest.TestStringRpc(callback,"你好,祖国!");和jsonrpc.RPCTest.TestMapRpc(receive,"实验中学");参数中的callback和receive是两个对应的回调函数。

三、在Web.xml中,配置对应的servlet,如下图所示:

jsonrpc环境搭建和简单实例_第4张图片

 

源码如下:

<?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>
            com.metaparadigm.jsonrpc.JSONRPCServlet
        </servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>JSONRPCServlet</servlet-name>
        <url-pattern>/JSON-RPC</url-pattern>
    </servlet-mapping>
    <welcome-file-list>
        <welcome-file>index.jsp</welcome-file>
    </welcome-file-list>
</web-app>

注意:url-pattern中的/JSON-RPC与jsp中var jsonrpc = new JSONRpcClient("JSON-RPC");中的参数一致。

运行效果:

jsonrpc环境搭建和简单实例_第5张图片

对应工程源码:https://yunpan.cn/cxvzMXyEFS6tf  访问密码 6561

 

你可能感兴趣的:(jsonrpc环境搭建和简单实例)