用Axis构建java WEB Service

 一、Axis安装 1、环境 jdk1.5,Tomcat 5.0
  
  2、到 http://ws.apache.org/Axis/网站下载Axis安装包
  
  3、解压缩安装包,将Axis_UNZIP_PATH\Axis-version\webapps下的Axis包拷贝到TOMCAT_HOME\webapps\下,以下约定Axis_HOME为该TOMCAT_HOME\webapps\Axis目录
  
  4、启动tomcat,访问http://localhost:8080/Axis 检查安装是否成功
  
  5、以上步骤执行成功,可以开发webservice例子了

Axis支持三种web service的部署和开发,分别为:1、Dynamic Invocation Interface ( DII) 2、Stubs方式 3、Dynamic Proxy方式
下面分别举例说明:

二、编写DII(Dynamic Invocation Interface )方式web服务
  
  1.编写服务端程序HelloClient
  
  public class HelloClient
  {
  public String getName(String name)
  {
  return "hello "+name;
  }
  }
  
  2、将源码拷贝到Axis_HOME下,重命名为 HelloClient.jws
  
  3、访问连接http://localhost:8080/Axis/HelloClient.jws?wsdl,页面显示Axis自动生成的wsdl
  
  4、编写访问服务的客户端 TestHelloClient.java
  
  import org.apache.Axis.client.Call;
  import org.apache.Axis.client.Service;
  import javax.xml.namespace.QName;
  import javax.xml.rpc.ServiceException;
  import java.net.MalformedURLException;
  import java.rmi.RemoteException;
  
  public class SayHelloClient2
  {
  public static void main(String[] args)
  {
  try
  {
  String endpoint =
  "http://localhost:8080/Axis/HelloClient.jws";
  
  Service service = new Service();
  Call call = null;
  
  call = (Call) service.createCall();
  
  call.setOperationName(new QName(
  "http://localhost:8080/Axis/HelloClient.jws",
  "getName"));
  call.setTargetEndpointAddress
  (new java.net.URL(endpoint));
  
  String ret = (String) call.invoke(new Object[]
  {"zhangsan"});
  System.out.println("return value is " + ret);
  }
  catch (Exception ex)
  {
  ex.printStackTrace();
  }
  }
  }
  
  三、编写Dynamic Proxy方式访问服务
  
  1、编写部署服务端程序,同上边DII方式,本次仍使用上边部署的HelloClient
  
  2、编写代理接口
  
  public interface HelloClientInterface
  extends java.rmi.Remote
  {
  public String getName(String name)
  throws java.rmi.RemoteException;
  }
  
  3、编写并执行客户端程序TestHelloClient.java
  
  import javax.xml.rpc.Service;
  import javax.xml.rpc.ServiceFactory;
  import java.net.URL;
  import javax.xml.namespace.QName;
  
  public class TestHelloClient
  {
  public static void main(String[] args)
  {
  try
  {
  String wsdlUrl =
  "http://localhost:8080/Axis/HelloClient.jws?wsdl";
  String nameSpaceUri =
  "http://localhost:8080/Axis/HelloClient.jws";
  String serviceName = "HelloClientService";
  String portName = "HelloClient";
  
  ServiceFactory serviceFactory =
  ServiceFactory.newInstance();
  Service afService =
  serviceFactory.createService(new URL(wsdlUrl),
  new QName(nameSpaceUri, serviceName));
  HelloClientInterface proxy = (HelloClientInterface)
  afService.getPort(new QName(
  nameSpaceUri, portName),
  HelloClientInterface.class);
  System.out.println
  ("return value is "+proxy.getName("john") ) ;
  }catch(Exception ex)
  {
  ex.printStackTrace() ;
  }
  }
  }
  
  四、编写wsdd发布web服务,编写stub client访问web服务
  
  1、编写服务端程序server,SayHello.java,编译server.SayHello.java
  package server;
  public class SayHello
  {
  public String getName(String name)
  {
  return "hello "+name;
  }
  }
  
  2.编写LogHandler.java
  import org.apache.Axis.AxisFault;
  import org.apache.Axis.Handler;
  import org.apache.Axis.MessageContext;
  import org.apache.Axis.handlers.BasicHandler;
  
  import java.util.Date;
  
  public class LogHandler
  extends BasicHandler
  {
  public void invoke
  (MessageContext msgContext)
  throws AxisFault
  {
  /** Log an access each time
  we get invoked.
  */
  try {
  Handler serviceHandler
  = msgContext.getService();
  
  Integer numAccesses =
  (Integer)serviceHandler.getOption("accesses");
  if (numAccesses == null)
  numAccesses = new Integer(0);
  numAccesses = new Integer
  (numAccesses.intValue() + 1);
  Date date = new Date();
  String result =
  date + ": service " +
  msgContext.getTargetService() +
  " accessed " + numAccesses + " time(s).";
  serviceHandler.setOption
  ("accesses", numAccesses);
  System.out.println(result);
  } catch (Exception e)
  {
  throw AxisFault.makeFault(e);
  }
  }
  }
  
  3、编写wsdd文件
  
  deploy.wsdd
  <deployment xmlns=
  "http://xml.apache.org/Axis/wsdd/"
  xmlns:java=
  "http://xml.apache.org/Axis/wsdd/providers/java">
  <handler name="print" type="java:LogHandler"/>
  <service name="sayhello"
  provider="java:RPC">
  <requestFlow>
  <handler type="print"/>
  </requestFlow>
  <parameter name="className"
  value="server.SayHello"/>
  <parameter name="allowedMethods"
  value="*"/>
  </service>
  </deployment>
  
  3、将编译后的文件拷贝到Axis_HOME/WEB-INF/classes下,如:D:\tomcat\webapps\Axis\WEB-INF\classes
  
  4、发布服务:
  
  java org.apache.Axis.client.AdminClient deploy.wsdd
  
  5、生成client stub文件
  
  a:方式1
  
  将SayHello.java拷贝到Axis_HOME/下,重命名为SayHello.jws,
  
  执行下面的命令生存client stub
  
  java org.apache.Axis.wsdl.WSDL2Java
  -p client http://localhost:8080
  /Axis/services/SayHello.jws?wsdl
  
  b:方式2
  
  执行如下命令生成SayHello.wsdl
  
  java org.apache.Axis.wsdl.Java2WSDL
  -oSayHello.wsdl -lhttp://localhost:8080
  /Axis/services/SayHello -nsayhello server.SayHello
  
  执行如下命令生成client stub
  
  java org.apache.Axis.wsdl.WSDL2Java
  SayHello.wsdl -p client
  
  生成的stub client文件列表为:
  
  1.SayHello.java
  
  2.SayHelloService.java。
  
  3.SayHelloServiceLocator.java
  
  4.SayHelloSoapBindingStub.java
  
  6、编写客户端程序,编译并执行
  
  public class SayHelloClient
  {
  public static void main(String[] args)
  {
  try
  {
  SayHelloService service = new client.
  SayHelloServiceLocator();
  client.SayHello_PortType
  client = service.getSayHello();
  String retValue=client.getName("zhangsan");
  System.out.println(retValue);
  }
  catch (Exception e)
  {
  System.err.println
  ("Execution failed. Exception: " + e);
  }
  }
  }
  
  您也可以写server-config.wsdd
  <?xml version="1.0" encoding="UTF-8"?>
  <deployment xmlns="http://xml.apache.org/axis/wsdd/"
  xmlns:java="http://xml.apache.org/axis/wsdd/providers/java">
  <globalConfiguration>
  
  <parameter name="adminPassword" value="admin"/>
  <parameter name="attachments.implementation"
  value="org.apache.axis.attachments.AttachmentsImpl"/>
  <parameter name="sendXsiTypes" value="true"/>
  <parameter name="sendMultiRefs" value="true"/>
  <parameter name="sendXMLDeclaration" value="true"/>
  <parameter name="axis.sendMinimizedElements" value="true"/>
  
  <requestFlow>
  <handler type="java:org.apache.axis.handlers.JWSHandler">
  <parameter name="scope" value="session"/>
  </handler>
  
  <handler type="java:org.apache.axis.handlers.JWSHandler">
  <parameter name="scope" value="request"/>
  <parameter name="extension" value=".jwr"/>
  </handler>
  
  </requestFlow>
  
  </globalConfiguration>
  <handler name="LocalResponder" type="java:org.apache.axis.transport.local.LocalResponder"/>
  <handler name="URLMapper" type="java:org.apache.axis.handlers.http.URLMapper"/>
  <handler name="Authenticate" type="java:org.apache.axis.handlers.SimpleAuthenticationHandler"/>
  <handler name="print" type="java:stub.LogHandler"/>
  
  <service name="sayhello" provider="java:RPC">
  <requestFlow>
  <handler type="print"/>
  </requestFlow>
  <parameter name="className"  value="stub.server.SayHello"/>
  <parameter name="allowedMethods" value="*"/>
  </service>
  
  <transport name="http">
  <requestFlow>
  <handler type="URLMapper"/>
  <handler type="java:org.apache.axis.handlers.http.HTTPAuthHandler"/>
  </requestFlow>
  </transport>
  <transport name="local">
  <responseFlow>
  <handler type="LocalResponder"/>
  </responseFlow>
  </transport>
  </deployment>
