2016-09-25 5 views
1

Недавно я получил требование от одного из наших клиентов. Они предоставили WSDL для вызова своего сервиса. Они выполняют IP-переключение для аутентификации. Я дал IP-адрес своего сервера, и он получил белый список. Во-первых, я тестировал эту услугу с помощью инструмента SOAP UI, и он работал без каких-либо проблем. Затем я интегрировал код JAVA, и он потерпел неудачу. Я получаю исключение, какПолучение ошибки 401 Несанкционированное использование запроса на мыло

Unable to sendViaPost to url[ https://apps.greystar.com/gsWebService/gsExtract.asmx] org.apache.axis2.AxisFault: Transport error: 401 Error: Unauthorized at org.apache.axis2.transport.http.impl.httpclient3.HTTPSenderImpl.handleResponse(HTTPSenderImpl.java:343) ~[axis2-transport-http-1.7.1.jar:1.7.1] at org.apache.axis2.transport.http.impl.httpclient3.HTTPSenderImpl.sendViaPost(HTTPSenderImpl.java:213) ~[axis2-transport-http-1.7.1.jar:1.7.1] at org.apache.axis2.transport.http.HTTPSender.send(HTTPSender.java:121) [axis2-transport-http-1.7.1.jar:1.7.1] at org.apache.axis2.transport.http.CommonsHTTPTransportSender.writeMessageWithCommons(CommonsHTTPTransportSender.java:403) [axis2-transport-http-1.7.1.jar:1.7.1] at org.apache.axis2.transport.http.CommonsHTTPTransportSender.invoke(CommonsHTTPTransportSender.java:234) [axis2-transport-http-1.7.1.jar:1.7.1] at org.apache.axis2.engine.AxisEngine.send(AxisEngine.java:431) [axis2-kernel-1.7.1.jar:1.7.1] at org.apache.axis2.description.OutInAxisOperationClient.send(OutInAxisOperation.java:399) [axis2-kernel-1.7.1.jar:1.7.1] at org.apache.axis2.description.OutInAxisOperationClient.executeImpl(OutInAxisOperation.java:225) [axis2-kernel-1.7.1.jar:1.7.1] at org.apache.axis2.client.OperationClient.execute(OperationClient.java:150) [axis2-kernel-1.7.1.jar:1.7.1] at com.reputation.r4e.integrator.greystar.ExtractDataStub.greystarExtract(ExtractDataStub.java:300) [classes/:na] at com.reputation.r4e.integrator.recordreader.GreystarLocationImportRecordReader.getGreystarExtractResponse(GreystarLocationImportRecordReader.java:198) [classes/:na] at com.reputation.r4e.integrator.recordreader.GreystarLocationImportRecordReader.process(GreystarLocationImportRecordReader.java:97) [classes/:na] at com.reputation.r4e.integrator.impl.DefaultPipeline.flow(DefaultPipeline.java:33) [classes/:na] at com.reputation.r4e.integrator.impl.DefaultPipeline.process(DefaultPipeline.java:52) [classes/:na] at com.reputation.r4e.integrator.importer.NullImporter.process(NullImporter.java:38) [classes/:na] at com.reputation.r4e.integrator.impl.DefaultPipeline.flow(DefaultPipeline.java:33) [classes/:na] at com.reputation.r4e.integrator.impl.DefaultPipeline.process(DefaultPipeline.java:52) [classes/:na] at com.reputation.r4e.integrator.IntegrationRunner$IntegrationRunnable.run(IntegrationRunner.java:87) [classes/:na] at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) [na:1.8.0_45] at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) [na:1.8.0_45] at java.lang.Thread.run(Thread.java:745) [na:1.8.0_45]

Говорят, 401 несанкционированная ошибка. Как это работает через интерфейс SOAP и почему он не работает через JAVA-клиент.?

Я отслеживаю трафик http через TCPMon, и кроме заголовков все такие же. Поэтому я добавил заголовки, полученные из инструмента SOAP UI, моему клиенту JAVA, но все равно не повезло. Я получаю такую ​​же несанкционированную ошибку 401.

Вот мыльный запрос как интерфейса SOAP, так и клиента JAVA.

SOAP запрос UI:

POST https://apps.greystar.com/gsWebService/gsExtract.asmx HTTP/1.1 
Accept-Encoding: gzip,deflate 
Content-Type: application/soap+xml;charset=UTF-8;action="https://apps.greystar.com/greystarExtract" 
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.116 Safari/537.36 
Content-Length: 692 
Host: apps.greystar.com 
Connection: Keep-Alive 

<soap:Envelope xmlns:soap="http://www.w3.org/2003/05/soap-envelope" xmlns:apps="https://apps.greystar.com/"> 
    <soap:Header/> 
    <soap:Body> 
    <apps:greystarExtract> 
     <apps:axmlVendorCode>VENDOR_CODE</apps:axmlVendorCode> 
     <apps:axmlToken>PASSWORD</apps:axmlToken> 
     <apps:axmlExtractType>PROPERTY_LIST</apps:axmlExtractType> 
     <apps:axmlFormat>XML</apps:axmlFormat> 
     <apps:axmlParameters></apps:axmlParameters> 
    </apps:greystarExtract> 
    </soap:Body> 
</soap:Envelope> 

JAVA КЛИЕНТ Запрос:

POST /gsWebService/gsExtract.asmx HTTP/1.1 
Content-Type: application/soap+xml; charset=UTF-8; action="https://apps.greystar.com/greystarExtract 
Accept-Encoding: gzip,deflate 
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.116 Safari/537.36[\r][\n] 
Connection: Keep-Alive 
Host: apps.greystar.com 
Transfer-Encoding: chunked 

<?xml version='1.0' encoding='UTF-8'?> 
<soapenv:Envelope xmlns:soapenv="http://www.w3.org/2003/05/soap-envelope"> 
    <soapenv:Header /> 
    <soapenv:Body> 
     <ns1:greystarExtract xmlns:ns1="https://apps.greystar.com/"> 
      <ns1:axmlVendorCode>VENDOR_CODE</ns1:axmlVendorCode> 
      <ns1:axmlToken>PASSWORD</ns1:axmlToken> 
      <ns1:axmlExtractType>PROPERTY_LIST</ns1:axmlExtractType> 
      <ns1:axmlFormat>JSON</ns1:axmlFormat> 
      <ns1:axmlParameters></ns1:axmlParameters> 
     </ns1:greystarExtract> 
    </soapenv:Body> 
</soapenv:Envelope> 

Примечание: Я добавил заголовки клиента JAVA, глядя на заголовки SOAP UI. Фактические заголовки JAVA клиента ниже

POST /gsWebService/gsExtract.asmx HTTP/1.1 
Content-Type: application/soap+xml; charset=UTF-8;    
action="https://apps.greystar.com/greystarExtract 
User-Agent: Axis2 
Host: apps.greystar.com 
Transfer-Encoding: chunked 

Что может быть причиной этого неудачу через JAVA клиента.? Может ли кто-нибудь ответить на мой вопрос, потому что я застрял здесь.

Спасибо заранее, Amar.T

+0

ли сертификаты на сервере назначения действует? – BlackFlag

+0

Я просто использую эту услугу. Я не знаю о серверном коде. Если сертификат недействителен, как это получило работу через интерфейс SOAP.? – Amar

+0

Ну, в последний раз, когда я пытался реализовать мыло в андроиде, я задерживался, когда сертификат сервера был недействительным и поэтому не доверял. Таким образом, структура решила прекратить общение. Что произойдет, если вы попытаетесь открыть wsdl в своем браузере? Вы видите действительный сертификат? – BlackFlag

ответ

0

Я пробовал другие библиотеки третьей партии и ее работу, как и ожидалось. Я попробовал CXF и SOAP UI JAVA API и его работу как ожидалось. Я не знаю, почему он не работает с APACHE AXIS2.

Если кто-нибудь найдет ответ, почему его не работает с AXIS2, пожалуйста, отправьте ответ.

Благодаря & С уважением, Amar.T

Смежные вопросы