How to create Custom WPA Hotspot with ssid and pas

2019-04-06 21:15发布

问题:

I am using the following code for creating the Wifi-hotspot configuration. I am able to create the Hotspot configuration and able to enable it. but i have give configuration for WPA-PSK, But it always taken as OPEN network.

public boolean setHotSpot(String SSID,String passWord){
Method[] mMethods = mWifiManager.getClass().getDeclaredMethods();

    for(Method mMethod: mMethods){

        if(mMethod.getName().equals("setWifiApEnabled")) {
            WifiConfiguration netConfig = new WifiConfiguration();
             netConfig.SSID = SSID ;
                netConfig.preSharedKey = passWord;
                netConfig.hiddenSSID = true;
                netConfig.status = WifiConfiguration.Status.ENABLED;
                netConfig.allowedAuthAlgorithms.set(WifiConfiguration.AuthAlgorithm.SHARED);
                netConfig.allowedKeyManagement.set(4);
                netConfig.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.WPA_PSK);
                netConfig.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.WPA_EAP);
                netConfig.allowedGroupCiphers.set(WifiConfiguration.GroupCipher.TKIP);
                netConfig.allowedGroupCiphers.set(WifiConfiguration.GroupCipher.CCMP);
                netConfig.allowedPairwiseCiphers.set(WifiConfiguration.PairwiseCipher.TKIP);
                netConfig.allowedPairwiseCiphers.set(WifiConfiguration.PairwiseCipher.CCMP);
                netConfig.allowedProtocols.set(WifiConfiguration.Protocol.RSN);
                netConfig.allowedProtocols.set(WifiConfiguration.Protocol.WPA);

            try {              
                mMethod.invoke(mWifiManager, netConfig,true);
                mWifiManager.saveConfiguration();
                return true;

            } catch (Exception e) {
                e.printStackTrace();
                CommonUtil.log(TAG,"Exception : "+e.getLocalizedMessage());
            }
        }
    }
return false; 

}

After run this app the Hotspot got enabled. Please check the image below.

How to set the WPA_PSK wifi configuration in android app?

As per below answer i have modified the code below.

public boolean setHotSpot(String SSID, String passWord) {
    boolean apstatus;
    WifiConfiguration netConfig = new WifiConfiguration();
    if (passWord == "") {
        netConfig.SSID = SSID;
        netConfig.allowedAuthAlgorithms.set(WifiConfiguration.AuthAlgorithm.OPEN);
        netConfig.allowedProtocols.set(WifiConfiguration.Protocol.RSN);
        netConfig.allowedProtocols.set(WifiConfiguration.Protocol.WPA);
        netConfig.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.NONE);
    } else {
        netConfig.SSID = SSID;
        netConfig.preSharedKey = passWord;
                /*netConfig.hiddenSSID = true;
                netConfig.status = WifiConfiguration.Status.ENABLED;
                netConfig.allowedAuthAlgorithms.set(WifiConfiguration.AuthAlgorithm.SHARED);
                netConfig.allowedKeyManagement.set(4);
                netConfig.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.WPA_PSK);
                netConfig.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.WPA_EAP);
                netConfig.allowedGroupCiphers.set(WifiConfiguration.GroupCipher.TKIP);
                netConfig.allowedGroupCiphers.set(WifiConfiguration.GroupCipher.CCMP);
                netConfig.allowedPairwiseCiphers.set(WifiConfiguration.PairwiseCipher.TKIP);
                netConfig.allowedPairwiseCiphers.set(WifiConfiguration.PairwiseCipher.CCMP);
                netConfig.allowedProtocols.set(WifiConfiguration.Protocol.RSN);
                netConfig.allowedProtocols.set(WifiConfiguration.Protocol.WPA);*/
        netConfig.allowedAuthAlgorithms.set(WifiConfiguration.AuthAlgorithm.SHARED);
        netConfig.allowedProtocols.set(WifiConfiguration.Protocol.RSN);
        netConfig.allowedProtocols.set(WifiConfiguration.Protocol.WPA);
        netConfig.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.WPA_PSK);
    }

    try {
        Method setWifiApMethod = mWifiManager.getClass().getMethod("setWifiApEnabled", WifiConfiguration.class, boolean.class);
        //setWifiApMethod.invoke(mWifiManager, previousConfigurations, false);
        //Thread.sleep(2000);
        apstatus = (Boolean) setWifiApMethod.invoke(mWifiManager, netConfig, true);
    } catch (Exception e) {
        CommonUtil.log(TAG, e.getMessage());
        return false;
    }
    return apstatus;
}

