2008-12-30 11 views
31

मैं उपलब्ध वायरलेस नेटवर्क की एक सूची प्राप्त करना चाहता हूं। आदर्श रूप से यह कुछ सी कॉल के माध्यम से होगा, लेकिन मुझे कोई फर्क नहीं पड़ता कि मुझे इसे सिस्टम कॉल के साथ जोड़ना है। यदि आवश्यक सी कॉल या प्रोग्राम को कुछ विदेशी तृतीय पक्ष पैकेज की आवश्यकता नहीं है तो भी बेहतर होगा।मैं लिनक्स पर उपलब्ध वायरलेस नेटवर्क की सूची कैसे प्राप्त कर सकता हूं?

इंटरनेट का सुझाव है कि मैं sudo iwlist <interface> scan का उपयोग करता हूं जो कमांड लाइन से चाल करने लगता है, लेकिन मुझे रूट अनुमतियों की आवश्यकता नहीं है। मैं केवल मूल बातें देखना चाहता हूं, कुछ भी नहीं बदलना चाहता हूं।

+2

आपको iwlist चलाने के लिए रूट होने की आवश्यकता नहीं है, लेकिन यह केवल अंतिम आवधिक स्कैन से कैश किए गए मानों की रिपोर्ट करेगा। एक नए स्कैन को मजबूर करने के लिए आपको रूट होने की आवश्यकता है। – Hudson

+0

हम्म, जब गैर-रूट चलाते हैं तो कम से कम उबंटू 8 पर कुछ भी नहीं लौटाता है।04: -/ – richq

उत्तर

26

Wireless Tools पैकेज - जिसमें से iwlist एक हिस्सा है - इसमें एक वायरलेस टूल्स हेल्पर लाइब्रेरी भी है। आप (अर्थात जोड़ने -liw) iwlib.h और libiw.a साथ लिंक शामिल करने की जरूरत है। फिर iw_set_ext फ़ंक्शन के लिए प्रलेखन देखें। SIOCSIWSCAN पैरामीटर सबसे अधिक उपयोग किया जाएगा। इस इंटरफ़ेस का उपयोग करने के उदाहरण के लिए, केडीई लाइब्रेरी में KWifiManager स्रोत पर एक नज़र डालें (देखें: Interface_wireless_wirelessextensions::get_available_networks विधि)। वैकल्पिक रूप से, आप Wireless Tools source code भी डाउनलोड कर सकते हैं और Iwlist.c में स्कैनिंग के लिए iwlib iw_set_ext फ़ंक्शन का उपयोग कैसे किया जाता है, इस पर एक नज़र डालें।

विशेषाधिकारों के लिए, मुझे लगता है कि प्रक्रिया को स्कैन करने के लिए रूट के रूप में चलाने की आवश्यकता होगी। मुझे यह जानना अच्छा लगेगा कि यह अन्यथा भी किया जा सकता है।

आप Ubuntu 8.04 के बाद से उपयोग कर रहे हैं libiw-dev पैकेज उपयोग की होना चाहिए।

+0

क्या मैं वाणिज्यिक अनुप्रयोग में ** वायरलेस उपकरण ** पैकेज (** libiw-dev **) का उपयोग कर सकता हूं? शायद मैं नहीं कर सकता, लेकिन मुझे यकीन है कि। – rraszewski

35

कमांड लाइन में स्कैन करना बहुत आसान है। मैन पेज यहां आपका मित्र हैं (iwconfig और iwlist देखें)। लेकिन सी इंटरफ़ेस का उपयोग करना थोड़ा और मुश्किल है इसलिए मैं उस पर ध्यान केंद्रित करूंगा।

सबसे पहले, के रूप में अन्य लोगों का उल्लेख किया है, निश्चित रूप से बाहर wireless tools source code डाउनलोड करें। प्रोग्रामिंग इंटरफेस के लिए सभी दस्तावेज .c फाइलों में हैं। जहां तक ​​मैं कह सकता हूं, एपीआई के लिए कोई वेब प्रलेखन नहीं है। हालांकि, स्रोत कोड पढ़ने के लिए बहुत आसान है। इस प्रश्न के लिए आपको बहुत अधिक iwlib.h और iwlib.c की आवश्यकता है।

आप iw_set_ext और iw_get_ext, libiw एक बुनियादी स्कैनिंग समारोह iw_scan, जिसमें से आप जानकारी है कि आप की जरूरत के सबसे निकाल सकते हैं लागू करता है का उपयोग कर सकते है।

सभी उपलब्ध वायरलेस नेटवर्क के लिए ईएसएसआईडी प्राप्त करने के लिए यहां एक सरल कार्यक्रम है। -liw के साथ संकलित करें और sudo के साथ चलाएं।

#include <stdio.h> 
#include <time.h> 
#include <iwlib.h> 

int main(void) { 
    wireless_scan_head head; 
    wireless_scan *result; 
    iwrange range; 
    int sock; 

    /* Open socket to kernel */ 
    sock = iw_sockets_open(); 

    /* Get some metadata to use for scanning */ 
    if (iw_get_range_info(sock, "wlan0", &range) < 0) { 
    printf("Error during iw_get_range_info. Aborting.\n"); 
    exit(2); 
    } 

    /* Perform the scan */ 
    if (iw_scan(sock, "wlan0", range.we_version_compiled, &head) < 0) { 
    printf("Error during iw_scan. Aborting.\n"); 
    exit(2); 
    } 

    /* Traverse the results */ 
    result = head.result; 
    while (NULL != result) { 
    printf("%s\n", result->b.essid); 
    result = result->next; 
    } 

    exit(0); 
} 

अस्वीकरण: यह सिर्फ एक प्रदर्शन का कार्यक्रम है। कुछ परिणामों के लिए एक निबंध नहीं होना संभव है। इसके अलावा, यह मानता है कि आपका वायरलेस इंटरफ़ेस "wlan0" है। तुम्हें नया तरीका मिल गया है।

iwlib स्रोत कोड पढ़ें!

+0

क्या आप इस विधि का उपयोग कर एपी पता (मैक पता) भी प्राप्त कर सकते हैं? कैसे? धन्यवाद :) – bubbly

+0

मुझे मैक पता मिलता है: परिणाम-> ap_addr लेकिन यह एक प्रिंट करने योग्य रूप में नहीं है। यह 71732 की तरह कुछ प्रिंट करता है। – bubbly

+0

** iwconfig ** सामान्य प्रारूप में एक्सेस पॉइंट प्रिंट करता है। 'Iwconfig.c' में कमांड के लिए स्रोत कोड देखें (" एक्सेस पॉइंट "के लिए खोजें)। –

 संबंधित मुद्दे

  • कोई संबंधित समस्या नहीं^_^