新建一个接口类
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
//如果没有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前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
打开全栈工匠技能包-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