利用winpcap抓包,已经可以抓包,但如何解析包头结构按字段写入文本文件?后面应该添加什么代码?
#define HAVE_REMOTE
#include <pcap.h>

/* packet handler 函数原型 */
void packet_handler(u_char *param, const struct pcap_pkthdr *header, const u_char *pkt_data);

int main()
{
    pcap_if_t *alldevs;
    pcap_if_t *d;
    int inum;
    int i=0;
    pcap_t *adhandle;
    char errbuf[PCAP_ERRBUF_SIZE];

    /* 获取本机设备列表 */
    if (pcap_findalldevs_ex(PCAP_SRC_IF_STRING, NULL, &alldevs, errbuf) == -1)
    {
        fprintf(stderr,"Error in pcap_findalldevs: %s\n", errbuf);
        exit(1);
    }

    /* 打印列表 */
    for(d=alldevs; d; d=d->next)
    {
        printf("%d. %s", ++i, d->name);
        if (d->description)
            printf(" (%s)\n", d->description);
        else
            printf(" (No description available)\n");
    }

    if(i==0)
    {
        printf("\nNo interfaces found! Make sure WinPcap is installed.\n");
        return -1;
    }

    printf("Enter the interface number (1-%d):",i);
    scanf("%d", &inum);

    if(inum < 1 || inum > i)
    {
        printf("\nInterface number out of range.\n");
        /* 释放设备列表 */
        pcap_freealldevs(alldevs);
        return -1;
    }

    /* 跳转到选中的适配器 */
    for(d=alldevs, i=0; i< inum-1 ; d=d->next, i++);

    /* 打开设备 */
    if ( (adhandle= pcap_open(d->name,          // 设备名
                              65535,            // 65535保证能捕获到不同数据链路层上的每个数据包的全部内容
                              PCAP_OPENFLAG_PROMISCUOUS,    // 混杂模式
                              1000,             // 读取超时时间
                              NULL,             // 远程机器验证
                              errbuf            // 错误缓冲池
                             ) ) == NULL)
    {
        fprintf(stderr,"\nUnable to open the adapter. %s is not supported by WinPcap\n", d->name);
        /* 释放设备列表 */
        pcap_freealldevs(alldevs);
        return -1;
    }

    printf("\nlistening on %s...\n", d->description);

    /* 释放设备列表 */
    pcap_freealldevs(alldevs);

    /* 开始捕获 */
    pcap_loop(adhandle, 0, packet_handler, NULL);

    return 0;
}


/* 每次捕获到数据包时,libpcap都会自动调用这个回调函数 */
void packet_handler(u_char *param, const struct pcap_pkthdr *header, const u_char *pkt_data)
{
    struct tm *ltime;
    char timestr[16];
    time_t local_tv_sec;

    /* 将时间戳转换成可识别的格式 */
    local_tv_sec = header->ts.tv_sec;
    ltime=localtime(&local_tv_sec);
    strftime( timestr, sizeof timestr, "%H:%M:%S", ltime);

    printf("%s,%.6ld len:%d\n", timestr, header->ts.tv_usec, header->len);

}

1个回答

