Ошибка подключения к веб-сервису отдыха с ближайшего прокси-сервера
У меня проблема с подключением к моему веб-сервису из-за прокси-сервера. У меня есть следующий вызов ajax
$.ajax({
async: false,
url: "http://localhost:8080/Card/rest/UploadBackground"
}).done(function ( data ) {
arr = JSON.parse(data);
updateSlider(arr);
}).fail(function ( data ) {
alert('falied');
});
который вызывает следующую услугу
@GET
@Produces(MediaType.TEXT_PLAIN)
public Response getBackgroundImages(@QueryParam("missions") String missions,
@QueryParam("objects") String objects,
@QueryParam("dates") String date) {
String result= "";
......
try {
.....
result = dbman.extractQueriedData(queryMissions, queryObjects, date);
} else {
result = dbman.extractPopular();
}
} catch(SQLException ex){
LoggingServices.createExceptionLogMessage(ex, LOGGER);
}
return Response.ok()
.entity(result)
.header("Access-Control-Allow-Origin", "*")
.header("Access-Control-Allow-Methods", "GET, POST, DELETE, PUT")
.allow("OPTIONS").build();
}
Код работает, когда я запускаю все на локальном сервере. Но когда я загружаю его на сервер, который находится за прокси-сервером, я получаю сообщение об ошибке, которое, согласно странице chrome net-internals, выглядит так:
245: URL_REQUEST
http://localhost:8080/Card/rest/UploadBackground
Start Time: 2017-03-23 16:23:19.477
t=12380 [st= 0] +REQUEST_ALIVE [dt=1305]
--> priority = "HIGHEST"
--> url = "http://localhost:8080/Card/rest/UploadBackground"
t=12380 [st= 0] URL_REQUEST_DELEGATE [dt=0]
t=12380 [st= 0] +URL_REQUEST_START_JOB [dt=1305]
--> load_flags = 51008 (DO_NOT_SAVE_COOKIES | DO_NOT_SEND_AUTH_DATA | DO_NOT_SEND_COOKIES | IGNORE_LIMITS | MAYBE_USER_GESTURE | VERIFY_EV_CERT)
--> method = "GET"
--> url = "http://localhost:8080/Card/rest/UploadBackground"
t=12380 [st= 0] URL_REQUEST_DELEGATE [dt=0]
t=12380 [st= 0] HTTP_CACHE_GET_BACKEND [dt=0]
t=12380 [st= 0] HTTP_CACHE_OPEN_ENTRY [dt=0]
t=12380 [st= 0] HTTP_CACHE_ADD_TO_ENTRY [dt=0]
t=12380 [st= 0] HTTP_CACHE_READ_INFO [dt=0]
t=12380 [st= 0] +HTTP_STREAM_REQUEST [dt=303]
t=12380 [st= 0] HTTP_STREAM_REQUEST_STARTED_JOB
--> source_dependency = 248 (HTTP_STREAM_JOB)
t=12683 [st= 303] HTTP_STREAM_REQUEST_BOUND_TO_JOB
--> source_dependency = 248 (HTTP_STREAM_JOB)
t=12683 [st= 303] -HTTP_STREAM_REQUEST
t=12683 [st= 303] +HTTP_TRANSACTION_SEND_REQUEST [dt=0]
t=12683 [st= 303] HTTP_TRANSACTION_SEND_REQUEST_HEADERS
--> GET /Card/rest/UploadBackground HTTP/1.1
Host: localhost:8080
Connection: keep-alive
Accept: */*
Origin: http://mycard.xxx.yyy
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/57.0.2987.98 Safari/537.36
Referer: http://mycard.xxx.yyy/mainPage.html
Accept-Encoding: gzip, deflate, sdch, br
Accept-Language: en-US,en;q=0.8
t=12683 [st= 303] -HTTP_TRANSACTION_SEND_REQUEST
t=12683 [st= 303] +HTTP_TRANSACTION_READ_HEADERS [dt=1002]
t=12683 [st= 303] HTTP_STREAM_PARSER_READ_HEADERS [dt=1002]
--> net_error = -324 (ERR_EMPTY_RESPONSE)
t=13685 [st=1305] -HTTP_TRANSACTION_READ_HEADERS
--> net_error = -324 (ERR_EMPTY_RESPONSE)
t=13685 [st=1305] -URL_REQUEST_START_JOB
--> net_error = -324 (ERR_EMPTY_RESPONSE)
t=13685 [st=1305] URL_REQUEST_DELEGATE [dt=0]
t=13685 [st=1305] -REQUEST_ALIVE
--> net_error = -324 (ERR_EMPTY_RESPONSE)
Может кто-нибудь объяснить, в чем ошибка? это как-то связано с прокси-сервером?
веселит,
эс
РЕШЕНИЕ
После более чем 4-х дней я наконец заработал. Проблема была просто в междоменной проблеме, и я решил использовать jsonp и правильный URL-адрес. На стороне сервера я изменил MediaType на MediaType.APPLICATION_JSON, и возвращаемое значение было обернуто вокруг имени функции обратного вызова, см. Ниже
@GET
@Produces( MediaType.APPLICATION_JSON)
public String getBackgroundImages(@QueryParam("missions") Stringmissions,
@QueryParam("objects") String objects,
@QueryParam("dates") String date) {
String result= "";
......
try {
.....
result = dbman.extractQueriedData(queryMissions, queryObjects, date);
} else {
result = dbman.extractPopular();
}
} catch(SQLException ex){
LoggingServices.createExceptionLogMessage(ex, LOGGER);
}
return String res = "jsonCallback("+ result +");";
}
и на стороне JavaScript
$.ajax({
async: false,
url: "/rest/UploadBackground/",
jsonp: "callback",
type:"GET",
dataType: "jsonp",
jsonpCallback: "jsonCallback",
success: function( response ) {
}
});
window.jsonCallback = function(data) {
//do something
};
Наиболее важные проблемы
- Возвращаемое значение сервера должно быть заключено в имя функции обратного вызова.
- Насколько мне известно, функция обратного вызова должна быть определена глобально с заданной сигнатурой.
Надеюсь, это поможет другим,
веселит,
эс
1 ответ
"Localhost" - это специально определенное имя, которое преобразуется в 127.0.0.1, который является адресом обратной связи, и доступно только с того же компьютера, но не доступно в любой другой сети.
Если ваши URL имеют полномочия localhost, они будут работать только с того же компьютера, что и сервер.