у нас есть приложение, которое использует много локальных ресурсов, таких как API печати Windows, реестр Windows, некоторые Active X для подключения к POS-устройствам (для оплаты денег и получения квитанции, цена отправляется из приложения), принтер штрих-кода для печать этикеток, устройства RFID для чтения и записи некоторых данных. Приложение написано с использованием .Net Framework 3.5 и использует некоторые новые функции .Net Framework (например, WCF). Формы в приложении представляют собой очень тяжелые формы (7 из них являются обязательными), в каждой форме имеется более 100 текстовых полей, комбо, переключателей, панелей и многих других элементов управления, которые в соответствии с потребностями пользователя отображаются или скрыты, отключены или включен, заполнен и очищен, много-много раз.
После того, как пользователь выполнит работу, большая часть отпечатков будет автоматически отправлена на ранее выбранный принтер, большинство этикеток будет напечатано на принтере штрих-кодов, при необходимости будут вызваны устройства RFID и POS.
Проблема в том, что теперь нам нужна базовая веб-версия этого. причина в том, что существует административный отдел, который должен знать о любых транзакциях в сети (есть программное обеспечение для панели инструментов). В версии WIN APP мы используем WCF для отправки и получения новых данных (что-то похожее на репликацию).
Согласно моим поискам, есть 3 (даже 4) способа достижения этой цели, как показано ниже.
Использование технологии WPF
Использование Clickonce
Использование Pure html + Active X (что означает asp.net, очень тяжелый JavaScript и запись Active X)
Хостинг Windows формирует элементы управления в IE
WPF XBAP - это хорошо, но:
Необходимо загрузить все библиотеки DLL на локальный компьютер, а затем запустить приложение. Это также происходит каждый раз, когда на сервер загружается новая версия. Размеры DLL составляют около 5мг.
Также существует риск, что пользователь может разобрать DLL. Также нам нужно подписать сборки, чтобы иметь возможность использовать win API, и пользователю необходимо добавить сайт на его защищенный сайт.
Основным недостатком является то, что WPF на самом деле отсутствует в веб-архитектуре. Я имею в виду, что dll выполняет вычисления на стороне клиента, а сервер отвечает только за сохранение сущностей (и выполняет некоторые проверки).
см. https://stackoverflow.com/tags/web-applications/info
Clickonce:
Понятия не имею, мы можем развернуть приложение (версия WPF или версия для Windows) как приложение clickonce, но сервер отвечает только за обновление новых версий программного обеспечения.
Чистая сеть и HTML + Active X :
Это трудоемкая работа, все вроде бы нормально, но на самом деле мы должны быть мастерами JQuery и AJAX, и я думаю, что большая часть времени уходит на отладку javascript. Также только IE может запускать App @ all из-за элементов управления Active X на странице.
Winform в IE :
Совсем не лучший выбор, но мы можем это сделать, вывод работает только в IE, а также визуализированный пользовательский интерфейс, в очень плохом стиле.
Существует также другой способ , который может быть взломом, когда мы разрабатываем с помощью чистого веба, мы можем написать некоторые службы WCF для выполнения аппаратной части (связь с оборудованием, локальными ресурсами и другими вещами) и установите их на клиентах (например, запустите cassini). Поэтому, когда нам нужно, например, работать с аппаратными и локальными ресурсами (POS, RFID, Registry и другими), мы можем вызывать их с нашего сайта с помощью вызова веб-службы (который указывает на локальный хост).
Что из этого является хорошим выбором и что?
Есть ли другое решение?
любая идея может помочь.
большое спасибо .