Я пытаюсь создать безопасное соединение TCP / IP между моим клиентом Android и сервером Java.Криптография далеко не моя сильная сторона.Я знаю, что должен использовать хранилища ключей Bouncy Castle, но я застрял.
Мне нужно создать самоподписанный сертификат, который я могу использовать с сервером и клиентом.Вот где я застрял.
InputStream clientTruststoreIs = getResources().openRawResource(R.raw.bks);
KeyStore trustStore = null;
trustStore = KeyStore.getInstance("BKS");
trustStore.load(clientTruststoreIs, "123456".toCharArray());
InetAddress serverAddr = InetAddress.getByName(serverIpAddress);
SSLSocketFactory sslsocketfactory = (SSLSocketFactory) SSLSocketFactory.getDefault();
sslSocket = (SSLSocket) sslsocketfactory.createSocket(serverAddr, 2222);
inputStream = sslSocket.getInputStream();
Log.d("TEST", "\n1 input");
Соединяется нормально, показывает соединение на стороне сервера, однако линия inputStream = sslSocket.getInputStream()
полностью блокируется / не возвращается.Я не уверен, правильно ли я настроил какой-либо из надувных замков или сервер настроен правильно.Пожалуйста, помогите, я нахожусь в тупике ....
Редактировать: я изменил сервер так, чтобы он отправлял данные при соединении и все еще ничего, и я изменил порядок, где я получаю свой ввод ивыходные потоки, а затем он заблокирован там, где я получал выходной поток:
sslSocket = (SSLSocket) sslsocketfactory.createSocket(serverAddr, 9999);
outputStream = sslSocket.getOutputStream();
Log.d("test", "--**--- created socket 2.0 outputsreams"); // does not reach here
outputStreamWriter = new OutputStreamWriter(outputStream);
bufferedWriter = new BufferedWriter(outputStreamWriter);
inputStream = sslSocket.getInputStream();
inputStreamReader = new InputStreamReader(inputStream);
bufferedReader = new BufferedReader(inputStreamReader);
...
String line = bufferedReader.readLine(); // where I'd expect it to lock...
Так что все равно нет ни удачи, ни таймаута, ни исключения, он просто ждет там ...