回答1:

netConfig.allowedAuthAlgorithms.set(WifiConfiguration.AuthAlgorithm.OPEN);

replace above OPEN to SHARED

netConfig.allowedAuthAlgorithms.set(WifiConfiguration.AuthAlgorithm.SHARED);


回答2:

sollution

/** 
 * Uppsala University 
 *  
 * Project CS course, Fall 2012 
 * 
 * Projekt DV/Project CS, is a course in which the students develop software for 
 * distributed systems. The aim of the course is to give insights into how a big 
 * project is run (from planning to realization), how to construct a complex  
 * distributed system and to give hands-on experience on modern construction  
 * principles and programming methods. 
 * 
 * All rights reserved. 
 * 
 * Copyright (C) 2012 LISA team 
 */ 
package project.cs.lisa.networksettings; 

import java.util.List; 

import android.content.Context; 
import android.net.wifi.ScanResult; 
import android.net.wifi.WifiConfiguration; 
import android.net.wifi.WifiInfo; 
import android.net.wifi.WifiManager; 
import android.util.Log; 

public class WifiHandler { 
    //constants 
    public static final int WEP = 1;
    public static final int WAP = 2;
    public static final int OPEN_NETWORK = 3;

    public static final String TAG = "LISA_Network";

    /** dfsdfsdfsdf. */ 
    WifiConfiguration wifiConf;             /* WifiConfiguration object */

    /** dfsdfsdfsdf. */ 
    WifiManager wifiMgr;                            /* WifiManager object */

    /** dfsdfsdfsdf. */ 
    WifiInfo wifiInfo;                              /* WifiInfo object */

    /** dfsdfsdfsdf. */ 
    List<ScanResult> wifiScan;              /* List of ScanResult objects */

    /** 
     * Constructor initializes WifiManager and WifiInfo. 
     * @param context 
     */ 
    public WifiHandler(Context context) {
        wifiMgr  = getWifiManager(context);     // gets wifiMgr in the current context 
        wifiInfo = getWifiInfo(context);            // gets wifiInfo in the current context
        wifiConf = getWifiConf(context);            // gets wifiConf in the current context
        wifiScan = getWifiInRange();                    // gets wifiScan in the current context
    } 

    /** 
     * Function checkWifiEnabled checks if the WiFi connection 
     * is enabled on the device.  
     * @param wifiMgr 
     * @return true  if the WiFi connection is enabled, 
     *               false if the WiFi connection is disabled 
     */ 
    public boolean checkWifiEnabled() { 
        // checks if WiFi is enabled 
        return (wifiMgr != null && wifiMgr.isWifiEnabled());
    } 

    /** 
     * Function enableWifi enables WiFi connection on the device. 
     * @param wifiMgr 
     * @return true  if the attempt to enable WiFi succeeded, 
     *               false if the attempt to enable WiFi failed.  
     */ 
    public boolean enableWifi() { 
        // enables WiFi connection 
        return wifiMgr.setWifiEnabled(true);
    } 

    /** 
     * Function disableWifi disables WiFi connection on the device. 
     * @param wifiMgr 
     * @return true  if WiFi connection was disabled, 
     *               false if attempt to disable WiFi failed. 
     */ 
    public boolean disableWifi() { 
        // disables WiFi connection 
        return wifiMgr.setWifiEnabled(false);
    } 

    /** 
     * Function getWifiManager gets the WiFiManager object from the device. 
     * @param context 
     * @return WifiManager object. Also sets the class variable 
     *               wifiMgr as the WifiManager object returned. 
     */ 
    public WifiManager getWifiManager(Context context) {
        WifiManager wifiMgr = null;

        // gets WifiManager obj from the system 
        wifiMgr = (WifiManager) context.getSystemService(Context.WIFI_SERVICE);

        if (wifiMgr == null) {
            Log.d("TAG", "WIFI_SERVICE is the wrong service name.");
        } 

        return wifiMgr;
    } 

