Сканирование доступных сетей Wi-Fi на BlackBerry - PullRequest
3 голосов
/ 07 июня 2010

Имеется ли какой-либо API RIM , который поможет получить список доступных сетевых услуг или только сетей Wi-Fi для устройства и установить выбранную точку доступа к сети для любых сетевых коммуникаций?

Возможно ли для моего приложения отключить мобильные сети, такие как GPRS, WAP и т. Д.?

Пример:
Когда приложение запущено, оно должно выполнить поиск подключений Wi-Fi, даже если на устройстве не было установлено предыдущих точек доступа к сети Wi-Fi, и отобразить список доступных подключений Wi-Fi. Затем пользователь выберет соответствующее соединение Wi-Fi для подключения к любой сети связи. За пределами приложения любое интернет-общение, такое как браузер или любое другое приложение, должно осуществляться через одно и то же выбранное соединение Wi-Fi. Сканирование для Wi-Fi и настройка соединения практически аналогичны настройке BlackBerry Wi-Fi.

Я собираюсь сделать это для BlackBerry OS 4.5, 4.7 и 5.0.

Обновление

Дело в том, что я ищу сканирование Wi-Fi через приложение. Это похоже на то, как через приложение я могу сканировать доступные точки доступа Wi-Fi или точки доступа и установить одну из точек доступа, выбрав ее на устройстве, а затем подключиться к ней для связи.

По сути, это как настроить Wi-Fi-соединение в «Управлении подключением» BlackBerry? Я должен сделать подобное через приложение.

На некоторых форумах BlackBerry я узнал, что в ОС v5.0 есть пакет, то есть пакет net.rim.device.api.wlan.hotspot для получения точек доступа Wi-Fi. Но после долгих поисков я не нашел ни одного примера, ни большого объяснения. Как я пытаюсь реализовать, изучая его документацию по API, но у меня ничего не получилось.

Если у вас есть идеи, связанные с этим или любым другим примером кода, это будет очень полезно.

1 Ответ

5 голосов
/ 13 июня 2010

Что ж, для сканирования всех доступных сетей для приложения вы можете использовать NetworkDiagnostic tool от RIM.

Другой фрагмент кода для сканирования вашего телефона и получения наилучшей строки подключения можно найти в Как надежно установить сетевое соединение на любом устройстве BlackBerry ,

/**
 * Determines what connection type to use and returns the necessary string to use it.
 * @return A string with the connection info
 */
private static String getConnectionString()
{
    // This code is based on the connection code developed by Mike Nelson of AccelGolf.
    // http://blog.accelgolf.com/2009/05/22/blackberry-cross-carrier-and-cross-network-http-connection
    String connectionString = null;

    // Simulator behavior is controlled by the USE_MDS_IN_SIMULATOR variable.
    if (DeviceInfo.isSimulator())
    {
            if (UploaderThread.USE_MDS_IN_SIMULATOR)
            {
                    logMessage("Device is a simulator and USE_MDS_IN_SIMULATOR is true");
                    connectionString = ";deviceside=false";
            }
            else
            {
                    logMessage("Device is a simulator and USE_MDS_IN_SIMULATOR is false");
                    connectionString = ";deviceside=true";
            }
    }

    // Wi-Fi is the preferred transmission method.
    else if (WLANInfo.getWLANState() == WLANInfo.WLAN_STATE_CONNECTED)
    {
        logMessage("Device is connected via Wifi.");
        connectionString = ";interface=wifi";
    }

    // Is the carrier network the only way to connect?
    else if ((CoverageInfo.getCoverageStatus() & CoverageInfo.COVERAGE_DIRECT) == CoverageInfo.COVERAGE_DIRECT)
    {
        logMessage("Carrier coverage.");

        String carrierUid = getCarrierBIBSUid();
        if (carrierUid == null)
        {
            // Has carrier coverage, but not BIBS.  So use the carrier's TCP network
            logMessage("No Uid");
            connectionString = ";deviceside=true";
        }
        else
        {
            // otherwise, use the Uid to construct a valid carrier BIBS request
            logMessage("uid is: " + carrierUid);
            connectionString = ";deviceside=false;connectionUID="+carrierUid + ";ConnectionType=mds-public";
        }
    }

    // Check for an MDS connection instead (BlackBerry Enterprise Server).
    else if ((CoverageInfo.getCoverageStatus() & CoverageInfo.COVERAGE_MDS) == CoverageInfo.COVERAGE_MDS)
    {
        logMessage("MDS coverage found");
        connectionString = ";deviceside=false";
    }

    // If there is no connection available abort to avoid bugging the user unnecssarily.
    else if (CoverageInfo.getCoverageStatus() == CoverageInfo.COVERAGE_NONE)
    {
        logMessage("There is no available connection.");
    }

    // In theory, all bases are covered so this shouldn't be reachable.
    else
    {
        logMessage("no other options found, assuming device.");
        connectionString = ";deviceside=true";
    }

    return connectionString;
}

/**
 * Looks through the phone's service book for a carrier provided BIBS network
 * @return The uid used to connect to that network.
 */
private static String getCarrierBIBSUid()
{
    ServiceRecord[] records = ServiceBook.getSB().getRecords();
    int currentRecord;

    for (currentRecord = 0; currentRecord < records.length; currentRecord++)
    {
        if (records[currentRecord].getCid().toLowerCase().equals("ippp"))
        {
            if (records[currentRecord].getName().toLowerCase().indexOf("bibs") >= 0)
            {
                return records[currentRecord].getUid();
            }
        }
    }
    return null;
}
...