python+opencv简谱识别音频生成系统源码含GUI界面+详细运行教程+数据 一、项目简介 提取简谱中的音乐信息,依据识别到的信息生成midi文件。 Extract music information from musical scores and generate a midi file according to it. 二、项目运行环境 python=3.11.1 第三方库依赖 opencv-python=4.7.0.68 numpy=1.24.1 可以使用命令 pip install -r requirements.txt 来安装所需的第三方库。 三、项目运行步骤 3.1 命令行运行 运行main.py。 输入简谱路径:支持图片或文件夹,相对路径或绝对路径都可以。 输入简谱主音:它通常在第一页的左上角“1=”之后。 输入简谱速度:即每分钟拍数,同在左上角。 选择是否输出程序中间提示信息:请输入Y或N(不区分大小写,下同)。 选择匹配精度:请输入L或M或H,对应低/中/高精度,一般而言输入L即可。 选择使用的线程数:一般与CPU核数相同即可。虽然python的线程不是真正的多线程,但仍能起到加速作用。 估算字符上下间距:这与简谱中符号的密集程度有关,一般来说纵向符号越稀疏,这个值需要设置得越大,范围通常在1.0-2.5。 二值化算法:使用全局阈值则跳过该选项即可,或者也可输入OTSU、采用大津二值化算法。 设置全局阈值:如果上面选择全局阈值则需要手动设置全局阈值,对于.\test.txt中所提样例,使用全局阈值并在后面设置为160即可。 手动调整中间结果:若输入Y/y,则在识别简谱后会暂停代码,并生成一份txt文件,在其中展示识别结果,此时用户可以通过修改这份txt文件来更正识别结果。 如果选择文件夹的话,还可以选择所选文件夹中不需要识别的文件以排除干扰
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值