AndroidWiFi開發(fā)教程之WiFi熱點(diǎn)的創(chuàng)建與關(guān)閉示例

小編給大家分享一下Android WiFi開發(fā)教程之WiFi熱點(diǎn)的創(chuàng)建與關(guān)閉示例,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)公司專業(yè)提供四川服務(wù)器托管服務(wù),為用戶提供五星數(shù)據(jù)中心、電信、雙線接入解決方案,用戶可自行在線購(gòu)買四川服務(wù)器托管服務(wù),并享受7*24小時(shí)金牌售后服務(wù)。

先上效果圖

Android WiFi開發(fā)教程之WiFi熱點(diǎn)的創(chuàng)建與關(guān)閉示例
Android WiFi開發(fā)教程之WiFi熱點(diǎn)的創(chuàng)建與關(guān)閉示例 
Android WiFi開發(fā)教程之WiFi熱點(diǎn)的創(chuàng)建與關(guān)閉示例

Demo功能比較簡(jiǎn)單,四個(gè)按鈕、兩個(gè)文本和一個(gè)列表。功能主要有創(chuàng)建WiFi熱點(diǎn),關(guān)閉WiFi熱點(diǎn),搜索WiFi,連接WiFi,數(shù)據(jù)通訊。源碼會(huì)在教程結(jié)尾提供。

本章節(jié)主要介紹WiFi熱點(diǎn)的創(chuàng)建和關(guān)閉

需要用到的權(quán)限

WiFi熱點(diǎn)的創(chuàng)建

  1. /**
  2.     * 創(chuàng)建Wifi熱點(diǎn)
  3.     */
  4. private void createWifiHotspot() {
  5. if (wifiManager.isWifiEnabled()) {
  6. //如果wifi處于打開狀態(tài),則關(guān)閉wifi,
  7. wifiManager.setWifiEnabled(false);
  8. }
  9. WifiConfiguration config = new WifiConfiguration();
  10. config.SSID = WIFI_HOTSPOT_SSID;
  11. config.preSharedKey = "123456789";
  12. config.hiddenSSID = true;
  13. config.allowedAuthAlgorithms
  14. .set(WifiConfiguration.AuthAlgorithm.OPEN);//開放系統(tǒng)認(rèn)證
  15. config.allowedGroupCiphers.set(WifiConfiguration.GroupCipher.TKIP);
  16. config.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.WPA_PSK);
  17. config.allowedPairwiseCiphers
  18. .set(WifiConfiguration.PairwiseCipher.TKIP);
  19. config.allowedGroupCiphers.set(WifiConfiguration.GroupCipher.CCMP);
  20. config.allowedPairwiseCiphers
  21. .set(WifiConfiguration.PairwiseCipher.CCMP);
  22. config.status = WifiConfiguration.Status.ENABLED;
  23. //通過反射調(diào)用設(shè)置熱點(diǎn)
  24. try {
  25. Method method = wifiManager.getClass().getMethod(
  26. "setWifiApEnabled", WifiConfiguration.class, Boolean.TYPE);
  27. boolean enable = (Boolean) method.invoke(wifiManager, config, true);
  28. if (enable) {
  29. textview.setText("熱點(diǎn)已開啟 SSID:" + WIFI_HOTSPOT_SSID + " password:123456789");
  30. } else {
  31. textview.setText("創(chuàng)建熱點(diǎn)失敗");
  32. }
  33. } catch (Exception e) {
  34. e.printStackTrace();
  35. textview.setText("創(chuàng)建熱點(diǎn)失敗");
  36. }
  37. }

