私は他の人に配布したいプログラムを書いていますが、ソケットを使用しており、ほとんどのセキュリティソフトウェアはそれをマルウェアとして扱います。ファイアウォールを低くし、プログラムからスキャンを免除するように人々に指示せずに、このプログラムを動作させるにはどうすればよいですか?私のソケットで間違っていることがあるのでしょうか、これは私のプログラムでデジタル証明書を持っていないという問題ですか?セキュリティソフトウェアが私のソケットを嫌う
#include <stdio.h>
#include <stdlib.h>
#include <winsock2.h>
int client(char *ip,int port,SOCKET *sock)
{
struct sockaddr_in addr;
*sock=socket(AF_INET,SOCK_STREAM,IPPROTO_TCP);
addr.sin_family = AF_INET;
addr.sin_addr.s_addr = inet_addr(ip);
addr.sin_port = htons(port);
connect(*sock,(SOCKADDR*)&addr,sizeof(addr));
return 2;
}
void ssend(char *buffer,int len,SOCKET sock)
{
int sent;
int *tmp;
char head[4];
sent=0;
tmp=(int*)&head;
*tmp=htonl(len);
while(sent<4)
{
sent+=send(sock,head,4-sent,0);
}
sent=0;
while(sent<len)
{
sent+=send(sock,buffer,len-sent,0);
}
}
void srecv(char *buffer,int *len,SOCKET sock)
{
char head[4];
recv(sock,head,4,MSG_WAITALL);
*len=ntohl(*((int*)head));
recv(sock,buffer,*len,MSG_WAITALL);
}
int main(int argc,char **argv)
{
WSADATA dat;
WSAStartup(MAKEWORD(2, 2),&dat);
SOCKET sock;
char ip[256];
char msg[1024];
int port;
scanf("%s",ip);
scanf("%d",&port);
printf("%d\n",client(ip,port,&sock));
while(1)
{
scanf("%s",msg);
ssend(msg,strlen(msg),sock);
}
}
わかりやすいコードではありません。私はちょうどCでソケットに足場を得ようとしています。
あなたがしていることを見ることができないと言うのは難しいです。 –
確かに、私のコードで追加します。 –
そのコードはPOSIXソケットを使用していますが、ほとんどのLinuxディストリビューションには、実行ファイルにマルウェアとフラグを立てる "セキュリティソフトウェア"はありません...このプログラムはどのOSで動作するはずですか? – Borealid