Наконец, это решается с помощью атрибута "timeout" в jQuery AJAX (и JSONP). Смотрите мой собственный ответ!
Пожалуйста, смотрите обновленную часть, я тоже пробовал апплет. И не стесняйтесь принять ваш ответ, если вы можете дать решение с внедрением апплета.
Я работаю с веб-приложением на основе Java. Мое требование - проверить, открыт ли или заблокирован определенный порт (скажем, 1935) на стороне клиента. Я реализовал «jsonp» (почему «jsonp»? Я обнаружил, что запрос «http» через AJAX не может работать для corssdomain для браузеров с «одинаковой политикой происхождения») AJAX-вызов одного из моих серверов, содержащих определенный порт. И если сервер возвращает xhr.status == 200
, порт открыт. Вот недостаток, который я не могу заставить поток выполнения ждать (синхронно), пока вызов не завершится. Вот функция JavaScript, которую я использую.
Любое альтернативное решение (должно быть на стороне клиента, должно быть параллельно с моим приложением, пожалуйста, не предлагайте python / php / другие языки) также приветствуется. Спасибо за ваше время.
function checkURL() {
var url = "http://10.0.5.255:1935/contextname" ;
var isAccessible = false;
$.ajax({
url: url,
type: "get",
cache: false,
dataType: 'jsonp',
crossDomain : true,
asynchronous : false,
jsonpCallback: 'deadCode',
complete : function(xhr, responseText, thrownError) {
if(xhr.status == "200") {
isAccessible = true;
alert("Request complete, isAccessible==> " + isAccessible); // this alert does not come when port is blocked
}
}
});
alert("returning isAccessible=> "+ isAccessible); //this alert comes 2 times before and after the AJAX call when port is open
return isAccessible;
}
function deadCode() {
alert("Inside Deadcode"); // this does not execute in any cases
}
-------------------------------------------- -------------ОБНОВИТЬ------------------------------------ ----------------------------
Я пробовал с Java-апплетом (благодаря предложению Y Martin). Это нормально работает в appletviewer. Но когда я добавляю апплет на HTML-страницу, он дает уязвимые результаты. Уязвимый в том смысле, что при изменении вкладки или изменении размера браузера значение portAvailable
изменяется в печатном сообщении.
Код апплета:
import java.applet.Applet;
import java.awt.Graphics;
import java.net.InetSocketAddress;
import java.net.Socket;
public class ConnectionTestApplet extends Applet {
private static boolean portAvailable;
public void start() {
int delay = 1000; // 1 s
try {
Socket socket = new Socket();
/*****This is my tomcat5.5 which running on port 1935*************/
/***I can view it with url--> http://101.220.25.76:1935/**********/
socket.connect(new InetSocketAddress("101.220.25.76", 1935), delay);
portAvailable = socket.isConnected();
socket.close();
System.out.println("init() giving---> " + portAvailable);
}
catch (Exception e) {
portAvailable = false;
System.out.println("init() giving---> " + portAvailable);
System.out.println("Threw error---> " + e.getMessage());
}
}
public void paint(Graphics g) {
System.out.println("Connection possible---> " + portAvailable);
String msg = "Connection possible---> " + portAvailable;
g.drawString(msg, 10, 30);
}
}
И это моя HTML-страница (я размещаю ее на том же компьютере с другим Tomcat 6, работающим на порте 9090. Я могу просмотреть эту страницу с помощью URL ---> <a href="http://101.220.25.76:9090/test/" rel="nofollow">http://101.220.25.76:9090/test/</a>
):
<html>
<body>
<applet code="ConnectionTestApplet" width=300 height=50>
</applet>
</body>
</html>
А как у меня порт 1935 блокируется и открывается?
Я создал правило брандмауэра для входящего и исходящего трафика для порта 1935.
Я проверяю сценарий открытия / блокировки порта 1935, отключив / включив оба правила.
Это мой S.S.C.C.E . Теперь, пожалуйста, помогите мне:)