這里我們需要用到一個(gè)很重要的API——WifiManager。源碼中是有這么一段介紹:

  1. This class provides the primary API for managing all aspects of Wi-Fi
  2. connectivity. Get an instance of this class by calling
  3. {@link android.content.Context#getSystemService(String) Context.getSystemService(Context.WIFI_SERVICE)}.

可以了解到,我們能夠通過WifiManager來管理WiFi的連接。而通過Context.getSystemService(Context.WIFI_SERVICE)就能獲取到它的實(shí)例。

wifiManager = (WifiManager) getSystemService(Context.WIFI_SERVICE);

在開啟熱點(diǎn)的時(shí)候,我們需要確保WiFi是關(guān)閉狀態(tài),因?yàn)榇蟛糠质謾C(jī)都是不支持熱點(diǎn)和WiFi是同時(shí)開啟的。接著就需要?jiǎng)?chuàng)建WifiConfiguration這個(gè)類,由于配置我們所要?jiǎng)?chuàng)建的熱點(diǎn)的屬性。這里我們所需注意的主要是SSID、preSharedKey和KeyMgmt。 分別對(duì)應(yīng)熱點(diǎn)的名稱、密碼和加密方式。

配置完屬性后,我們就可以通過Java的反射機(jī)制去創(chuàng)建熱點(diǎn)。

WiFi熱點(diǎn)的關(guān)閉

  1. /**
  2.     * 關(guān)閉WiFi熱點(diǎn)
  3.     */
  4. public void closeWifiHotspot() {
  5. try {
  6. Method method = wifiManager.getClass().getMethod("getWifiApConfiguration");
  7. method.setAccessible(true);
  8. WifiConfiguration config = (WifiConfiguration) method.invoke(wifiManager);
  9. Method method2 = wifiManager.getClass().getMethod("setWifiApEnabled", WifiConfiguration.class, boolean.class);
  10. method2.invoke(wifiManager, config, false);
  11. } catch (NoSuchMethodException e) {
  12. e.printStackTrace();
  13. } catch (IllegalArgumentException e) {
  14. e.printStackTrace();
  15. } catch (IllegalAccessException e) {
  16. e.printStackTrace();
  17. } catch (InvocationTargetException e) {
  18. e.printStackTrace();
  19. }
  20. }

跟創(chuàng)建WiFI熱點(diǎn)一樣,關(guān)閉的時(shí)候同樣需要用到Java的反射機(jī)制。在調(diào)用Method的invoke方法時(shí),將最后一個(gè)參數(shù)改成false就可以了。

Android WiFi開發(fā)教程(二)——WiFi的搜索和連接

WiFi的搜索

  1. /* 搜索wifi熱點(diǎn)
  2.     */
  3. private void search() {
  4. if (!wifiManager.isWifiEnabled()) {
  5. //開啟wifi
  6. wifiManager.setWifiEnabled(true);
  7. }
  8. wifiManager.startScan();
  9. }

