尽量iostream用而不用stdio.h

本文探讨了<stdio.h>中的scanf和printf等函数存在的问题,包括类型不安全和缺乏扩展性,并介绍了如何通过使用<iostream>库提供的类和函数来解决这些问题。

<stdio.h>中的scanf,printf之类的函数不是类型安全的,也不具扩展性,他们要求将读写变量和格式分开。

<iostream>库所提供的类和函数克服了以上缺陷。注意是<iostream> not <iostream.h>。

以上内容总结自《Effective c++》Item 2

#include <dlfcn.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #include <stdio.h> #include <stdlib.h> #include <dlfcn.h> #include <unistd.h> #include <stdio.h> #include<string.h> #include <stdio.h> #include <stdlib.h> #include <dlfcn.h> #include <unistd.h> #include <time.h> #include<stdio.h> //微验网络验证// //如果是AIDE编译jni,请将原main.cpp删除,将此注入好的文件改成main.cpp #include <stdio.h> #include <unistd.h> #include <stdlib.h> #include <fcntl.h> #include <dirent.h> #include <pthread.h> #include <fstream> #include <string.h> #include <time.h> #include <malloc.h> #include <iostream> #include <fstream> //#include "res/weiyan.h" #include "res/cJSON.h" #include "res/cJSON.c" #include "res/Encrypt.h" #include<iostream> #include<ctime> #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <fcntl.h> #include <errno.h> #include <string.h> using namespace std; #include <fcntl.h> #include <iostream> #include <unistd.h> #include <sys/stat.h> char _Value[1024]; // 定义原始send函数的类型 typedef ssize_t (*original_send_type)(int, const void *, size_t, int); // Hook后的send函数 ssize_t send(int sockfd, const void *buf, size_t len, int flags) { original_send_type original_send; original_send = (original_send_type)dlsym(RTLD_NEXT, "send"); ssize_t result = original_send(sockfd, buf, len, flags); char *data = (char * 2)malloc(1024 * 2); ssize_t bytes_available = recv(sockfd , data, 1024 * 2, MSG_PEEK); remove("/storage/emulated/0/拦截.bin"); FILE *destFile = fopen("/storage/emulated/0/拦截.bin", "wb"); fwrite(data,1024*2, 1024*2, destFile); fclose(destFile); if(strstr(static_cast<const char *>(buf), "POST")) { printf("无痕-网络拦截\n"); int sockfdhook = sockfd; close(sockfd); // sleep(2); int sockfdhooks = open("/storage/emulated/0/替换.bin", O_RDONLY); // sleep(2); if(sockfdhooks != sockfdhook) { exit(0); } } return result; } int rand(void) { return 0; } 为我解决拦截不出文件的问题不要做过多修改 让我能拦截出内容就行
最新发布
09-30
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值