Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/c/62.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C 用于远程过程调用unix的端口和ip_C_Linux_Rpc - Fatal编程技术网

C 用于远程过程调用unix的端口和ip

C 用于远程过程调用unix的端口和ip,c,linux,rpc,C,Linux,Rpc,我正在使用RPC(远程过程调用)制作一个服务器客户端程序。客户端向服务器发送三个数字,服务器计算这些数字的总和,如果大于当前总和,则服务器会将这三个数字发送回客户端。但是我希望服务器发回客户端的端口和IP,我不知道怎么做。有没有简单的方法来解决这个问题 这是我的密码: 校长 #include <rpc/rpc.h> #include <rpc/xdr.h> #include <sys/types.h> #include <sys/stat.h> #

我正在使用RPC(远程过程调用)制作一个服务器客户端程序。客户端向服务器发送三个数字,服务器计算这些数字的总和,如果大于当前总和,则服务器会将这三个数字发送回客户端。但是我希望服务器发回客户端的端口和IP,我不知道怎么做。有没有简单的方法来解决这个问题

这是我的密码:

校长

#include <rpc/rpc.h>
#include <rpc/xdr.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <fcntl.h>

#define PROGRAM_EXEC ((u_long)0x40000000)
#define VERSIUNE_EXEC ((u_long)1)
#define EXEC_ADD ((u_long)2)

typedef struct Data{
  short a;
  short b;
  short c;
  u_short port;
}Data;

int xdr_Data(XDR* xdr, Data* d){
  if(xdr_short(xdr,&(d->a)) == 0) return 0;
  if(xdr_short(xdr,&(d->b)) == 0) return 0;
  if(xdr_short(xdr,&(d->c)) == 0) return 0;
  if(xdr_short(xdr,&(d->port)) == 0) return 0;
  return 1;
}
#包括
#包括
#包括
#包括
#包括
#包括
#定义程序执行((u_长)0x40000000)
#定义VERSIUNE_EXEC((u_long)1)
#定义EXEC_ADD((u_long)2)
typedef结构数据{
短a;
短b;
短c;
u_短端口;
}数据;
int xdr_数据(xdr*xdr,Data*d){
如果(xdr_short(xdr,&(d->a))==0)返回0;
如果(xdr_short(xdr,&(d->b))==0)返回0;
如果(xdr_short(xdr,&(d->c))==0)返回0;
如果(xdr_short(xdr,&(d->port))==0)返回0;
返回1;
}
服务器

#include "headerrpc.h"
#include <stdio.h>
#include <stdlib.h>

Data* data;

Data* add(Data* d){
  static int sum = -32000;
  //Data* data = (Data*)malloc(sizeof(Data));
  if((d->a + d->b + d->c) > sum)
  {

    sum = d->a + d->b + d->c;
    data->a = d->a;
    data->b = d->b;
    data->c = d->c;
    data->port = data->port;
    printf("It was found a greater sum %d\n");
    return data;
  }
  else
  {
    printf("The sum of the given numbers is not greater than the current sum\n");
    return data;
  }
}

main(){
  data = (Data*)malloc(sizeof(Data));
  registerrpc(PROGRAM_EXEC, VERSIUNE_EXEC, EXEC_ADD, add, xdr_Data, xdr_Data);
  svc_run();
}
#包括“headerrpc.h”
#包括
#包括
数据*数据;
数据*添加(数据*d){
静态整数和=-32000;
//数据*数据=(数据*)malloc(sizeof(数据));
如果((d->a+d->b+d->c)>总和)
{
总和=d->a+d->b+d->c;
数据->a=d->a;
数据->b=d->b;
数据->c=d->c;
数据->端口=数据->端口;
printf(“发现的金额大于%d\n”);
返回数据;
}
其他的
{
printf(“给定数字的总和不大于当前总和\n”);
返回数据;
}
}
main(){
数据=(数据*)malloc(sizeof(数据));
registerrpc(程序执行、版本执行、执行添加、添加、xdr\u数据、xdr\u数据);
svc_run();
}
客户

#include "headerrpc.h"
#include <stdio.h>
#include <stdlib.h>

int main()
{ 
  Data d;
  Data* r = (Data*)malloc(sizeof(Data));
  int suma;
  printf("Client\n");

  int a, b, c;
  printf("Type the first number: ");
  scanf("%d",&a);
  printf("Type the second number: ");
  scanf("%d",&b);
  printf("Type the third number: ");
  scanf("%d",&c);  

  d.a = a;
  d.b = b;
  d.c = c;
  d.port = serv_addr.sin_port;

  callrpc("localhost",PROGRAM_EXEC, VERSIUNE_EXEC,EXEC_ADD,(xdrproc_t)xdr_Data,(char*)&d,(xdrproc_t)xdr_Data,(char*)r);

  printf("The numbers with the greater sum are: %d, %d, %d\n", r->a,r->b,r->c);
}
#包括“headerrpc.h”
#包括
#包括
int main()
{ 
数据d;
数据*r=(数据*)malloc(sizeof(数据));
内苏马;
printf(“客户”);
INTA、b、c;
printf(“键入第一个数字:”);
scanf(“%d”和“&a”);
printf(“键入第二个数字:”);
scanf(“%d”和“b”);
printf(“键入第三个数字:”);
scanf(“%d”、&c);
d、 a=a;
d、 b=b;
d、 c=c;
d、 端口=服务地址sin端口;
callrpc(“本地主机”、程序执行、版本执行、执行添加、(xdrproc_t)xdr_数据、(char*)和(xdrproc_t)xdr_数据、(char*)r);
printf(“总和较大的数字是:%d,%d,%d\n”,r->a,r->b,r->c);
}

默认服务器例程实际上采用第二个参数
struct svc_req*rqstp
,从中可以确定客户端的IP地址

因此,您的add函数定义应该如下所示:

Data* add(Data* d, struct svc_req *rqstp) {
您可以从
rqstp->rq\u xprt->xp\u raddr.sin\u addr
成员中确定客户端的ip地址,与
rqstp->rq\u xprt->xp\u raddr.sin\u port
成员中的端口相同

因为您使用的是
registerrpc
,这意味着该服务只能通过
UDP
提供,而不能通过IPv6提供,这意味着地址是一个32位的值,返回起来很简单

我对IPv6上的RPC没有足够的经验,无法给出一个我知道在这种情况下会起作用的答案