我們?cè)陂_始搜索WiFi之前確保當(dāng)前WiFi功能是處于開啟狀態(tài)。如果未開啟,通過調(diào)用WifiManager的setWifiEnabled(boolean enable)去開啟。之后調(diào)用startScan()就開始掃描附近的WiFi了。而獲取掃描的結(jié)果我們就需要?jiǎng)?chuàng)建一個(gè)廣播接收者來處理。

  1. private BroadcastReceiver receiver = new BroadcastReceiver() {
  2. @Override
  3. public void onReceive(Context context, Intent intent) {
  4. final String action = intent.getAction();
  5. if (action.equals(WifiManager.SCAN_RESULTS_AVAILABLE_ACTION)) {
  6. // wifi已成功掃描到可用wifi。
  7. List
  8. wifiListAdapter.clear();
  9. wifiListAdapter.addAll(scanResults);
  10. }
  11. };

系統(tǒng)在掃描結(jié)束后,會(huì)發(fā)出WifiManager.SCAN_RESULTS_AVAILABLE_ACTION的廣播,當(dāng)我們的接收者接收到這個(gè)廣播的時(shí)候,通過WifiManager的getScanResults()就能獲取到掃描結(jié)果的集合了。ScanResult保存著每一個(gè)WiFi的信息。這里我將這個(gè)集合設(shè)置到Adapter中,并在列表中展示出來。下面是Apater中主要的代碼:

  1. @Override
  2. public View getView(int position, View convertView, ViewGroup parent) {
  3. if (convertView == null) {
  4. convertView = mInflater.inflate(mResource, parent, false);
  5. }
  6. TextView name = (TextView) convertView.findViewById(R.id.wifi_name);
  7. TextView signl = (TextView) convertView.findViewById(R.id.wifi_signal);
  8. ScanResult scanResult = getItem(position);
  9. name.setText(scanResult.SSID);
  10. int level = scanResult.level;
  11. if (level
  12. signl.setText("信號(hào)很好");
  13. } else if (level < -50 && level >= -70) {
  14. signl.setText("信號(hào)較好");
  15. } else if (level < -70 && level >= -80) {
  16. signl.setText("信號(hào)一般");
  17. } else if (level < -80 && level >= -100) {
  18. signl.setText("信號(hào)較差");
  19. } else {
  20. signl.setText("信號(hào)很差");
  21. }
  22. return convertView;
  23. }

可以看出列表展示的數(shù)據(jù)也是比較簡(jiǎn)單,只有WiFi的名稱和信號(hào)強(qiáng)度,這兩個(gè)數(shù)據(jù)也是平時(shí)用得比較多的。獲取到掃描結(jié)果后,我們就可以處理連接的邏輯了。

WiFi的連接

WiFi的連接相當(dāng)于搜索就要復(fù)雜一些。首先給列表項(xiàng)設(shè)置點(diǎn)擊事件,獲取對(duì)應(yīng)的ScanResult。

  1. listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
  2. @Override
  3. public void onItemClick(AdapterView
  4. wifiManager.disconnect();
  5. final ScanResult scanResult = wifiListAdapter.getItem(position);
  6. String capabilities = scanResult.capabilities;
  7. int type = WIFICIPHER_WPA;
  8. if (!TextUtils.isEmpty(capabilities)) {
  9. if (capabilities.contains("WPA") || capabilities.contains("wpa")) {
  10. type = WIFICIPHER_WPA;
  11. } else if (capabilities.contains("WEP") || capabilities.contains("wep")) {
  12. type = WIFICIPHER_WEP;
  13. } else {
  14. type = WIFICIPHER_NOPASS;
  15. }
  16. }
  17. config = isExsits(scanResult.SSID);
  18. });

取到ScanResult后我們通過他的capabilities屬性判斷WiFi的加密方式。接著通過isExsits(String SSID)方法判斷系統(tǒng)是否保存著當(dāng)前WiFi的信息。

  1. private WifiConfiguration isExsits(String SSID) {
  2. List
  3. for (WifiConfiguration existingConfig : existingConfigs) {
  4. if (existingConfig.SSID.equals("\"" + SSID + "\"")) {
  5. return existingConfig;
  6. }
  7. }
  8. return null;
  9. }

如果之前連接過,則返回WiFi的配置信息,否則返回空對(duì)象。然后接著處理連接的邏輯

  1. if (config == null) {
  2. if (type != WIFICIPHER_NOPASS) {//需要密碼
  3. final EditText editText = new EditText(MainActivity.this);
  4. final int finalType = type;
  5. new AlertDialog.Builder(MainActivity.this).setTitle("請(qǐng)輸入Wifi密碼").setIcon(
  6. android.R.drawable.ic_dialog_info).setView(
  7. editText).setPositiveButton("確定", new DialogInterface.OnClickListener() {
  8. @Override
  9. public void onClick(DialogInterface dialog, int which) {
  10. Log.w("AAA", "editText.getText():" + editText.getText());
  11. config = createWifiInfo(scanResult.SSID, editText.getText().toString(), finalType);
  12. connect(config);
  13. }
  14. })
  15. .setNegativeButton("取消", null).show();
  16. return;
  17. } else {
  18. config = createWifiInfo(scanResult.SSID, "", type);
  19. connect(config);
  20. }
  21. } else {
  22. connect(config);
  23. }

當(dāng)沒有獲取到所要連接WiFi的配置信息時(shí),我們就需要用到前面獲取到的加密方式判斷是否需要輸入密碼。如果加密方式為WAP或WEP時(shí),則彈出提示框提示用戶輸入WiFi密碼。用戶輸入密碼后再調(diào)用connect(WifiConfiguration config)方法

如果可以獲取到所要連接WiFi的配置信息,則直接調(diào)用connect(WifiConfiguration config)。

  1. private void connect(WifiConfiguration config) {
  2. int wcgID = wifiManager.addNetwork(config);
  3. wifiManager.enableNetwork(wcgID, true);
  4. }