    /** 
     * Function getWifiInfo gets the current WiFi connection information in a 
     * WifiInfo object from the device. 
     * @param context 
     * @return wifiInfo created object or 
     *               null       if wifi is not enabled. 
     */ 
    public WifiInfo getWifiInfo(Context context) {
        WifiInfo wifiInfo = null;

        // gets WiFi network info of the current connection 
        if (checkWifiEnabled()) { 
            wifiInfo = (WifiInfo) wifiMgr.getConnectionInfo();   
        } 

        if (wifiInfo == null) {
            Log.d("TAG", "WifiInfo object is empty.");
        } 

        return wifiInfo;
    } 

    /** 
     * Function that returns a WifiConfiguration object from the WifiInfo 
     * object from the class. If wifiInfo exists, then we are able to retrieve 
     * information from the current connection  
     * @param context 
     * @return WifiConfiguration object created. 
     */ 
    public WifiConfiguration getWifiConf(Context context) {
        WifiConfiguration wifiConfiguration = new WifiConfiguration();

        if (wifiInfo == null) {
            Log.d("TAG", "WifiInfo object is empty");
            return null; 
        } 

        wifiConfiguration.SSID = wifiInfo.getSSID();
        wifiConfiguration.networkId = wifiInfo.getNetworkId();

        return wifiConfiguration;
    } 

    /** 
     * Creates a new WifiConfiguration object for wifiConf. 
     */ 
    public void clearWifiConfig() { 
        wifiConf = new WifiConfiguration();
    } 

    /** 
     * Function getWifiInRange returns all the WiFi networks that are 
     * accessible through the access point (device AP) found during the 
     * last scan. 
     * @param wifi 
     * @return List of ScanResult containing information on all WiFi networks 
     *               discovered in the range. 
     */ 
    public List<ScanResult> getWifiInRange() {
        // gets ~last~ list of WiFi networks accessible through the access point. 
        return (wifiScan = (List<ScanResult>) wifiMgr.getScanResults());
    } 

    /** 
     * Function that scans for wifi networks available in the devices range. 
     * @return true  if scan started 
     *               false if scan could not be started  
     */ 
    public boolean scanWifiInRange() { 
        if (!checkWifiEnabled()) { 
            return false; 
        } 

        if (!wifiMgr.startScan()) {
            Log.d("TAG", "Failed to scan wifi's in range.");
            return false; 
        } 

        return true; 
    } 

    /** 
     * Function to disconnect from the currently connected WiFi AP. 
     * @return true  if disconnection succeeded 
     *               false if disconnection failed 
     */ 
    public boolean disconnectFromWifi() { 
        return (wifiMgr.disconnect());
    } 

    /** 
     * Function to connect to a selected network 
     * @param networkSSID         network SSID name 
     * @param   networkPassword     network password 
     * @param networkId           network ID from WifiManager 
     * @param SecurityProtocol    network security protocol 
     * @return true  if connection to selected network succeeded 
     *               false if connection to selected network failed 
     */ 
    public boolean connectToSelectedNetwork(String networkSSID, String networkPassword) {
        int networkId;
        int SecurityProtocol = WEP;

        // Clear wifi configuration variable 
        clearWifiConfig(); 

        // Sets network SSID name on wifiConf  
        wifiConf.SSID = "\"" + networkSSID + "\"";
        Log.d(TAG, "SSID Received: " + wifiConf.SSID);
        switch(SecurityProtocol) {
            // WEP "security". 
            case WEP:
                wifiConf.wepKeys[0] = "\"" + networkPassword + "\""; 
                wifiConf.wepTxKeyIndex = 0;
                wifiConf.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.NONE);
                wifiConf.allowedGroupCiphers.set(WifiConfiguration.GroupCipher.WEP40);
                break; 

                // WAP security. We have to set preSharedKey. 
            case WAP:
                wifiConf.preSharedKey = "\""+ networkPassword +"\"";
                break; 

                // Network without security. 
            case OPEN_NETWORK:
                wifiConf.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.NONE);
                break; 
        } 

        // Add WiFi configuration to list of recognizable networks 
        if ((networkId = wifiMgr.addNetwork(wifiConf)) == -1) {
            Log.d("TAG", "Failed to add network configuration!");
            return false; 
        } 

        // Disconnect from current WiFi connection 
        if (!disconnectFromWifi()) { 
            Log.d("TAG", "Failed to disconnect from network!");
            return false; 
        } 

        // Enable network to be connected 
        if (!wifiMgr.enableNetwork(networkId, true)) {
            Log.d("TAG", "Failed to enable network!");
            return false; 
        } 

        // Connect to network 
        if (!wifiMgr.reconnect()) {
            Log.d("TAG", "Failed to connect!");
            return false; 
        } 

        return true; 
    } 
} 


