תוכן עניינים:
2025 מְחַבֵּר: John Day | [email protected]. שונה לאחרונה: 2025-01-13 06:57
מאת: ריילי בארט ודילן האלנד
מטרתו של פרויקט זה היא לאפשר למכשיר IoT, כגון תקע Weemo חכם, אמזון אקו, קונסולת משחקים, או כל מכשיר אחר המאפשר Wi-Fi להתחבר לרשת WPA_EAP ארגונית באמצעות פטל פייס אפס W כחבילה מכשיר העברה. נדרשים שלבי תצורה נוספים להתקנים המתחברים לרשת ארגונית, והתקנים רבים אינם תואמים כלל. באמצעות גשר Wi-Fi, כל מכשיר יכול להשיג גישה לאינטרנט בקלות על ידי חיבור ל- Pi.
ניתן ליישם את המערכת על כרטיס אלחוטי אחד או על שני כרטיסים נפרדים בהתאם לדרישות המשתמש. עבור מערכות הדורשות עוצמת אות גבוהה יותר ומהירות העלאה/הורדה מהירות יותר, עדיף להשתמש בכרטיס אלחוטי ייעודי לאירוח נקודת הגישה. עם זאת, עבור מערכות שבהן עוצמת האות ורוחב הפס פחות חשובות, או שבהן רצוי פתרון חסכוני יותר, ניתן לשתף כרטיס יחיד על ידי נקודת הגישה וחיבור הרשת.
אספקה
Raspberry Pi Zero W
גישה למקלדת ולצג
קצת ידע בתכנות (למטרות ניפוי באגים, הגדרת פטל פטל)
מתאם/דונגל WiFi חיצוני (אופציונלי)
שלב 1: הגדרת ה- Raspberry Pi
התחל על ידי חיבור ה- Pi שלך למקלדת ולצג (ייתכן שיהיה צורך במתאם HDMI).
לאחר מכן, תוכל להתחיל בהקלדת הפקודה:
סודו סו
זה יבטיח שיש לך את ההרשאות הדרושות לשינוי קבצים ב- pi.
כעת תרצה להתקין dnsmasq ו- hostapd באמצעות הפקודה:
apt-get להתקין dnsmasq hostapd
כעת תוכל להתחיל להתקין את גשר ה- WiFi.
הערה - המדריך הבא יכיל מידע עבור משתמשים המשתמשים בכרטיס האלחוטי היחיד המשולב הן עבור נקודת הגישה והן לחיבור לרשת. כמו כן, ניתן להגדיר את המערכת לפעול על שני כרטיסים נפרדים. לשם כך, פשוט חפש את שורות ה- "wlan1" המופיעות בקבצים שסופקו, והחליף אותן בשורות "ap0" השכנות.
שלב 2: 70-persistent-net.rules
התחל במציאת כתובת ה- MAC של ה- pi שלך על ידי הקלדת:
iw dev
צור את הקובץ הבא:
nano /etc/udev/rules.d/70-persistent-net.rules
ולערוך אותו כך שיכיל את הדברים הבאים
SUBSYSTEM == "ieee80211", ACTION == "הוסף | שינוי", ATTR {macaddress} == "b8: 27: eb: c0: 38: 40", KERNEL == "phy0", / RUN+= "/sbin/ ממשק iw phy phy0 הוסף סוג ap0 סוג _ap ", / RUN+="/bin/ip link set כתובת ap0 b8: 27: eb: c0: 38: 40"
קובץ זה אומר למערכת להקצות מכשיר לנקודת הגישה בעת האתחול. כאן, יש להחליף את כתובת ה- MAC בכתובת ה- pi שלך, שזה עתה מצאת.
(שני כרטיסי אלחוטית) אין צורך בקובץ זה בעת שימוש בשני כרטיסי אלחוטית.
שלב 3: Hostapd.conf
לאחר מכן תערוך את הקובץ hostapd.conf על ידי הזנת הפרטים הבאים:
nano /etc/hostapd/hostapd.conf
שנה את הקובץ כך שיתאים לתצורה הבאה:
ctrl_interface =/var/run/hostapd
ctrl_interface_group = 0 #interface = ap0 interface = wlan1 driver = nl80211 ssid = testnet hw_mode = g channel = 6 wmm_enabled = 0 macaddr_acl = 0 auth_algs = 1 wpa = 2 wpa_passphrase = 0123456789 wpa_key_mgmt = WPA-PSK_WP_PWK_PWK_pa_pkWspa
שים לב שבעוד שהערוץ שלי כאן מוגדר ל -6, ייתכן שיהיה עליך לשנות ערך זה כך שיתאים לערוץ בו wlan0 נמצא. בחלק מהרשתות הערוץ ישתנה אוטומטית כך שנקודת הגישה תתאים ל- wlan0, אך זו לא הייתה החוויה שלי ברשת הארגונית. אתה יכול לבדוק אילו ערוצים נמצאים כרגע בשימוש ועל פי אילו ממשקים על ידי הקלדה
ערוץ iwlist
(שני כרטיסים אלחוטיים) כל שעליך לעשות הוא לבטל את התגובה של השורה המכילה wlan1 ולהעיר את זה המכיל ap0.
שלב 4: Dnsmasq.conf
כעת תערוך את הקובץ dnsmasq.conf:
nano /etc/dnsmasq.conf
בטל תגובה או הוסף את השורות הבאות:
ממשק = הנה, ap0
#interface = lo, wlan1 no-dhcp-interface = lo bind-interfaces server = 8.8.8.8 תחום דרוש מזויף- priv dhcp-range = 192.168.2.100, 192.168.2.200, 12h
אתה יכול להשתמש ברשת המשנה שלך כאן אם תרצה, רק וודא שאתה עקבי.
(שני כרטיסי WirelessC) הסירו תגובה על השורה המכילה wlan1, והעירו את המכיל ap0.
שלב 5: ממשקים
לאחר מכן, יהיה עליך לשנות את קובץ הממשקים:
ממשקים nano/etc/network/
אוטומטי לא
auto ap0 #auto wlan1 auto wlan0 iface lo inet loopback iface eth0 inet dhcp allow-hotplug ap0 #allow-hotplug wlan1 iface ap0 inet static #iface wlan1 inet כתובת סטטית 192.168.2.1 netmask 255.255.255.0 hostapd /etc/hostapd/hostapd.conf allow -hotplug wlan0 iface wlan0 inet dhcp pre -up wpa_supplicant -B -Dwext -i wlan0 -c/etc/wpa_supplicant/wpa_supplicant.conf post -down killall -q wpa_supplicant
ראוי לציין כי ממשק wlan0 חייב לבוא אחרי כל ממשק שאתה מעביר אליו, אחרת המערכת לא תפעל כראוי.
(שני כרטיסים אלחוטיים) בטל את כל השורות המכילות wlan1 והעיר הערות על כל המכילים ap0.
שלב 6: Wpa_supplicant.conf
כעת תשנה את הקובץ wpa_supplicant.conf שנמצא ב:
nano /etc/wpa_supplicant/wpa_supplicant.conf
חלק מהרשתות מוגדרות באופן שונה מאחרים כך שחלק זה עשוי לדרוש קצת התעסקות, להלן הקובץ wpa_supplicant.conf שאיפשר לי להתחבר לרשת ב- Cal Poly:
country = USctrl_interface = DIR =/var/run/wpa_supplicant GROUP = netdev update_config = 1 רשת = {ssid = "SecureMustangWireless" scan_ssid = 1 key_mgmt = WPA-EAP pairwise = CCMP TKIP group = CCMP TKIP eap = PEAP זהות = "שם משתמש@ calpoly.edu "password =" your_password "phase1 =" peapver = 0 "phase2 =" MSCHAPV2 "}
קובץ זה משמש להגדרת wlan0 להתחבר לרשת הארגונית שלך. חלק מהרשתות הארגוניות דורשות תעודת CA כדי להתחבר. רשת הקמפוסים של Cal Poly אינה דורשת תעודה, ולכן דילגתי על חלק זה, אך ניתן להוריד בקלות את האישורים המתאימים ולהוסיף אותם לקובץ wpa_supplicant שלך עם השורה
ca_cert = "/path/to/cert.pem"
שלב 7: סקריפט Hostapdstart
הדבר האחרון שנותר לעשות הוא לכתוב סקריפט שמתחיל את שני הממשקים ומגדיר את העברת החבילות כשהמערכת מתחילה. צור קובץ בשם hostapdstart על ידי הקלדת:
nano/usr/local/bin/hostapdstart
הוסף את הקובץ הבא
sudo ifdown --force wlan0 && sudo ifdown -force ap0 && sudo ifup ap0 && sudo ifup wlan0
#sudo ifdown --force wlan0 && sudo ifdown --force wlan1 && sudo ifup wlan1 && sudo ifup wlan0 sudo sysctl -w net.ipv4.ip_forward = 1 sudo iptables -t nat -A POSTROUTING -s 192.168.2.0/24! -d 192.168.2.0/24 -j MASQUERADEsudo systemctl הפעלה מחדש dnsmasq
תסריט זה מוריד את שני הממשקים ולאחר מכן מעלה אותם בסדר הנכון, אומר ל- pi שתרצה להעביר חבילות מממשק אחד למשנהו, ולבסוף מפעיל מחדש את dnsmasq כך שהשינויים ישפיעו.
(שני כרטיסים אלחוטיים) קו ללא תגובה עם wlan1 והערת שורה עם ap0.
שלב 8: Rc.local
לבסוף, אנו רוצים שהמערכת תתחיל כאשר המערכת אתחלה, לכן נשנה את הקובץ rc.local, המופעל בעת האתחול:
nano /etc/rc.local
כל שעליך לעשות הוא להוסיף את השורה הבאה לסוף הקובץ:
hostapdstart> 1 &
הקובץ שלך אמור להיראות בערך כך:
_IP = $ (שם מארח -אני) || trueif ["$ _IP"]; ואז printf "כתובת ה- IP שלי היא %s / n" "$ _IP" fi
hostapdstart> 1 &
יציאה 0
שלב 9: אתחל מחדש
וזה הכל! כעת, בהנחה שהכל מותקן כהלכה והדונגל ה- WiFi שלך מחובר (אם אתה משתמש באחד), עליך פשוט לאתחל את ה- Raspberry Pi שלך באמצעות הפקודה:
לְאַתחֵל
לאחר שה- Pi שלך יאתחל בהצלחה, אתה אמור להיות מסוגל לראות את שם נקודת הגישה שלך בכל מכשיר (טלפון, מחשב נייד וכו '). לאחר שתתחבר באמצעות הסיסמה שציינת, היא אמורה לחבר אותך ישירות לרשת הארגונים הרצויה לך!
תודה מיוחדת לקישורים הבאים שסיפקו לנו מושג כיצד לגשת לפרויקט זה:
- https://blog.thewalr.us/2017/09/26/raspberry-pi-ze…
- https://www.raspberrypi.org/forums/viewtopic.php?p…
- https://www.raspberrypi.org/forums/viewtopic.php?f…
הודע לנו אם יש לך שאלות, הערות או הצעות!
מקום שני באתגר IoT