直接調(diào)用WifiManger的addNetwork方法,將配置信息傳進(jìn)去后,會(huì)創(chuàng)建一個(gè)新的網(wǎng)絡(luò)描述的身份并返回回來,如果返回來是-1,則表示創(chuàng)建失敗。獲取到身份后,調(diào)用enableNetwork方法就能開始連接WiFi了。到了這里,我們連接部分就完成了一半,接下來需要繼續(xù)處理WiFi連接過程中返回來的狀態(tài)。這里同樣我們是需要用到廣播接收者來處理。

  1. if (action.equals(WifiManager.NETWORK_STATE_CHANGED_ACTION)) {
  2. NetworkInfo info = intent.getParcelableExtra(WifiManager.EXTRA_NETWORK_INFO);
  3. if (info.getState().equals(NetworkInfo.State.DISCONNECTED)) {
  4. text_state.setText("連接已斷開");
  5. } else if (info.getState().equals(NetworkInfo.State.CONNECTED)) {
  6. WifiManager wifiManager = (WifiManager) context.getSystemService(Context.WIFI_SERVICE);
  7. final WifiInfo wifiInfo = wifiManager.getConnectionInfo();
  8. text_state.setText("已連接到網(wǎng)絡(luò):" + wifiInfo.getSSID());
  9. }
  10. } else {
  11. NetworkInfo.DetailedState state = info.getDetailedState();
  12. if (state == state.CONNECTING) {
  13. text_state.setText("連接中...");
  14. } else if (state == state.AUTHENTICATING) {
  15. text_state.setText("正在驗(yàn)證身份信息...");
  16. } else if (state == state.OBTAINING_IPADDR) {
  17. text_state.setText("正在獲取IP地址...");
  18. } else if (state == state.FAILED) {
  19. text_state.setText("連接失敗");
  20. }
  21. }
  22. }

上面是廣播接收者中的關(guān)鍵代碼。WiFi在連接的過程中系統(tǒng)會(huì)發(fā)出WifiManager.NETWORK_STATE_CHANGED_ACTION的廣播,當(dāng)接收者接收到這條廣播時(shí),獲取NetworkInfo的state來判斷當(dāng)前的連接狀態(tài)。狀態(tài)值分別代表如下

  1. NetworkInfo.State.DISCONNECTED //連接已斷開
  2. NetworkInfo.State.CONNECTED //已成功連接

除了這兩個(gè)狀態(tài)之外,這里還判斷了其他狀態(tài)

  1. NetworkInfo.DetailedState state = info.getDetailedState();
  2. if (state == state.CONNECTING) {
  3. text_state.setText("連接中...");
  4. } else if (state == state.AUTHENTICATING) {
  5. text_state.setText("正在驗(yàn)證身份信息...");
  6. } else if (state == state.OBTAINING_IPADDR) {
  7. text_state.setText("正在獲取IP地址...");
  8. } else if (state == state.FAILED) {
  9. text_state.setText("連接失敗");
  10. }

DetailedState中包含了很多連接狀態(tài)的信息,這里只對(duì)部分狀態(tài)進(jìn)行處理,其他狀態(tài)值解析具體如下

  1. IDLE:空閑
  2. SCANNING:正在掃描
  3. CONNECTING:連接中
  4. AUTHENTICATING:正在進(jìn)行身份驗(yàn)證
  5. OBTAINING_IPADDR:正在獲取Ip地址
  6. CONNECTED:已連接
  7. SUSPENDED:已暫停
  8. DISCONNECTING:正在斷開連接
  9. DISCONNECTED:已斷開
  10. FAILED:失敗
  11. BLOCKED:已阻止
  12. VERIFYING_POOR_LINK:暫時(shí)關(guān)閉(網(wǎng)絡(luò)狀況不佳)
  13. CAPTIVE_PORTAL_CHECK:判斷是否需要瀏覽器二次登錄

 

跟藍(lán)牙通訊一樣,WiFi熱點(diǎn)數(shù)據(jù)傳輸也是要運(yùn)用到Socket。這里我創(chuàng)建了兩個(gè)線程ConnectThread和ListenerThread,分別去處理數(shù)據(jù)傳輸和監(jiān)聽連接。

