gpt4 book ai didi

java - header 中包含用户名和密码的 SOAP 客户端请求

转载 作者:行者123 更新时间:2023-11-30 06:10:58 30 4
gpt4 key购买 nike

我有以下用于发出 SOAP 请求的 Java 客户端:

package com.example.petstore.test;

import java.util.GregorianCalendar;

import javax.xml.datatype.DatatypeConfigurationException;
import javax.xml.datatype.DatatypeFactory;
import javax.xml.datatype.XMLGregorianCalendar;

import org.apache.cxf.jaxws.JaxWsProxyFactoryBean;

import com.example.petstore.schema.ProcessUpdateResponse;
import com.example.petstore.schema.SyncProcessDAO;

public class TestUtility {

public static void main(String[] args) {

JaxWsProxyFactoryBean factory = new JaxWsProxyFactoryBean();

// Use the URL defined in the soap address portion of the WSDL
factory.setAddress("http://192.168.1.4:8080/MySyncService/services/SyncProcessDAOPort");

// Utilize the class which was auto-generated by Apache CXF wsdl2java
factory.setServiceClass(SyncProcessDAO.class);

Object client = factory.create();

try {

// Call the Web Service to perform an operation
GregorianCalendar gregory = new GregorianCalendar();
XMLGregorianCalendar xmlgregory = DatatypeFactory.newInstance()
.newXMLGregorianCalendar(gregory);
ProcessUpdateResponse response = ((SyncProcessDAO)client).gatherFunctionAttributes("hello1", "hello2", "hello3", 1, 2, xmlgregory, xmlgregory, "hello4", "hello5");
System.out.println("hahahaha");
System.out.println(response);

} catch (SecurityException e) {

e.printStackTrace();

} catch (IllegalArgumentException e) {

e.printStackTrace();

} catch (DatatypeConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}

我需要修改它以将用户名和密码作为 WS 安全 header 的一部分包含在内。我该怎么做?

如果它有用,我还附上了我的 WSDL 文件:

    <?xml version="1.0" encoding="UTF-8"?>
<wsdl:definitions name="SyncProcessDAOService" targetNamespace="http://example.com/" xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/" xmlns:tns="http://example.com/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/">
<wsdl:types>
<schema xmlns="http://www.w3.org/2001/XMLSchema">
<import namespace="http://example.com/" schemaLocation="my_schema1.xsd"/>
</schema>
</wsdl:types>
<wsdl:message name="gatherFunctionAttributesResponse">
<wsdl:part name="parameters" element="tns:gatherFunctionAttributesResponse">
</wsdl:part>
</wsdl:message>
<wsdl:message name="gatherFunctionAttributes">
<wsdl:part name="parameters" element="tns:gatherFunctionAttributes">
</wsdl:part>
</wsdl:message>
<wsdl:portType name="SyncProcessDAO">
<wsdl:operation name="gatherFunctionAttributes">
<wsdl:input name="gatherFunctionAttributes" message="tns:gatherFunctionAttributes">
</wsdl:input>
<wsdl:output name="gatherFunctionAttributesResponse" message="tns:gatherFunctionAttributesResponse">
</wsdl:output>
</wsdl:operation>
</wsdl:portType>
<wsdl:binding name="SyncProcessDAOServiceSoapBinding" type="tns:SyncProcessDAO">
<soap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http"/>
<wsdl:operation name="gatherFunctionAttributes">
<soap:operation soapAction="" style="document"/>
<wsdl:input name="gatherFunctionAttributes">
<soap:body use="literal"/>
</wsdl:input>
<wsdl:output name="gatherFunctionAttributesResponse">
<soap:body use="literal"/>
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:service name="SyncProcessDAOService">
<wsdl:port name="SyncProcessDAOPort" binding="tns:SyncProcessDAOServiceSoapBinding">
<soap:address location="http://localhost:8080/MySyncService/services/SyncProcessDAOPort"/>
</wsdl:port>
</wsdl:service>
</wsdl:definitions>

最佳答案

在客户端,您需要编写以下代码以将 use/pwd 作为

SyncProcessDAO client = (SyncProcessDAO)factory.create();
Map<String, Object> requestContext = ((BindingProvider)client).getRequestContext();
Map<String, List<String>> requestHeaders = new HashMap<String, List<String>>();
requestHeaders.put("username", "user");
requestHeaders.put("Password", "pwd");
requestContext.put(MessageContext.HTTP_REQUEST_HEADERS, requestHeaders);

发送到服务器前请加密密码

有关服务器端更改的更多详细信息,请点击以下链接

http://examples.javacodegeeks.com/enterprise-java/jws/application-authentication-with-jax-ws/

如果您想实现 jax WS-Security,请点击此链接

http://cxf.apache.org/docs/ws-security.html

关于java - header 中包含用户名和密码的 SOAP 客户端请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34921812/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com