java WebService CXF Spring 自定义拦截器 附实例源码

新建一个接口类

package com.iflyee.cxf;

import javax.jws.WebService;

@WebService

public interface Ivo {

public boolean vo(String username,int count);

public int getvousernameCount();

public int getvocount();

public String build01();

public String xml();

}

package com.iflyee.cxf;

import java.util.ArrayList;

import javax.jws.WebService;

import org.dom4j.Document;

import org.dom4j.DocumentHelper;

import org.dom4j.Element;

@WebService

public class Vo implements Ivo {

//添加属性

private static int pt;

private static int ut;

public int getvocount() {

// TODO Auto-generated method stub

return pt;

}

public int getvousernameCount() {

// TODO Auto-generated method stub

return ut;

}

public boolean vo(String username, int count) {

ut++;

pt+=count;

return true;

}

public String build01(){

//DocumentHelper提供了创建Document对象的方法

Document document = DocumentHelper.createDocument();

try {

//添加节点信息

Element rootElement = document.addElement(“modules”);

//这里可以继续添加子节点,也可以指定内容

rootElement.setText(“这个是module标签的文本信息”);

Element element = rootElement.addElement(“module”);

for (int i = 0; i < 5; i++) {

Element nameElement = element.addElement(“name”);

Element valueElement = element.addElement(“value”);

Element descriptionElement = element.addElement(“description”);

nameElement.setText(“名称”+i);

nameElement.addAttribute(“language”, “java”+i);//为节点添加属性值

valueElement.setText(“值”+i);

valueElement.addAttribute(“language”, “c#”+i);

descriptionElement.setText(“描述”+i);

descriptionElement.addAttribute(“language”, “sql server”+i);

}

System.out.println(document.asXML()); //将document文档对象直接转换成字符串输出

} catch (Exception e) {

e.printStackTrace();

}

return document.asXML();

}

public String xml(){

StringBuffer str = new StringBuffer();

str.append(“\n”);

APIUtils ap = new APIUtils();

User user = new User();

java.util.List list = new ArrayList();

list.add(1);

list.add(“张胜男”);

list.add(“xs111”);

list.add(2);

list.add(“张胜”);

list.add(“xs222”);

list.add(3);

list.add(“胜男”);

list.add(“xs333”);

for (int i = 0; i < 3; i++) {

str.append(ap.getXMLModel(user,list));

}

System.out.println(str);

str.append(“”);

APIUtils.num=0;

return str.toString();

}

}

package com.iflyee.cxf;

public class User {

private int id;

private String userName;

private String password;

public int getId() {

return id;

}

public void setId(int id) {

this.id = id;

}

public String getUserName() {

return userName;

}

public void setUserName(String userName) {

this.userName = userName;

}

public String getPassword() {

return password;

}

public void setPassword(String password) {

this.password = password;

}

}

package com.lzw.springcxf.auth;

import java.util.List;

import org.apache.cxf.binding.soap.SoapMessage;

import org.apache.cxf.headers.Header;

import org.apache.cxf.interceptor.Fault;

import org.apache.cxf.phase.AbstractPhaseInterceptor;

import org.apache.cxf.phase.Phase;

import org.w3c.dom.Element;

import org.w3c.dom.NodeList;

public class AuthInterceptor extends AbstractPhaseInterceptor{

public AuthInterceptor() {

//拦截器在调用方法之前拦截SOAP消息

super(Phase.PRE_INVOKE);

System.out.println(“11111111111111111111111111111111111”);

}

/**

  • @Description: 拦截器操作

  • @param msg 被拦截到的SOAP消息

  • @throws Fault

*/

@Override

public void handleMessage(SoapMessage msg) throws Fault {

System.out.println(“==============================”);

System.out.println(“=自定义拦截器===”);

//获取SOAP消息的Header

List

headers = msg.getHeaders();

//如果没有Header

if(headers == null || headers.size() < 1) {

throw new Fault(new IllegalArgumentException(“没有Header,拦截器实施拦截”));

}

//获取Header携带是用户和密码信息

Header firstHeader = headers.get(0);

Element ele = (Element) firstHeader.getObject();

NodeList userIdEle = ele.getElementsByTagName(“userId”);

NodeList userPassEle = ele.getElementsByTagName(“userPass”);

if (userIdEle.getLength() != 1) {

throw new Fault(new IllegalArgumentException(“用户Id格式不对”));

}

if (userPassEle.getLength() != 1) {

throw new Fault(new IllegalArgumentException(“用户密码格式不对”));

}

//获取元素的文本内容

String userId = userIdEle.item(0).getTextContent();

String userPass = userPassEle.item(0).getTextContent();

if (!userId.equals(“lyy”) || !userPass.equals(“123456”)) {

throw new Fault(new IllegalArgumentException(“用户和密码不正确”));

}

}

}

package jp.co.service;

public interface TestService {

public String SayHello();

}

package jp.co.service.impl;

import jp.co.service.TestService;

public class TestServiceImpl implements TestService {

@Override

public String SayHello() {

System.out.println(“功能方法被调用!”);

return “Hello 这是一个简单的WebService实例”;

}

}

调用方法

package com.testClient;

import org.apache.cxf.frontend.ClientProxyFactoryBean;

import org.apache.cxf.jaxws.JaxWsProxyFactoryBean;

import jp.co.service.TestService;

public class TestClient {

public static void main(String[] args) {

//创建一个客户端的代理工厂

ClientProxyFactoryBean clientProxy = new ClientProxyFactoryBean() ;

clientProxy.setServiceClass(TestService.class);

clientProxy.setAddress(“http://localhost:8080/WcxF/services/test”);

TestService pic = (TestService)clientProxy.create();

System.out.println(pic.SayHello());

}

}

bean.xml

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns=“http://www.springframework.org/schema/beans”

xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instance”

xmlns:jaxws=“http://cxf.apache.org/jaxws”

xsi:schemaLocation="http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans.xsd

http://cxf.apache.org/jaxws

http://cxf.apache.org/schemas/jaxws.xsd">

<jaxws:endpoint id=“vo” implementor=“com.iflyee.cxf.Vo” address=“/vo”>

jaxws:inInterceptors

</jaxws:inInterceptors>

jaxws:outInterceptors

</jaxws:outInterceptors>

</jaxws:endpoint>

cxf-servlet.xml

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

[外链图片转存中…(img-ccOYsrwk-1715462520480)]

[外链图片转存中…(img-jDu1hi1n-1715462520481)]

[外链图片转存中…(img-72HK1GhV-1715462520481)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值