ConnectThread

  1. **
  2. * 連接線程
  3. * Created by 坤 on 2016/9/7.
  4. */
  5. public class ConnectThread extends Thread{
  6. private final Socket socket;
  7. private Handler handler;
  8. private InputStream inputStream;
  9. private OutputStream outputStream;
  10. public ConnectThread(Socket socket, Handler handler){
  11. setName("ConnectThread");
  12. this.socket = socket;
  13. this.handler = handler;
  14. }
  15. @Override
  16. public void run() {
  17. if(socket==null){
  18. return;
  19. }
  20. handler.sendEmptyMessage(MainActivity.DEVICE_CONNECTED);
  21. try {
  22. //獲取數(shù)據(jù)流
  23. inputStream = socket.getInputStream();
  24. outputStream = socket.getOutputStream();
  25. byte[] buffer = new byte[1024];
  26. int bytes;
  27. while (true){
  28. //讀取數(shù)據(jù)
  29. bytes = inputStream.read(buffer);
  30. if (bytes > 0) {
  31. final byte[] data = new byte[bytes];
  32. System.arraycopy(buffer, 0, data, 0, bytes);
  33. Message message = Message.obtain();
  34. message.what = MainActivity.GET_MSG;
  35. Bundle bundle = new Bundle();
  36. bundle.putString("MSG",new String(data));
  37. message.setData(bundle);
  38. handler.sendMessage(message);
  39. }
  40. }
  41. } catch (IOException e) {
  42. e.printStackTrace();
  43. }
  44. }
  45. /**
  46.     * 發(fā)送數(shù)據(jù)
  47.     */
  48. public void sendData(String msg){
  49. if(outputStream!=null){
  50. try {
  51. outputStream.write(msg.getBytes());
  52. Message message = Message.obtain();
  53. message.what = MainActivity.SEND_MSG_SUCCSEE;
  54. Bundle bundle = new Bundle();
  55. bundle.putString("MSG",new String(msg));
  56. message.setData(bundle);
  57. handler.sendMessage(message);
  58. } catch (IOException e) {
  59. e.printStackTrace();
  60. Message message = Message.obtain();
  61. message.what = MainActivity.SEND_MSG_ERROR;
  62. Bundle bundle = new Bundle();
  63. bundle.putString("MSG",new String(msg));
  64. message.setData(bundle);
  65. handler.sendMessage(message);
  66. }
  67. }
  68. }
  69. }

ConnectThread的構(gòu)造中,傳入了Socket和Handler。Socket用來獲取數(shù)據(jù)以及發(fā)送數(shù)據(jù),Handler用來更新UI了。在run方法中,我們從Socket中獲取到了輸入流和輸出流,然后循環(huán)地讀取InputStream的數(shù)據(jù),當(dāng)讀取到數(shù)據(jù)時(shí),則通過Handler將數(shù)據(jù)更新到UI上。在sendData方法中主要是通過OutputStream寫入數(shù)據(jù),然后將寫入結(jié)果通過Handler更新到UI上。

ListenerThread監(jiān)聽線程處理的邏輯就比較簡(jiǎn)單,通過端口號(hào)獲取ServerSocket后調(diào)用accept()阻塞線程,直到有設(shè)備連接上后就通過Handler更新UI。這里需要注意的是連接上的設(shè)備的端口號(hào)必須與這里的端口號(hào)相同。接著我們看看Hander獲取到消息后做了哪些處理。

  1. private Handler handler = new Handler() {
  2. @Override
  3. public void handleMessage(Message msg) {
  4. switch (msg.what) {
  5. case DEVICE_CONNECTING:
  6. connectThread = new ConnectThread(listenerThread.getSocket(),handler);
  7. connectThread.start();
  8. break;
  9. ... ...
  10. }
  11. }
  12. };

可以看到Handler獲取到數(shù)據(jù)后,通過listenerThread.getSocket()將獲取到Socket和handler一同創(chuàng)建了ConnectThread實(shí)例。

