![]() |
Модераторы: LSD, AntonSaburov |
![]() ![]() ![]() |
|
Рассада |
|
|||
Новичок Профиль Группа: Участник Сообщений: 47 Регистрация: 13.7.2005 Репутация: нет Всего: 1 |
Добрый день!
У меня такая задача: надо осуществить взаимодействие приложения на Java с различными СУБД (MS SQL, MySQL, Oracle) без использования JDBC. Задачу придумал не я, поэтому советы перестать валять дурака мне пока малополезны ![]() Может, есть какие-нибудь API-библиотеки фирм-производителей СУБД... Хотя боюсь, что работа с каждой СУБД через API принесет с собой кучу хлопот |
|||
|
||||
LSD |
|
||||
![]() Leprechaun Software Developer ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 15718 Регистрация: 24.3.2004 Где: Dublin Репутация: 210 Всего: 538 |
Для Oracle есть OCI, но она рассчитана на работу с Си, а из Java придется использовать JNI.
Именно табу на JDBC, или стоит задача абстрагироваться от конкретной СУБД? -------------------- Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it. |
||||
|
|||||
Рассада |
|
||||
Новичок Профиль Группа: Участник Сообщений: 47 Регистрация: 13.7.2005 Репутация: нет Всего: 1 |
Разве это сохранить платформонезависимость?
Задача абстрагирования стоит давно. ![]() А запрет связан с тем, что JDBC не обладает должной надежностью (без комментариев). В общем, как я понял, хочется им обойтись без использования высокоуровневых функций ODBC, JDBC, OLE DB... Добавлено @ 11:20 Для MySQL нашлось что-то вот здесь: http://www.mysql.com/products/connector/j/. Надо копнуть глубже... |
||||
|
|||||
LSD |
|
|||
![]() Leprechaun Software Developer ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 15718 Регистрация: 24.3.2004 Где: Dublin Репутация: 210 Всего: 538 |
OCI реализован для всех платформ на которых работает Oracle. Надо ли будет вносить изменения в Сишную прослойку или достаточно будет ее перекомпилировать под конкретную платформу, я не знаю. А вот Java код можно оставить без изменений. Но работать с OCI то еще удовольствие, библиотека довольно низкоуровневая. Лучше объясни заказчику, что это весьма трудоемко, а результат может быть хуже чем с JDBC. -------------------- Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it. |
|||
|
||||
batigoal |
|
|||
![]() Нелетучий Мыш ![]() ![]() ![]() ![]() Профиль Группа: Участник Клуба Сообщений: 6423 Регистрация: 28.12.2004 Где: Санктъ-Петербургъ Репутация: 24 Всего: 151 |
Это JDBC-драйвер ![]() -------------------- "Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли) ЖоржЖЖ |
|||
|
||||
Рассада |
|
|||
Новичок Профиль Группа: Участник Сообщений: 47 Регистрация: 13.7.2005 Репутация: нет Всего: 1 |
![]() ![]() Не слишком простые пути вырисовываются по грядущей реализации... |
|||
|
||||
SmaLL |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Клуба Сообщений: 557 Регистрация: 17.12.2002 Где: Voronezh Репутация: 1 Всего: 2 |
Интересно, а откуда такая информация? 2All А что действительно не обладает? ![]() -------------------- Что ни делается - всЁ к лучшему! SmallWeb Мой адрес не дом и не улица, мой адрес родной пивзавод! |
|||
|
||||
AntonSaburov |
|
|||
![]() Штурман ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 5658 Регистрация: 2.7.2002 Где: Санкт-Петербург Репутация: 51 Всего: 118 |
Да вообщем-то как любое приложение, которое использует нешифрованный TCP/IP. Весь трафик открыт. Хотя тот же Oracle по моим сведениям поддерживает в своем драйвере возможность шифрования. |
|||
|
||||
SmaLL |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Клуба Сообщений: 557 Регистрация: 17.12.2002 Где: Voronezh Репутация: 1 Всего: 2 |
СдаЁтся мне что Рассада будет писать тотже JDBC драйвер только, например, с поддержкой шифрования.
-------------------- Что ни делается - всЁ к лучшему! SmallWeb Мой адрес не дом и не улица, мой адрес родной пивзавод! |
|||
|
||||
AntonSaburov |
|
|||
![]() Штурман ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 5658 Регистрация: 2.7.2002 Где: Санкт-Петербург Репутация: 51 Всего: 118 |
Так надо предварительно посмотреть, может это в драйверах уже есть. Хотя если надо для универсальности, тогда надо делать промежуточный слой для шифрования.
Или организовать VPN внутри подсети. |
|||
|
||||
Итальянец |
|
|||
Новичок Профиль Группа: Участник Сообщений: 15 Регистрация: 13.6.2005 Репутация: нет Всего: нет |
Я так понимаю у Рассада задача написать мост альтернативный JDBC? Или ему нужно просто обеспечить более высокую надежность? Вообще-то я сомневаюсь, что с мостом у него что-то получится, по-моему гораздо легче и экономнее обеспечить надежность.
|
|||
|
||||
Stampede |
|
|||
![]() Гносеолог ![]() ![]() Профиль Группа: Участник Клуба Сообщений: 963 Регистрация: 25.4.2005 Где: Calgary, Alberta, Canada Репутация: 24 Всего: 144 |
Я понимаю, что требование идет откуда-то сверху и, возможно, из кругов не сильно компетентных, но все же можно поподробнее, что именно подразумевается под "должной надежностью"? Просто слово достаточно многозначное, хотелось бы уточнить. В любом случае, требование реализовать собственный метод доступа к БД (да еще с условием переносимости между СУБД) есть очевидная и дорогостоящая глупость. Потому что выйдет в итоге тот же JDBC - просто в силу природы взаимодействия ДБ-серверов с SQL-клиентами. Ибо цикл выполнения SQL команды - он и в африке цикл, безотносительно к тому, как называется библиотека доступа: ODBC, JDBC или Vasya Pupkin's Data Access Library ![]() |
|||
|
||||
Рассада |
|
||||||
Новичок Профиль Группа: Участник Сообщений: 47 Регистрация: 13.7.2005 Репутация: нет Всего: 1 |
SmaLL, мне самому так сдается ![]()
1. Точно. 2. Возможный вариант..? Stampede, под недостаточной надежностью понимается то, о чем сказал AntonSaburov(как я понял ![]()
|
||||||
|
|||||||
LSD |
|
|||
![]() Leprechaun Software Developer ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 15718 Регистрация: 24.3.2004 Где: Dublin Репутация: 210 Всего: 538 |
Рассада если тебе надо шифровать трафик, то используй VPN как советовал AntonSaburov, тот же OCI не позволит сам по себе передавать шифрованные данные, только совместно с Oracle Advanced Security. Да и другие низкоуровневые интерфейсы тоже врядли смогут работать с шифрованными данными, если это в них не заложенно изначально.
А если уж никак VPN нельзя, то придется на сервере где стоит СУБД, запускать некого твоего агента, который будет соединяться с БД от имени клиента и передавать ему данные по шифрованному каналу. -------------------- Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it. |
|||
|
||||
hatsumeika |
|
|||
![]() Шустрый ![]() Профиль Группа: Участник Сообщений: 51 Регистрация: 14.5.2005 Где: Минск Репутация: 2 Всего: 2 |
Если задача решается шифрованием, можно шифровать данные записываемые в БД.
Тут конечно будет полно побочных эффектов, например перестанет работать сравнение >, <. Но останется ==, != Еще можно исключить трафик между приложением и БД по сети посредством сервера приложений, живущего на одном компе с БД. Объекты передаваемые между клиентом и сервером можно шифровать при сериализации. |
|||
|
||||
![]() ![]() ![]() |
Правила форума "Java" | |
|
Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux, javastic. |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | Java: Общие вопросы | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |