當前位置:首頁 » 幣種行情 » ioctl綁定eth

ioctl綁定eth

發布時間: 2023-03-26 07:34:06

A. 在android JNI中通過socket獲取MAC硬體地址,socket創建成功,但調用ioctl的時候,返回-1,怎麼回事

這跟具體的WLAN驅動有關系,在你手機上不行說明你手機的WLAN驅動沒有實現這個參數的ioctl

B. 計算機網路編程,關於ioctl函數,求大神指教。

下面的清單介紹了一些最重要的結構,使用 ioctl 套接字命令時常常用到這些結構。
清單 1. struct ifreq (/usr/include/net/if.h)

/* Interface request structure used for socket
* ioctl's. All interface ioctl's must have parameter
* definitions which begin with ifr_name. The
* remainder may be interface specific.
*/
struct ifreq {
#ifndef IFNAMSIZ
#define IFNAMSIZ 16
#endif
char ifr_name[IFNAMSIZ];
union {
struct sockaddr ifru_addr;
struct sockaddr ifru_dstaddr;
struct sockaddr ifru_broadaddr;
__ulong32_t ifru_flags;
int ifru_metric;
caddr_t ifru_data;
u_short ifru_site6;
__ulong32_t ifru_mtu;
int ifru_baudrate;
} ifr_ifru;
Following macros are provided for convenience
#define ifr_addr ifr_ifru.ifru_addr /* address */
#define ifr_dstaddr ifr_ifru.ifru_dstaddr /* other end of p-to-p link */
#define ifr_broadaddr ifr_ifru.ifru_broadaddr /* broadcast address */
#define ifr_flags ifr_ifru.ifru_flags /* flags */
#define ifr_metric ifr_ifru.ifru_metric /* metric */
#define ifr_data ifr_ifru.ifru_data /* for use by interface */
#define ifr_site6 ifr_ifru.ifru_site6 /* IPv6 site index */
#define ifr_mtu ifr_ifru.ifru_mtu /* mtu of interface */
#define ifr_isno ifr_ifru.ifru_data /* pointer to if_netopts */
#define ifr_baudrate ifr_ifru.ifru_baudrate /* baudrate of interface */
};

清單 2. struct ifconf (/usr/include/net/if.h)

/*
* Structure used in SIOCGIFCONF request.
* Used to retrieve interface configuration
* for machine (useful for programs which
* must know all networks accessible).
*/
struct ifconf {
int ifc_len; /* size of associated buffer */
union {
caddr_t ifcu_buf;
struct ifreq *ifcu_req;
} ifc_ifcu;
Following macros are provided for convenience
#define ifc_buf ifc_ifcu.ifcu_buf /* buffer address */
#define ifc_req ifc_ifcu.ifcu_req /* array of structures returned */
};
可以去網路上搜下編程回憶錄之Unity3D,他們有公開課,你們看看就知道,我感覺非常的好。

C. struct模塊中的ioctl函數有什麼作用

一、在普通程序中設置網卡混雜模式。
在普通程序中普遍用ioctl函數來設置,該函數很值得大家好好的了解,因為它的使用非常的廣泛。下面
給出設置網卡混雜模式的實現代碼:
#include
#include
#include
#include
int set_all_promisc()
{ struct ifreq ifaces[16];
struct ifconf param;
int sock, i;
param.ifc_len = sizeof(ifaces);
param.ifc_req = ifaces;
sock = socket(PF_INET, SOCK_DGRAM, IPPROTO_IP);
if (sock <= 0)
return 0;
if (ioctl(sock, SIOCGIFCONF, ¶m))
return 0;
for (i = 0; i < param.ifc_len / sizeof(struct ifreq); i++) {
if (ioctl(sock, SIOCGIFFLAGS, ifaces + i))
return 0;
ifaces[i].ifr_flags |= IFF_PROMISC; /*如果恢復網卡模式,把|= 改成 &=~ */
if (ioctl(sock, SIOCSIFFLAGS, ifaces + i))
return 0;
}
return 1;
}

二、在核心空間中設置混雜模式
1.在kernel-2.2.x 中
static struct device *sniffer_dev = NULL;
static unsigned short old_flags, old_gflags;

int init_mole ( void ) /* 模塊缺衫初始化 */
{
......

sniffer_dev = dev_get("eth0");
if ( sniffer_dev != NULL )
{
/* thanks for difeijing of whnet's Security */
old_flags = sniffer_dev->flags;
old_gflags = sniffer_dev->gflags;
/*
* 參看net/core/dev.c里的dev_change_flags()
* ->gflags的作用是避免多次重復設置混雜模式,沒有其他特別含義
*/
/* 設置混雜模式 */
sniffer_dev->flags |= IFF_PROMISC;
sniffer_dev->gflags |= IFF_PROMISC;
start_bh_atomic();
/* 注意,這個回調函數還是會報告 eth0: Setting promiscuous mode. */
sniffer_dev->set_multicast_list( sniffer_dev );
end_bh_atomic();
}

......

return 0;
}
void cleanup_mole(void)
{
......

if (sniffer_dev != NULL)
{
/* 恢復原有模式 */伏滑腔
sniffer_dev>flags = old_flags;
sniffer_dev>gflags = old_gflags;
start_bh_atomic();
sniffer_dev>set_multicast_list( sniffer_dev );
end_bh_atomic();
}

......
}

2.在kernel-2.4.x 中
在2.4中有了許多變化,首先struct device結構改為struct net_device, 再者dev_get
功能改為測試網路設備是否存在,真正的設置網路混雜模式的函數改為
void dev_set_promiscuity(struct net_device *dev, int inc);
其中根據inc的值來設置混雜模式還是恢復原來設置模式,通過計數來恢復原來模式,這樣的好處就是:不會和其讓核他的程序沖突,不在像上述兩種實現方式中恢復原來模式就全恢復了,不管還有沒有其他的程序是否也設置了混雜模式。現在就通過計數來恢復原來的模式,只要當計數相加為零才設置成普通模式。
linux源代碼的注釋如下:
/**
* dev_set_promiscuity - update promiscuity count on a device
* @dev: device
* @inc: modifier
*
* Add or remove promsicuity from a device. While the count in the device
* remains above zero the interface remains promiscuous. Once it hits zero
* the device reverts back to normal filtering operation. A negative inc
* value is used to drop promiscuity on the device.
*/
設置網卡混雜模式的實現代碼如下:

struct net_device *sniffer_dev = NULL;
int dev_flags = 0;

int init_mole ( void ) /* 模塊初始化 */
{
......

sniffer_dev = dev_get_by_name("eth0");
if (sniffer_dev != NULL)
{
dev_flags = 1;
dev_set_promiscuity(sniffer_dev, 1);
dev_put(sniffer_dev);
sniffer_dev = NULL;
}

......

return 0;
}

void cleanup_mole(void)
{
......

if (dev_flags)
{
sniffer_dev = dev_get_by_name("eth0");
if (sniffer_dev != NULL)
{
dev_flags = 0;
dev_set_promiscuity(sniffer_dev, -1); /*注意此處的第二個參數*/
dev_put(sniffer_dev);
sniffer_dev = NULL;
}
}

......
}

D. 通過ioctl 可以獲取網卡的網關地址嗎

1.ifconfig -a 其中 HWaddr欄位就是歲嫌mac地址
2. cat /sys/class/net/eth0/信激address 查看eth0的mac地址
3. cat /proc/net/arp 查看連接到本機的遠端ip的mac地址
4. 程序中使用SIOCGIFHWADDR的ioctl命令獲取mac地址
注意:要和ifcfg-eth0中乎坦手device和mac地址的eth0對應,mac地址也要對應

E. ethtool設置網卡速率後網卡狀態變成down

您好,在設置網岩脊昌卡速率後,網卡狀態變成down的原因可能是由於網卡的驅動程序有問題,或者網卡的設置不正確。此外,網路環境可能存在問題,也可能是網卡本身的問題。因此,在設置網卡速率後,建議您粗扒檢查網卡的驅動程序是否正確,檢查網卡的設置是否正確,檢查網路環境是否正常,以及檢查網卡本身是否有問題。如果以上檢查都沒野鋒有問題,建議您重新安裝網卡驅動程序,或者重新安裝操作系統,以解決網卡狀態變成down的問題。

F. 怎樣網卡設置混雜模式

有時候為嗅探到網路上的數據,需要將網卡設置到混雜模式。進入該模式將網路上的數據一並抓獲,為此在設置nic的混雜模式的時候有諸多方法:
一、通過shell命令來實現:
ifconfig eth1 promisc 設置混雜模式
ifconfig eth1 -promisc 取消混雜模式
執行結果如下
[root@localhost tftpboot]# ifconfig
eth6 Link encap:Ethernet HWaddr 08:00:27:70:1D:79
inet6 addr: fe80::a00:27ff:fe70:1d79/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:100124 errors:0 dropped:0 overruns:0 frame:0
TX packets:8795 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:12986638 (12.3 MiB) TX bytes:6452270 (6.1 MiB)
lo Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
inet6 addr: ::1/128 Scope:Host
UP LOOPBACK RUNNING MTU:16436 Metric:1
RX packets:1303 errors:0 dropped:0 overruns:0 frame:0
TX packets:1303 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:303973 (296.8 KiB) TX bytes:303973 (296.8 KiB)
[root@localhost tftpboot]# ifconfig eth6 promisc
[root@localhost tftpboot]# ifconfig
eth6 Link encap:Ethernet HWaddr 08:00:27:70:1D:79
inet6 addr: fe80::a00:27ff:fe70:1d79/64 Scope:Link
UP BROADCAST RUNNING PROMISC MULTICAST MTU:1500 Metric:1
RX packets:100154 errors:0 dropped:0 overruns:0 frame:0
TX packets:8795 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:13007885 (12.4 MiB) TX bytes:6452270 (6.1 MiB)
lo Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
inet6 addr: ::1/128 Scope:Host
UP LOOPBACK RUNNING MTU:16436 Metric:1
RX packets:1303 errors:0 dropped:0 overruns:0 frame:0
TX packets:1303 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:303973 (296.8 KiB) TX bytes:303973 (296.8 KiB)
[root@localhost tftpboot]#
二、通過C語言方式編程來實現
#include <stdio.h>

#include <unistd.h>

#include <sys/socket.h>

#include <netinet/in.h>

#include <arpa/inet.h>

#include <errno.h>

#include <linux/if_ether.h>

#include <net/if.h>

#include <sys/ioctl.h>

#include <string.h>

#define ETH_NAME "eth1"

int do_promisc(void) {

int f, s;

struct ifreq ifr;

if ( (f=socket(PF_PACKET, SOCK_RAW, htons(ETH_P_ALL)))<0){

return -1;

}

strcpy(ifr.ifr_name, ETH_NAME);

if ((s = ioctl(f, SIOCGIFFLAGS, &ifr))<0){

close(f);

return-1;

}

if(ifr.ifr_flags & IFF_RUNNING){

printf("eth link up\n");

}else{

printf("eth link down\n");

}

ifr.ifr_flags |= IFF_PROMISC;

if ((s = ioctl(f, SIOCSIFFLAGS, &ifr)) < 0){

return -1;

}

printf("Setting interface ::: %s ::: to promisc\n\n", ifr.ifr_name);

return 0;

}

int check_nic(void)

{

struct ifreq ifr;

int skfd = socket(AF_INET, SOCK_DGRAM, 0);

strcpy(ifr.ifr_name, ETH_NAME);

if (ioctl(skfd, SIOCGIFFLAGS, &ifr) < 0)

{

close(skfd);

return -1;

}

if(ifr.ifr_flags & IFF_RUNNING){

printf("link up\n");

close(skfd);

return 0; // 網卡已插上網線

}else {

printf("link down\n");

close(skfd);

return -1;

}

}

int main(void) {

do_promisc();

return 0;

}

G. 混雜模式的linux下通過C設置混雜模式(以eth0舉例)

char *eth_name = eth0; //對網卡eth0進行混雜設置
struct ifreq ethreq; //網路介面結構
strncpy(ethreq.ifr_name, eth_name, IFNAMSIZ); //指定網卡名稱if(-1 == ioctl(sock_raw_fd, SIOCGIFFLAGS, &ethreq)) //獲取網路介面{perror(ioctl);close(sock_raw_fd);exit(-1);}
/*此處用 | 是因為必須在保留原來設置的情況下,在標志位中加入「混雜」方式*/ ethreq.ifr_flags |= IFF_PROMISC;if(-1 == ioctl(sock_raw_fd, SIOCSIFFLAGS, &ethreq)) //將標志位設置寫入{perror(ioctl);close(sock_raw_fd);exit(-1);}

熱點內容
以太坊280x 發布:2025-07-09 23:18:57 瀏覽:719
xrp被盜 發布:2025-07-09 23:18:55 瀏覽:413
btc行情走勢年 發布:2025-07-09 23:14:08 瀏覽:867
幣圈下一次牛市熱點 發布:2025-07-09 22:56:11 瀏覽:708
以太坊發行白皮書 發布:2025-07-09 22:47:54 瀏覽:451
區塊鏈技術開發學習路徑 發布:2025-07-09 22:41:01 瀏覽:13
新晨科技中標銀行區塊鏈 發布:2025-07-09 22:38:22 瀏覽:941
以太坊代幣價格 發布:2025-07-09 22:37:14 瀏覽:172
eth錢包申請視頻 發布:2025-07-09 22:27:49 瀏覽:519
螞蟻z9mini礦機能挖什麼幣 發布:2025-07-09 22:09:54 瀏覽:625