weixin_44679926
觌氅 有没有抓ip包的教程?谢谢,我想再学习学习
3 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
小白求助:在网上下winpcap抓包软件,但内容显示乱码了,请问哪位大神可以解答!
![图片说明](https://img-ask.csdn.net/upload/201604/27/1461717900_175102.png)
请问,使用winpcap抓包,怎么设置可以使到达一个数据包后,应用程序尽快获取?
各位大神,请教一下,使用winpcap抓包,怎么设置可以使网卡到达一个数据包后,应用程序尽快获取?
使用WINPCAP抓包可以跳过网卡选择么?
不显式的选择,内部自动选择,可以么? 可以的话应该怎么实现?
winpcap发送数据包的问题
我用winpcap编写发包程序,用的是发送队列发的,但文件大小大于150M,就发送不了,抓包工具也抓不到包,这是什么原因,咋解决,急需求解
winpcap与socket相关问题求助
想利用winpcap抓取数据包。去除mac与ip头后利用socket发送到本机应用程序。不知这样做是否可行。暂时不考虑rawsocket抓包
winpcap 发送队列发送数据包的问题
我用winpcap的发送队列发送数据包,文件大小100M左右可以正常发送,抓包工具可以抓到包,但200M左右就发不了,运行黑框界面一闪而过,这是为什么,咋解决,
WinpCap抓不到ARP的包。禁用蓝牙后启用蓝牙就又收的到。但是只是这一小会可以收到。
我用WireShark可以抓到ARP包,但是用自己写的代码抓不到ARP包。抓IP之类的还是可以抓到。 过滤器设置的就是ARP。 ------------------------------------------------------------------------------- 应该是一些常规代码: { pcap_if_t *alldevs; pcap_if_t *d; int inum; int i = 0; pcap_t *adhandle; char errbuf[PCAP_ERRBUF_SIZE]; u_int netmask; char packet_filter[] = "arp"; struct bpf_program fcode; /* 获得设备列表 */ if (pcap_findalldevs_ex(PCAP_SRC_IF_STRING, NULL, &alldevs, errbuf) == -1) { fprintf(stderr, "Error in pcap_findalldevs: %s\n", errbuf); exit(1); } /* 打印列表 */ for (d = alldevs; d; d = d->next) { printf("%d. %s", ++i, d->name); if (d->description) printf(" (%s)\n", d->description); else printf(" (No description available)\n"); } if (i == 0) { printf("\nNo interfaces found! Make sure WinPcap is installed.\n"); return -1; } printf("Enter the interface number (1-%d):", i); scanf_s("%d", &inum); if (inum < 1 || inum > i) { printf("\nInterface number out of range.\n"); /* 释放设备列表 */ pcap_freealldevs(alldevs); return -1; } /* 跳转到已选设备 */ for (d = alldevs, i = 0; i< inum - 1; d = d->next, i++); /* 打开适配器 */ if ((adhandle = pcap_open(d->name, // 设备名 65536, // 要捕捉的数据包的部分 // 65535保证能捕获到不同数据链路层上的每个数据包的全部内容 PCAP_OPENFLAG_PROMISCUOUS, // 混杂模式 0, // 读取超时时间 NULL, // 远程机器验证 errbuf // 错误缓冲池 )) == NULL) { fprintf(stderr, "\nUnable to open the adapter. %s is not supported by WinPcap\n"); /* 释放设备列表 */ pcap_freealldevs(alldevs); return -1; } /* 检查数据链路层,为了简单,我们只考虑以太网 */ if (pcap_datalink(adhandle) != DLT_EN10MB) { fprintf(stderr, "\nThis program works only on Ethernet networks.\n"); /* 释放设备列表 */ pcap_freealldevs(alldevs); return -1; } if (d->addresses != NULL) /* 获得接口第一个地址的掩码 */ netmask = ((struct sockaddr_in *)(d->addresses->netmask))->sin_addr.S_un.S_addr; else /* 如果接口没有地址,那么我们假设一个C类的掩码 */ netmask = 0xffffff; //编译过滤器 if (pcap_compile(adhandle, &fcode, packet_filter, 1, netmask) <0) { fprintf(stderr, "\nUnable to compile the packet filter. Check the syntax.\n"); /* 释放设备列表 */ pcap_freealldevs(alldevs); return -1; } //设置过滤器 if (pcap_setfilter(adhandle, &fcode)<0) { fprintf(stderr, "\nError setting the filter.\n"); /* 释放设备列表 */ pcap_freealldevs(alldevs); return -1; } printf("\nlistening on %s...\n", d->description); /* 释放设备列表 */ pcap_freealldevs(alldevs); /* 开始捕捉 */ pcap_loop(adhandle, 3, packet_handler2, NULL); system("pause"); return 0; }
VC++ 6.0 做的网络抓包程序 已上传至http://pan.baidu.com/s/1sZrrX
使用winpcap和VC6.0做的抓包程序cutesniffer, 出现LINK:2005错误 不知道问题出在哪里,求指点
基于winpcap的arp中间人攻击(使用C++),目前无法转发数据包
为了方便叙述,称目标机器为B机器。本机为A机器。<br> 实现思路如下:<br> A机器一直向路由发送arp请求包,问路由的MAC地址,但是arp包里的发送方IP是B机器的,这样就完成了欺骗路由。达到获取B机器数据返回包的目的。<br> 我程序抓包时候解析包了,判断出来HTTP包打印到屏幕上<br> 目前可以成功的看到B机器打开网站后,从路由返回过来的HTTP包<br> 现在的问题主要有两个:<br> <b>1.设置过滤器的问题</b><br> 利用winpcap设置过滤器后,就看不到B机器的包了,不知道是不是过滤器语法有问题。但是编译语法时候也没提示错误。<br> 过滤语法如下:<br> <b>dst host 192.168.1.100(这是B的IP地址)</b> 下面放上代码,本人菜鸟,写的很渣,还请各位大牛不吝赐教啊!<br> 编译环境:VC6.0+WIN7+winpcap4.x<br>
Android手机上采用jpcap进行抓包
最近要做Android手机上抓包的项目,主要是在手机上对环境中无线包进行捕获并加以解析,因为看过一些文章说用jpcap要事先安装winpcap/libpcap,所以在Windows下尝试了一下(我用的eclipse测试的),是可以的,但是想把程序移植到Android程序中就会有问题,首先是动态库的问题,因为jpcap有两个文件,一个jar和一个dll文件,在Windows下把他们放到jdk里再导入面就可用以,但是在Androidstudio中这两个文件不知道怎么用,查了一下好像是dll不能再Android中使用,又下载了Linux下的jpcap中so文件,把jar和so放到libs下目录下算是没有报错了,但是调用JpcapCaptor.getDeviceList();时一直获取不到网卡,我在想会不会是Android手机上也需要装是winpcap/libpcap的问题,痛苦好几天了,实在解决不了了,跪求各路大神帮忙解决一下,没币了所以没开悬赏。
关于winpcap中获取活动网卡问题
使用winpcap写抓包程序时,获取到网络适配器列表后,如何只打开正在使用(即活动的适配器)的适配器呢?
基于WinPcap,编写一个简单的数据包捕获程序
* 功能要求: 1) 要求提供图形界面(类似Wireshark),可以捕获网络数据包;提供包过滤功能,可以输入过滤表达式;可以指定时段抓包;显示指定数据包的内容; 2) 提供网络数据包统计功能;提供输入IP地址,向指定IP地址发送数据包 3) 提供数据转储功能,将捕获到的数据包存储到磁盘文件,并可以读取转储的文件 4) 界面美观、大方
小白求助:winpcap的抓包软件,显示内容的Edit框只能显示一行。望大神求解!
(附程序图)显示内容的Edit框只显示一行,请问问题出在哪儿,望大神求解! 不知是不是edit只能显示一行内容,后面的内容覆盖了前面的内容![图片说明](https://img-ask.csdn.net/upload/201604/28/1461844516_358599.png)![图片说明](https://img-ask.csdn.net/upload/201604/28/1461844604_123954.png)
这个写什么代码可以使抓包60s或者按回车键停止?
``` #define HAVE_REMOTE #include <pcap.h> #include <windows.h> /* packet handler 函数原型 */ void packet_handler(u_char *param, const struct pcap_pkthdr *header, const u_char *pkt_data); int main() { pcap_if_t *alldevs; pcap_if_t *d; int inum; int i=0; pcap_t *adhandle; char errbuf[PCAP_ERRBUF_SIZE]; /* 获取本机设备列表 */ if (pcap_findalldevs_ex(PCAP_SRC_IF_STRING, NULL, &alldevs, errbuf) == -1) { fprintf(stderr,"Error in pcap_findalldevs: %s\n", errbuf); exit(1); } /* 打印列表 */ for(d=alldevs; d; d=d->next) { printf("%d. %s", ++i, d->name); if (d->description) printf(" (%s)\n", d->description); else printf(" (No description available)\n"); } if(i==0) { printf("\nNo interfaces found! Make sure WinPcap is installed.\n"); return -1; } printf("Enter the interface number (1-%d):",i); scanf("%d", &inum); if(inum < 1 || inum > i) { printf("\nInterface number out of range.\n"); /* 释放设备列表 */ pcap_freealldevs(alldevs); return -1; } /* 跳转到选中的适配器 */ for(d=alldevs, i=0; i< inum-1 ; d=d->next, i++); /* 打开设备 */ if ( (adhandle= pcap_open(d->name, // 设备名 65535, // 65535保证能捕获到不同数据链路层上的每个数据包的全部内容 PCAP_OPENFLAG_PROMISCUOUS, // 混杂模式 1000, // 读取超时时间 NULL, // 远程机器验证 errbuf // 错误缓冲池 ) ) == NULL) { fprintf(stderr,"\nUnable to open the adapter. %s is not supported by WinPcap\n", d->name); /* 释放设备列表 */ pcap_freealldevs(alldevs); return -1; } printf("\nlistening on %s...\n", d->description); /* 释放设备列表 */ pcap_freealldevs(alldevs); /* 开始捕获 */ pcap_loop(adhandle, , packet_handler, NULL); return 0; } /* 每次捕获到数据包时,libpcap都会自动调用这个回调函数 */ void packet_handler(u_char *param, const struct pcap_pkthdr *header, const u_char *pkt_data) { struct tm *ltime; char timestr[16]; time_t local_tv_sec; /* 将时间戳转换成可识别的格式 */ local_tv_sec = header->ts.tv_sec; ltime=localtime(&local_tv_sec); strftime( timestr, sizeof timestr, "%H:%M:%S", ltime); printf("%s,%.6ld len:%d\n", timestr, header->ts.tv_usec, header->len); } ```
pcap和winpcap一样吗?
libpcap和winpcap的函数名、参数、功能全一样吗?是不是只要学一种,另一种就可以不用学了?
最近做项目,需要用到winpcap,但是速度一直达不到要求,请问各位大侠,求解决办法
项目中需要使用winpap抓包,但是速度不够快,千兆网下只能达到100兆左右的速度,暂时没有找到解决办法。
用winpcap编程,怎样再加上一部分,源mac和目的mac的输出
#define HAVE_REMOTE #include <pcap.h> #include <iostream.h> //定义IP地址 typedef struct ip_address { u_char byte1; u_char byte2; u_char byte3; u_char byte4; }ip_address; //定义mac typedef struct ip_mac { u_char byte5; u_char byte6; u_char byte7; u_char byte8; u_char byte9; u_char byte10; u_char byte11; u_char byte12; }ip_mac; //IP头结构 typedef struct ip_header { u_char ver_ihl; /* 识别IP协议版本(0100是IPv4,0110是Ipv6)+网络首部长度(4 bits)*/ u_char tos; /* 服务类型*/ u_short tlen; /* 总长*/ u_short identification; /*识别*/ u_short flags_fo; /*标记(3 bits)+片段偏移(13 bits)*/ u_char ttl; /*生存时间*/ u_char proto; /*标识上层使用的协议*/ u_short crc; /*头部检验*/ ip_address saddr;/*源IP地址*/ ip_address daddr;/*目的IP地址*/ ip_mac smac; ip_mac dmac; u_int op_pad; /*可选项*/ }ip_header; //UDP头结构 typedef struct udp_header { u_char sport1; u_char sport2; /*源端口*/ u_char dport1; u_char dport2; /*目的端口*/ u_char len1; u_char len2; /*数据包长度*/ u_char crc1; u_char crc2; /*检查和*/ }udp_header; //定义packet handler void packet_handler(u_char *param/*数据包存储的文件指针*/, const struct pcap_pkthdr *header, const u_char *pkt_data); int main() { pcap_if *device; pcap_if *d; int inum; int i = 0; pcap_t *adhandle; char errbuf[PCAP_ERRBUF_SIZE]; u_int netmask; char packet_filter[] = "ip"; struct bpf_program fcode; //↓↓↓从本地检索设备表↓↓↓ if (/*获取设备列表函数*/pcap_findalldevs_ex(PCAP_SRC_IF_STRING, NULL /*不需要授权*/, &device/*搜索到的设备存在这里*/, errbuf/*如果有错误,存在这个错误缓冲区*/) == -1) { cout<<"Error in pcap_findalldevs_ex:"<<endl<<errbuf; exit(1); } //↓↓展示列表↓↓ for (d=device; d!=NULL; d=d->next) { //↓↓↓其中这是展示设备名字↓↓↓ cout<<++i<<"--"<<d->name<<endl; //↓↓↓其中这是设备的描述↓↓↓ if (d->description) { cout<<d->description<<endl; } else { cout<<"No description available)"<<endl; } } if (i == 0) { cout<<endl<<"No interfaces found! Make sure WinPcap is installed."<<endl; return -1; } //选择一个适配器 cout<<"输入接口号"<<"1-"<<i<<":"<<endl; cin>>inum; if (inum<1||inum>i) { cout<<endl<<"超出可选范围"<<endl; //释放设备列表 pcap_freealldevs(device); return -1; } //跳转到所选适配器 for (d=device,i=0;i<inum-1;d=d->next,++i); //打开设备 if ((adhandle=pcap_open(d->name, /*要打开的源名*/ 65536, /*65535保证能捕获到每个链路层上的数据*/ PCAP_OPENFLAG_PROMISCUOUS, /*混杂模式*/ 1000, /*等待1秒,让更多的数据包到来后从OS内核一次读多个数据包*/ NULL, /*不是远程抓包*/ errbuf /*存放错误的缓冲区*/ )/*返回给device一个pcap_t指针,*/ ) == NULL) { cout<<stderr<<endl<<d->name<<"不能被WinPcap支持"<<endl; pcap_freealldevs(device); return -1; } if (pcap_datalink(adhandle) != DLT_EN10MB/*以太网10m*/) { fprintf(stderr, "\nThis program works only on Ethernet networks.\n"); /*不是简单以太网,释放*/ pcap_freealldevs(device); return -1; } if (d->addresses != NULL) { /*检索第一个地址接口的掩码*/ netmask=((struct sockaddr_in *)(d->addresses->netmask))->sin_addr.S_un.S_addr; } else { /*如果接口没有地址,我们假设是在一个c++网络*/ netmask = 0xffffffff; } if (pcap_compile(adhandle, &fcode, packet_filter,1, netmask) < 0) { fprintf(stderr, "\nUnable to compile the packet filter. Check the syntax.\n"); /*释放*/ pcap_freealldevs(device); return -1; } if (pcap_setfilter(adhandle, &fcode) < 0) { fprintf(stderr, "\nError setting the filter.\n"); /*释放*/ pcap_freealldevs(device); return -1; } cout<<endl<<"listening on "<<d->description<<endl; //此刻我们不再需要这些设备了,释放掉 pcap_freealldevs(device); //开始抓包 pcap_loop(adhandle/*句柄*/,50/*?*/,packet_handler,NULL); return 1; } //回调函数,调用每个被Libpcap传入的数据包 void packet_handler(u_char *param,const struct pcap_pkthdr *header/*得到时间值,数据包长度*/, const u_char *pkt_data/*获得IP首部的位置,UDP首部的位置*/) { struct tm *ltime; char timestr[16]; ip_header* ih; udp_header* uh; u_int ip_len; u_int ip_proto;//------------ int a=0; //时间可视化 ltime=localtime(&header->ts.tv_sec); strftime(timestr,sizeof(timestr),"%H:%M:%S",ltime); cout<<"抓包时间: "<<timestr<<endl<<"包长: "<<header->len<<"字节"<<endl; ih=(ip_header*)(pkt_data); cout<<"以下是原始数据"<<endl<<"-----------------------------------------------"<<endl; for(a;a<=header->len;++a) { ih=(ip_header*)(pkt_data+a-12); } cout<<endl<<"-----------------------------------------------"<<endl; //检索ip首部 ih=(ip_header*)(pkt_data+14); //14字节是以太网mac帧的帧头长度,14=6目的地址+6源地址+2类型说明。 ip_len=(ih->ver_ihl & 0xf)*4;//取首部长度 ip_proto=ih->proto; uh=(udp_header*)((u_char*)ih+ip_len); printf("该数据从 -%d.%d.%d.%d- 发送到 -%d.%d.%d.%d-\n", ih->saddr.byte1, ih->saddr.byte2, ih->saddr.byte3, ih->saddr.byte4, /*sport,*/ ih->daddr.byte1, ih->daddr.byte2, ih->daddr.byte3, ih->daddr.byte4); /*dport*/ ih=(ip_header*)(pkt_data+14); //14字节是以太网mac帧的帧头长度,14=6目的地址+6源地址+2类型说明。 ip_len=(ih->ver_ihl & 0xf)*6;//取首部长度 ip_proto=ih->proto; uh=(udp_header*)((u_char*)ih+ip_len); printf("该数据从 -%.2x.%.2x.%.2x.%.2x.%.2x.%.2x- 发送到 -%.2x.%.2x.%.2x.%.2x.%.2x.%.2x-\n", ih->smac.byte5, ih->smac.byte6, ih->smac.byte7, ih->smac.byte8, ih->dmac.byte9, ih->dmac.byte10, ih->dmac.byte11, ih->dmac.byte12, /*sport,*/ ih->dmac.byte5, ih->dmac.byte6, ih->dmac.byte7, ih->dmac.byte8, ih->dmac.byte9, ih->dmac.byte10, ih->dmac.byte11, ih->dmac.byte12); /*dport*/ if (ih->proto==17) { cout<<"上层协议使用了-UDP-协议"<<endl; printf("源端口号:%d,目的端口:%d,头部长度:%d,头部校验:0x%x\n\n",uh->sport1*256+uh->sport2,uh->dport1*256+uh->dport2,uh->len1*256+uh->len2,uh->crc1*256+uh->crc2); } if (ih->proto==6) {cout<<"上层协议使用了-TCP-协议"<<endl<<endl;} }
802.1X认证请求失败,可能是版本不对,求大神指点迷津
我请求802.1X认证过程中失败(用winpcap),用wireshark抓包发现我这边请求Start的Version是802.1X-2004(2), ![Start](https://img-ask.csdn.net/upload/201804/19/1524105943_454209.png) 但是服务器给我回的Version却是802.1X-2001(1),如图: ![Response,Identity](https://img-ask.csdn.net/upload/201804/19/1524106149_152735.png) 最终服务器给我返回的是失败,如图: ![Failure](https://img-ask.csdn.net/upload/201804/19/1524106057_235704.png) 不知道是什么原因造成的,希望大神给答疑解惑,谢谢
TCP协议的手游数据怎么怎么修改或重新发送
通过抓包工具抓取了一款手游的服务端返回数据,是TCP协议的返回数据,想重复发送这些响应数据,用什么方法或软件?我已试用过FIDDLER,因不能抓取手游TCP协议内容,无法进行修改和重新发送。 感谢CAOZHY的帮助,我用wireshark抓的包,wireshark只能分析,不能重新发送或模拟,另外你说的winpcap怎么用,我在网上查了查没看明白。 谢谢大内群英帮忙,近日用WPE在研究,还没有结果。
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
死磕YOLO系列,YOLOv1 的大脑、躯干和手脚
YOLO 是我非常喜欢的目标检测算法,堪称工业级的目标检测,能够达到实时的要求,它帮我解决了许多实际问题。 这就是 YOLO 的目标检测效果。它定位了图像中物体的位置,当然,也能预测物体的类别。 之前我有写博文介绍过它,但是每次重新读它的论文,我都有新的收获,为此我准备写一个系列的文章来详尽分析它。这是第一篇,从它的起始 YOLOv1 讲起。 YOLOv1 的论文地址:https://www.c
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的 回答 - Bravo Yeung,获得该问题下回答中得最高赞(236赞和1枚专业勋章),对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalk
记一次腾讯面试:进程之间究竟有哪些通信方式?如何通信? ---- 告别死记硬背
有一次面试的时候,被问到进程之间有哪些通信方式,不过由于之前没深入思考且整理过,说的并不好。想必大家也都知道进程有哪些通信方式,可是我猜很多人都是靠着”背“来记忆的,所以今天的这篇文章,讲给大家详细着讲解他们是如何通信的,让大家尽量能够理解他们之间的区别、优缺点等,这样的话,以后面试官让你举例子,你也能够顺手拈来。 1、管道 我们来看一条 Linux 的语句 netstat -tulnp | gr...
20行Python代码爬取王者荣耀全英雄皮肤
引言 王者荣耀大家都玩过吧,没玩过的也应该听说过,作为时下最火的手机MOBA游戏,咳咳,好像跑题了。我们今天的重点是爬取王者荣耀所有英雄的所有皮肤,而且仅仅使用20行Python代码即可完成。 准备工作 爬取皮肤本身并不难,难点在于分析,我们首先得得到皮肤图片的url地址,话不多说,我们马上来到王者荣耀的官网: 我们点击英雄资料,然后随意地选择一位英雄,接着F12打开调试台,找到英雄原皮肤的图片
网络(8)-HTTP、Socket、TCP、UDP的区别和联系
TCP/IP协议是传输层协议,主要解决数据如何在网络中传输,而HTTP是应用层协议,主要解决如何包装数据。 一、TCP与UDP的不同 1. 是否需要建立连接。 UDP在传送数据之前不需要先建立连接;TCP则提供面向连接的服务; 2. 是否需要给出确认 对方的传输层在收到UDP报文后,不需要给出任何确认,而 TCP需要给出确认报文,要提供可靠的、面向连接的传输服务。 3.虽然UDP不提供可靠交...
简明易理解的@SpringBootApplication注解源码解析(包含面试提问)
欢迎关注文章系列 ,关注我 《提升能力,涨薪可待》 《面试知识,工作可待》 《实战演练,拒绝996》 欢迎关注我博客,原创技术文章第一时间推出 也欢迎关注公 众 号【Ccww笔记】,同时推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《提升能力,涨薪可待篇》- @SpringBootApplication注解源码解析 一、@SpringBootApplication 的作用是什
防劝退!数据结构和算法难理解?可视化动画带你轻松透彻理解!
大家好,我是 Rocky0429,一个连数据结构和算法都不会的蒟蒻… 学过数据结构和算法的都知道这玩意儿不好学,没学过的经常听到这样的说法还没学就觉得难,其实难吗?真难! 难在哪呢?当年我还是个小蒟蒻,初学数据结构和算法的时候,在忍着枯燥看完定义原理,之后想实现的时候,觉得它们的过程真的是七拐八绕,及其难受。 在简单的链表、栈和队列这些我还能靠着在草稿上写写画画理解过程,但是到了数论、图...
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
开挂的人生!那些当选院士,又是ACM/IEEE 双料Fellow的华人学者们
昨日,2019年两院院士正式官宣,一时间抢占了各大媒体头条。 朋友圈也是一片沸腾,奔走相告,赶脚比自己中了大奖还嗨皮! 谁叫咱家导师就是这么厉害呢!!! 而就在最近,新一年度的IEEE/ACM Fellow也将正式公布。 作为学术届的顶级荣誉,不自然地就会将院士与Fellow作比较,到底哪个含金量更高呢? 学术君认为,同样是专业机构对学者的认可,考量标准不一,自然不能一概而论。 但...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
Python语言高频重点汇总
Python语言高频重点汇总 GitHub面试宝典仓库——点这里跳转 文章目录Python语言高频重点汇总**GitHub面试宝典仓库——点这里跳转**1. 函数-传参2. 元类3. @staticmethod和@classmethod两个装饰器4. 类属性和实例属性5. Python的自省6. 列表、集合、字典推导式7. Python中单下划线和双下划线8. 格式化字符串中的%和format9.
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
代码详解:如何用Python快速制作美观、炫酷且有深度的图表
全文共12231字,预计学习时长35分钟生活阶梯(幸福指数)与人均GDP(金钱)正相关的正则图本文将探讨三种用Python可视化数据的不同方法。以可视化《2019年世界幸福报告》的数据为例,本文用Gapminder和Wikipedia的信息丰富了《世界幸福报告》数据,以探索新的数据关系和可视化方法。《世界幸福报告》试图回答世界范围内影响幸福的因素。报告根据对“坎特里尔阶梯问题”的回答来确定幸...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
(经验分享)作为一名普通本科计算机专业学生,我大学四年到底走了多少弯路
今年正式步入了大四,离毕业也只剩半年多的时间,回想一下大学四年,感觉自己走了不少弯路,今天就来分享一下自己大学的学习经历,也希望其他人能不要走我走错的路。 (一)初进校园 刚进入大学的时候自己完全就相信了高中老师的话:“进入大学你们就轻松了”。因此在大一的时候自己学习的激情早就被抛地一干二净,每天不是在寝室里玩游戏就是出门游玩,不过好在自己大学时买的第一台笔记本性能并不是很好,也没让我彻底沉...
如何写一篇技术博客,谈谈我的看法
前言 只有光头才能变强。 文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y 我一直推崇学技术可以写技术博客去沉淀自己的知识,因为知识点实在是太多太多了,通过自己的博客可以帮助自己快速回顾自己学过的东西。 我最开始的时候也是只记笔记,认为自己能看得懂就好。但如果想验证自己是不是懂了,可以写成技术博客。在写技术博客的...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
互联网公司的裁员,能玩出多少种花样?
裁员,也是一门学问,可谓博大精深!以下,是互联网公司的裁员的多种方法:-正文开始-135岁+不予续签的理由:千禧一代网感更强。95后不予通过试用期的理由:已婚已育员工更有责任心。2通知接下来要过苦日子,让一部分不肯同甘共苦的员工自己走人,以“兄弟”和“非兄弟”来区别员工。3强制996。员工如果平衡不了工作和家庭,可在离婚或离职里二选一。4不布置任何工作,但下班前必须提交千字工作日报。5不给活干+...
【设计模式】单例模式的八种写法分析
网上泛滥流传单例模式的写法种类,有说7种的,也有说6种的,当然也不排除说5种的,他们说的有错吗?其实没有对与错,刨根问底,写法终究是写法,其本质精髓大体一致!因此完全没必要去追究写法的多少,有这个时间还不如跟着宜春去网吧偷耳机、去田里抓青蛙得了,一天天的....
《面试宝典》:检验是否为合格的初中级程序员的面试知识点,你都知道了吗?查漏补缺
欢迎关注文章系列,一起学习 《提升能力,涨薪可待篇》 《面试知识,工作可待篇》 《实战演练,拒绝996篇》 也欢迎关注公 众 号【Ccww笔记】,原创技术文章第一时间推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《面试知识,工作可待篇》-Java笔试面试基础知识大全 前言 是不是感觉找工作面试是那么难呢? 在找工作面试应在学习的基础进行总结面试知识点,工作也指日可待,欢...
关于研发效能提升的思考
研发效能提升是最近比较热门的一个话题,本人根据这几年的工作心得,做了一些思考总结,由于个人深度有限,暂且抛转引入。 三要素 任何生产力的提升都离不开这三个因素:人、流程和工具,少了其中任何一个因素都无法实现。 人,即思想,也就是古人说的“道”,道不同不相为谋,是制高点,也是高层建筑的基石。 流程,即方法,也是古人说的“法”。研发效能的提升,也就是要提高投入产出比,既要增加产出,也要减...
微博推荐算法简述
在介绍微博推荐算法之前,我们先聊一聊推荐系统和推荐算法。有这样一些问题:推荐系统适用哪些场景?用来解决什么问题、具有怎样的价值?效果如何衡量? 推荐系统诞生很早,但真正被大家所重视,缘起于以”facebook”为代表的社会化网络的兴起和以“淘宝“为代表的电商的繁荣,”选择“的时代已经来临,信息和物品的极大丰富,让用户如浩瀚宇宙中的小点,无所适从。推荐系统迎来爆发的机会,变得离用户更近: 快...
相关热词 c# 时间比天数 c# oracle查询 c# 主动推送 事件 c# java 属性 c# 控制台 窗体 c# 静态类存值 c#矢量作图 c#窗体调用外部程式 c# enum是否合法 c# 如何卸载引用
立即提问