回答3:

I have done this in my app. Please check my code below.

First add below permissions to your manifest.

<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
<uses-permission android:name="android.permission.WRITE_SETTINGS" />

Then create below MyHotspotManager .java class

public class MyHotspotManager {
    private WifiConfiguration wifiCon;
    private HotspotDetails hotspotDetails;
    private WifiManager mWifiManager;

    public MyHotspotManager(WifiManager wifiManager){
        this.mWifiManager = wifiManager;
    }

    public boolean setHotspot(HotspotDetails hotspotDetails) {
        this.hotspotDetails = hotspotDetails;
        boolean apstatus;
        wifiCon = new WifiConfiguration();
        wifiCon.SSID = hotspotDetails.getSsid();
        wifiCon.preSharedKey = hotspotDetails.getPassword();
        wifiCon.allowedAuthAlgorithms.set(WifiConfiguration.AuthAlgorithm.SHARED);
        wifiCon.allowedProtocols.set(WifiConfiguration.Protocol.RSN);
        wifiCon.allowedProtocols.set(WifiConfiguration.Protocol.WPA);
        wifiCon.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.WPA_PSK);
        try {
            Method setWifiApMethod = mWifiManager.getClass().getMethod("setWifiApEnabled", WifiConfiguration.class, boolean.class);
            //setWifiApMethod.invoke(mWifiManager, previousConfigurations, false);
            //Thread.sleep(2000);
            apstatus = (Boolean) setWifiApMethod.invoke(mWifiManager, wifiCon, true);
        } catch (Exception e) {
            Log.e(this.getClass().toString(), "", e);
            return false;
        }

        return apstatus;
    }

}

After that you can call the setHotspot method anywhere in you activity like below. Here I had to check whether app has the ACTION_MANAGE_WRITE_SETTINGS permission.

public void OnButtonClick(View view) {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
            if (!Settings.System.canWrite(getApplicationContext())) {
                Toast.makeText(this, "Please try again after giving access to Change system settings", Toast.LENGTH_SHORT).show();
                Intent intent = new Intent(Settings.ACTION_MANAGE_WRITE_SETTINGS, Uri.parse("package:" + getPackageName()));
                startActivityForResult(intent, 200);

            }else{
                createHotspot();
            }
        }

    }

    private void createHotspot(){
        HotspotDetails hotspotDetails = new HotspotDetails();
        hotspotDetails.setSsid("TestStackOverFlow");
        hotspotDetails.setPassword("654321");
        new MyHotspotManager((WifiManager) getApplicationContext().getSystemService(Context.WIFI_SERVICE))
                .setHotspot(hotspotDetails);
    }

But if you want you can omit permission request part by changing your targetSdkVersion to 21 in build.gradle. Now you can call it like below

    public void OnButtonClick(View view) {
//        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
//            if (!Settings.System.canWrite(getApplicationContext())) {
//                Toast.makeText(this, "Please try again after giving access to Change system settings", Toast.LENGTH_SHORT).show();
//                Intent intent = new Intent(Settings.ACTION_MANAGE_WRITE_SETTINGS, Uri.parse("package:" + getPackageName()));
//                startActivityForResult(intent, 200);
//
//            }else{
//            }
//        }

        createHotspot();
    }

    private void createHotspot(){
        HotspotDetails hotspotDetails = new HotspotDetails();
        hotspotDetails.setSsid("TestStackOverFlow");
        hotspotDetails.setPassword("654321");
        new MyHotspotManager((WifiManager) getApplicationContext().getSystemService(Context.WIFI_SERVICE))
                .setHotspot(hotspotDetails);
    }

This my HotspotDetails.java class

public class HotspotDetails {
    private String ssid;
    private String password;

    public String getSsid() {
        return ssid;
    }

    public void setSsid(String ssid) {
        this.ssid = ssid;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    @Override
    public String toString() {
        return ssid + ":" + password;
    }
}