1, 异常处理

package com.yangw.soap.service;

public class UserException extends Exception {

    public UserException() {
        super();
    }
    public UserException(String message, Throwable cause) {
        super(message, cause);
    }
    public UserException(String message) {
        super(message);
    }
    public UserException(Throwable cause) {
        super(cause);
    }
}

  为login()方法增加抛异常

package com.yangw.soap.service;

import javax.jws.WebParam;
import javax.jws.WebResult;
import javax.jws.WebService;

//说明该接口是服务接口
@WebService
public interface IMyService {
    ......
     @WebResult(name="user")
     public User login(@WebParam(name="username")String username,
             @WebParam(name="password")String password) throws UserException;       ...... 

}
package com.yangw.soap.service;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;

import javax.jws.WebService;

//说明该类是服务接口的实现类
@WebService(endpointInterface="com.yangw.soap.service.IMyService")
public class MyServiceImpl implements IMyService {

......
    @Override
    public User login(String username, String password) throws UserException{
        for(User user:users){
            if(user.getUserName().equals(username)&&user.getPassword().equals(password)){
                return user;
            }
        }
        throw new UserException("用户不存在!");
    }

......

}
    /**
     * soap消息传递--测试异常处理
     */
    @Test
    public void test06() {

        try {
            //1,创建服务
            URL url=new URL(wsdlUrl);
            QName qName=new QName(ns,"MyServiceImplService");
            Service service=Service.create(url, qName);

            //2,创建Dispatch    (创建Port的时候指定名称空间)
            Dispatch<SOAPMessage> dispatch=service.createDispatch(new QName(ns,"MyServiceImplPort"),
                    SOAPMessage.class, Service.Mode.MESSAGE);

            //3, 创建SOAPMessage
             SOAPMessage msg=MessageFactory.newInstance().createMessage();
             SOAPEnvelope envelope=msg.getSOAPPart().getEnvelope();

             SOAPBody body=envelope.getBody();

             //4, 创建QName来指定消息中传递的数据
             QName eName=new QName(ns,"login", "nn"); //前缀必须指定,名字可以任意 <nn:add xmlns="XXX" />
             SOAPBodyElement bEle=body.addBodyElement(eName);        /*         * 因为username=yang password=wei,这个用户是不存在,因此会抛UserException,         * 这个异常会被SOAPFaultException捕获,Webservice会对他处理,因为服务器不会抛异常出来,而是在我们客户端打印我们的异常信息 “用户不存在!”         * webservice会将我们的异常转换为         * <message name="UserException"><part name="fault" element="tns:UserException"/></message>         */
             bEle.addChildElement("username").setValue("yang");
             bEle.addChildElement("password").setValue("wei");
             msg.writeTo(System.out); //输出消息到控制台

             System.out.println("\n invoke ...");
             //5, 通过Dispatch传递消息
             SOAPMessage  resMsg= dispatch.invoke(msg);
             resMsg.writeTo(System.out);
             System.out.println();

        }catch (SOAPFaultException e) {
            System.out.println(e.getMessage());
        }  catch (SOAPException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

控制台打印的信息 如下:

<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/">  <SOAP-ENV:Header/>  <SOAP-ENV:Body>    <nn:login xmlns:nn="http://service.soap.yangw.com/">      <username>yang</username>      <password>wei</password>    </nn:login>   </SOAP-ENV:Body> </SOAP-ENV:Envelope>
 invoke ...
用户不存在!

2,Handler处理SOAP消息

  LogicalHandler: 只能获取SOAPBody的信息,下面简称 LH;

  SOAPHandler:   可以 获取SOAPMessage的信息,下面简称 SH

  客户端,服务器端都可以设置若干个 LH SH !

  例子:客户端设置了 SH1 LH1 SH2 LH2 LH3,服务端设置了SH2 SH3 LH2 LH3 LH1

  那么最终通过的Handler形式是: LH1 LH2 LH3 SH1 SH2   SH2 SH3 LH2 LH3 LH1

  

  需要使用wsimport命令将代码导入到新的工程中!!!

  创建SOAPHandler的顺序:

  1> 创建一个类实现SOAPHandler接口

  2>在handlerMessage()方法中编写相应的处理代码 

package com.yangw.soap.service.handler;

import java.util.Set;
import javax.xml.namespace.QName;
import javax.xml.ws.handler.MessageContext;
import javax.xml.ws.handler.soap.SOAPHandler;
import javax.xml.ws.handler.soap.SOAPMessageContext;
/**
 * 这里写了一个HeaderHandler类,实现了接口SOAPHandler,需要设置泛型为SOAPMessageContext
 * @author yangw
 */
public class HeaderHandler implements SOAPHandler<SOAPMessageContext> {

    @Override
    public boolean handleMessage(SOAPMessageContext context) {
        System.out.println("handler message");
        return true;
    }
    @Override
    public boolean handleFault(SOAPMessageContext context) {
        System.out.println("fault");
        return false;
    }
    @Override
    public void close(MessageContext context) {

    }
    @Override
    public Set<QName> getHeaders() {
        return null;
    }
}

  3>配置handler,配置文件名字可以随便起,放到类路径下即可

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<javaee:handler-chains
     xmlns:javaee="http://java.sun.com/xml/ns/javaee"
     xmlns:xsd="http://www.w3.org/2001/XMLSchema">
  <javaee:handler-chain>
    <javaee:handler>
      <javaee:handler-class>com.yangw.soap.service.handler.HeaderHandler</javaee:handler-class>
    </javaee:handler>
  </javaee:handler-chain>
</javaee:handler-chains>

 

handler-chain.xml 文件放置在类路径下即可.

 3>在服务上开启过滤器链 @HandlerChain(file="handler-chain.xml")

package com.yangw.soap.service;

import javax.jws.HandlerChain;
import javax.xml.ws.Service;
import javax.xml.ws.WebServiceClient;

@WebServiceClient(name = "MyServiceImplService", targetNamespace = "http://service.soap.yangw.com/", wsdlLocation = "http://localhost:8899/ns?wsdl")
@HandlerChain(file="handler-chain.xml")
public class MyServiceImplService extends Service {
  ......
}

  4>测试类

 

package com.yangw.soap.service;

public class Test {

    public static void main(String[] args) {
        MyServiceImplService mis=new MyServiceImplService();
        IMyService service=mis.getMyServiceImplPort();
        try {
            /**
             * 因为后端没有yangw wei 这个用户,因此控制台打印如下:
             *  handler message
             *    fault
             *  用户不存在!
             */
            service.login("yangw", "123456");
            System.out.println("over");
            /**
             * 存在用户 yangw  123456,打印如下:
             *  handler message
             *    handler message
             *  over
             */

        } catch (UserException_Exception e) {
            System.out.println(e.getMessage());
        }

    }
}

webservice06#异常#Handler的更多相关文章

  1. 获取内核当前执行模块和当前发生异常地址和线程异常Handler调用步骤

    循环每个内核模块 统计模块大小 判断触发异常的地址属于那个模块.来确定模块 获取发生异常地址 nt!_EXCEPTION_RECORD +0x000 ExceptionCode : -21391605 ...

  2. springboot接口返回封装与异常控制

    首先,返回有两个状态,status和code status标识response的状态,有2个值:0成功,-1服务错误. code跟业务有关,可以有各种数值,99999服务未知异常,10000参数异常, ...

  3. 异常 Exception 知识点总结 MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  4. Atitit.异常机制的设计原理

    Atitit.异常机制的设计原理 缺陷 关键是只要知晓有一个异常表的存在,try 的范围就是体现在异常表行记录的起点和终点.JVM 在 try 住的代码区间内如有异常抛出的话,就会在当前栈桢的异常表中 ...

  5. 初识exception

    一.exception的分类 根据此exception(异常)是否可以打断正在执行的指令,可以将exception分为 asynchronous exception 和 synchronous exc ...

  6. 进入OS前的两步之PendSV(任务切换)

    先了解下如何使用PendSV异常.(为何要使用PendSV而不是其他的异常,请参考<cortex-M3权威指南>) 1,如何设定PendSV优先级? NVIC_SYSPRI14 EQU 0 ...

  7. android网络图片查看器

    package com.itheima.netimageviewer; import java.io.BufferedReader; import java.io.File; import java. ...

  8. Cortex-M3寄存器等基础知识

    1.寄存器 CM3拥有R0~R15通用寄存器和一些特殊功能寄存器 R0~R12这些通用寄存器,复位初始值都是不可预料的 2.CM3有R0到R15的通用寄存器组 注:绝大部分的16位thumb只能访问R ...

  9. dubbo源码—Service Reply

    dubbo通过netty将请求发送到provider的时候,provider之前已经启动好的NettyServer监听指定端口的时候会收到来自consumer的请求,将通过网络发送来的二进制编码成Re ...

随机推荐

  1. SpringMVC中文件的上传(上传到服务器)和下载问题(一)

    一.今天我们所说的是基于SpringMVC的关于文件的上传和下载的问题的解决.(这里所说的上传和下载都是上传到服务器与从服务器上下载文件).这里的文件包括我们常用的各种文件.如:文本文件(.txt), ...

  2. oracle多表连接查询竟然还有这种操作

    仔细观察上面几个图,比较下 oracle数据库中的+操作符竟然可以替换left join 和right join sql server暂时没用到过

  3. 【学习笔记】深入理解超时调用(setTimeout)和间歇调用(setInterval)

    超时调用(setTimeout):在指定的毫秒数后调用函数或计算表达式. setTimeout(func, 1000); // func执行的函数,1000毫秒 间歇调用(setInterval):按 ...

  4. Fedora删除旧版本内核

    由于Fedora升级非常快,因此非常有必要清除陈旧的内核,否则的话,每次登录系统会出现多个引导项,看着烦人也占用内存: 1.查看当前使用的内核 [root@w ~]# uname -r 4.9.14- ...

  5. APUE 2 - 进程组(process group) 会话(session) job

    进程组(process group) 进程组顾名思义是指一个或多个进程的集合.他们通常与同一个job(可以从同一个终端接收信号)相关联.每个进程组拥有一个唯一的Process Group Id.可以使 ...

  6. 关于 DropDownList 循环绑定中遇到的问题

    1绑定DataTable 简单直接下部分就ok了 this.DropDownList1.DataSource = DataTable; this.DropDownList1.DataTextField ...

  7. 线性代数-矩阵-【2】矩阵生成 C和C++实现

    矩阵的知识点之多足以写成一本线性代数. 所以我们把矩阵的运算封装成矩阵类.以C++为主进行详解. 点击这里可以跳转至 [1]矩阵汇总:http://www.cnblogs.com/HongYi-Lia ...

  8. 安装Hadoop 2.7.3的过程中遇到的一些问题及解决方法。

    1. 启动hadoop 时发现namenode 没有启动起来 出现以下错误: Incorrect configuration: namenode address dfs.namenode.servic ...

  9. 7-zip 解压

    7-zip 解压 1.引入依赖文件 sevenzipjbinding.jar sevenzipjbinding-Allwindows.jar <!-- https://mvnrepository ...

  10. Java异常的性能分析

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt276 在Java中抛异常的性能是非常差的.通常来说,抛一个异常大概会消耗10 ...