java WebService CXF Spring 自定义拦截器 附实例源码,看了这篇文章我才真正理解了

本文介绍了如何在Java中使用ApacheCXF创建WebService接口类,包括Ivo接口的定义和Vo类的实现,以及使用DOM4J处理XML结构。还涉及到了SpringCXF中的安全拦截器,用于验证SOAP消息中的用户身份。同时提到了前端开发相关的知识点,如SSR和插件开发。
摘要由CSDN通过智能技术生成

新建一个接口类

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实例”;

}

}

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

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

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

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

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

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

打开全栈工匠技能包-1小时轻松掌握SSR

两小时精通jq+bs插件开发

生产环境下如歌部署Node.js

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

网易内部VUE自定义插件库NPM集成

谁说前端不用懂安全,XSS跨站脚本的危害

webpack的loader到底是什么样的?两小时带你写一个自己loader

9waWM0LnpoaW1nLmNvbS84MC92Mi01NjcyZjU2ZTg1NTcwMDM3ZTg1ZmJlODI0MDA3MDJiYl9oZC5qcGc?x-oss-process=image/format,png)

网易内部VUE自定义插件库NPM集成

谁说前端不用懂安全,XSS跨站脚本的危害

webpack的loader到底是什么样的?两小时带你写一个自己loader

  • 22
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值