接下來就是用這兩個(gè)線程來處理數(shù)據(jù)傳輸了。

  1. @Override
  2. protected void onCreate(Bundle savedInstanceState) {
  3. super.onCreate(savedInstanceState);
  4. setContentView(R.layout.activity_main);
  5. ... ...
  6. listenerThread = new ListenerThread(PORT, handler);
  7. listenerThread.start();
  8. }

在onCreate中我們創(chuàng)建ListenerThread并啟動(dòng)它,讓它監(jiān)聽是否有設(shè)備連接上來。當(dāng)然這里需要先開啟WiFi熱點(diǎn)后才會(huì)有設(shè)備連接上來。這是開啟熱點(diǎn)并等待設(shè)備連接的情況。當(dāng)然我們也可以主動(dòng)去連接其他開啟著熱點(diǎn)的設(shè)備。

在監(jiān)聽WiFi連接情況的廣播接收者中加入下面的代碼

  1. if (info.getState().equals(NetworkInfo.State.CONNECTED)) {
  2. WifiManager wifiManager = (WifiManager) context.getSystemService(Context.WIFI_SERVICE);
  3. final WifiInfo wifiInfo = wifiManager.getConnectionInfo();
  4. text_state.setText("已連接到網(wǎng)絡(luò):" + wifiInfo.getSSID());
  5. if (wifiInfo.getSSID().equals(WIFI_HOTSPOT_SSID)) {
  6. //如果當(dāng)前連接到的wifi是熱點(diǎn),則開啟連接線程
  7. new Thread(new Runnable() {
  8. @Override
  9. public void run() {
  10. try {
  11. ArrayList
  12. for (String ip : connectedIP) {
  13. if (ip.contains(".")) {
  14. Socket socket = new Socket(ip, PORT);
  15. connectThread = new ConnectThread(socket, handler);
  16. connectThread.start();
  17. }
  18. }
  19. } catch (IOException e) {
  20. e.printStackTrace();
  21. }
  22. }
  23. }).start();
  24. }
  25. } else {
  26. ...
  27. }
  28. }

這里本地固定了其他設(shè)備WiFi熱點(diǎn)的SSID,如果當(dāng)前連接的WiFi的SSID跟我們之前保存的SSID一致,則證明我們連上了我們需要的WiFi熱點(diǎn)。然后通過getConnectedIP()獲取WiFi熱點(diǎn)的IP地址,通過這個(gè)IP地址和端口號(hào)創(chuàng)建一個(gè)Socket,然后創(chuàng)建ConnectThread來處理數(shù)據(jù)傳輸。到這里我們可以看到,PORT和SSID這兩個(gè)數(shù)據(jù)是需要兩個(gè)設(shè)備事先協(xié)議好的。

最后再看看Handler完整的代碼

  1. private Handler handler = new Handler() {
  2. @Override
  3. public void handleMessage(Message msg) {
  4. switch (msg.what) {
  5. case DEVICE_CONNECTING:
  6. connectThread = new ConnectThread(listenerThread.getSocket(),handler);
  7. connectThread.start();
  8. break;
  9. case DEVICE_CONNECTED:
  10. textview.setText("設(shè)備連接成功");
  11. break;
  12. case SEND_MSG_SUCCSEE:
  13. textview.setText("發(fā)送消息成功:" + msg.getData().getString("MSG"));
  14. break;
  15. case SEND_MSG_ERROR:
  16. textview.setText("發(fā)送消息失敗:" + msg.getData().getString("MSG"));
  17. break;
  18. case GET_MSG:
  19. textview.setText("收到消息:" + msg.getData().getString("MSG"));
  20. break;
  21. }
  22. }
  23. };

以上是Android WiFi開發(fā)教程之WiFi熱點(diǎn)的創(chuàng)建與關(guān)閉示例的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

網(wǎng)頁名稱:AndroidWiFi開發(fā)教程之WiFi熱點(diǎn)的創(chuàng)建與關(guān)閉示例
文章源于:http://bm7419.com/article30/pccsso.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)、響應(yīng)式網(wǎng)站外貿(mào)建站、服務(wù)器托管、用戶體驗(yàn)、面包屑導(dǎo)航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)