亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? rpc.prog.ms

?? 早期freebsd實現
?? MS
?? 第 1 頁 / 共 5 頁
字號:
.sp.IP "\fIServer Side\fP".LPThe server side is a lot simpler than the client side.  Here is theprevious example rewritten to use.I AUTH_DESinstead of.I AUTH_UNIX :.ie t .DS.el .DS L.ft CW.vs 11#include <sys/time.h>#include <rpc/auth_des.h>	. . .	. . .nuser(rqstp, transp)	struct svc_req *rqstp;	SVCXPRT *transp;{	struct authdes_cred *des_cred;	int uid;	int gid;	int gidlen;	int gidlist[10];.ft I	/*	 * we don't care about authentication for null proc	 */.ft CW	if (rqstp->rq_proc == NULLPROC) { 		/* \fIsame as before\fP */	}.ft I	/*	 * now get the uid	 */.ft CW	switch (rqstp->rq_cred.oa_flavor) {	case AUTH_DES:		des_cred =			(struct authdes_cred *) rqstp->rq_clntcred;		if (! netname2user(des_cred->adc_fullname.name,			&uid, &gid, &gidlen, gidlist))		{			fprintf(stderr, "unknown user: %s\n",				des_cred->adc_fullname.name);			svcerr_systemerr(transp);			return;		}		break;	case AUTH_NULL:	default:		svcerr_weakauth(transp);		return;	}.ft I	/*	 * The rest is the same as before 	 */	.ft CW.vs.DENote the use of the routine.I netname2user (),the inverse of.I user2netname ():it takes a network ID and converts to a unix ID..I netname2user () also supplies the group IDs which we don't use in this example,but which may be useful to other UNIX programs..NH 2\&Using Inetd.IX inetd "" "using \fIinetd\fP".LPAn RPC server can be started from.I inetdThe only difference from the usual code is that the servicecreation routine should be called in the following form:.ie t .DS.el .DS L.ft CWtransp = svcudp_create(0);     /* \fIFor UDP\fP */transp = svctcp_create(0,0,0); /* \fIFor listener TCP sockets\fP */transp = svcfd_create(0,0,0);  /* \fIFor connected TCP sockets\fP */.DEsince.I inetpasses a socket as file descriptor 0.Also,.I svc_register()should be called as.ie t .DS.el .DS L.ft CWsvc_register(transp, PROGNUM, VERSNUM, service, 0);.DEwith the final flag as 0,since the program would already be registered by.I inetdRemember that if you want to exitfrom the server process and return control to.I inetyou need to explicitly exit, since.I svc_run()never returns..LPThe format of entries in .I /etc/inetd.conf for RPC services is in one of the following two forms:.ie t .DS.el .DS L.ft CWp_name/version dgram  rpc/udp wait/nowait user server argsp_name/version stream rpc/tcp wait/nowait user server args.DEwhere.I p_nameis the symbolic name of the program as it appears in.I rpc(5) ,.I serveris the program implementing the server,and.I programand.I versionare the program and version numbers of the service.For more information, see.I inetd.conf(5) ..LPIf the same program handles multiple versions,then the version number can be a range,as in this example:.ie t .DS.el .DS L.ft CWrstatd/1-2 dgram rpc/udp wait root /usr/etc/rpc.rstatd.DE.NH 1\&More Examples.sp 1.NH 2\&Versions.IX "versions".IX "RPC" "versions".LPBy convention, the first version number of program.I PROGis.I PROGVERS_ORIGand the most recent version is.I PROGVERSSuppose there is a new version of the.I userprogram that returns an.I "unsigned short"rather than a.I long .If we name this version.I RUSERSVERS_SHORTthen a server that wants to support both versionswould do a double register..ie t .DS.el .DS L.ft CWif (!svc_register(transp, RUSERSPROG, RUSERSVERS_ORIG,  nuser, IPPROTO_TCP)) {	fprintf(stderr, "can't register RUSER service\en");	exit(1);}if (!svc_register(transp, RUSERSPROG, RUSERSVERS_SHORT,  nuser, IPPROTO_TCP)) {	fprintf(stderr, "can't register RUSER service\en");	exit(1);}.DEBoth versions can be handled by the same C procedure:.ie t .DS.el .DS L.ft CW.vs 11nuser(rqstp, transp)	struct svc_req *rqstp;	SVCXPRT *transp;{	unsigned long nusers;	unsigned short nusers2;	switch (rqstp->rq_proc) {	case NULLPROC:		if (!svc_sendreply(transp, xdr_void, 0)) {			fprintf(stderr, "can't reply to RPC call\en");            return (1);		}		return;	case RUSERSPROC_NUM:.ft I		/*         * Code here to compute the number of users         * and assign it to the variable \fInusers\fP		 */.ft CW		nusers2 = nusers;		switch (rqstp->rq_vers) {		case RUSERSVERS_ORIG:            if (!svc_sendreply(transp, xdr_u_long, 		    &nusers)) {                fprintf(stderr,"can't reply to RPC call\en");			}			break;		case RUSERSVERS_SHORT:            if (!svc_sendreply(transp, xdr_u_short, 		    &nusers2)) {                fprintf(stderr,"can't reply to RPC call\en");			}			break;		}	default:		svcerr_noproc(transp);		return;	}}.vs.DE.KS.NH 2\&TCP.IX "TCP".LPHere is an example that is essentially.I rcp.The initiator of the RPC.I sndcall takes its standard input and sends it to the server.I rcvwhich prints it on standard output.The RPC call uses TCP.This also illustrates an XDR procedure that behaves differentlyon serialization than on deserialization..ie t .DS.el .DS L.vs 11.ft I/* * The xdr routine: *		on decode, read from wire, write onto fp *		on encode, read from fp, write onto wire */.ft CW#include <stdio.h>#include <rpc/rpc.h>xdr_rcp(xdrs, fp)	XDR *xdrs;	FILE *fp;{	unsigned long size;	char buf[BUFSIZ], *p;	if (xdrs->x_op == XDR_FREE)/* nothing to free */		return 1;	while (1) {		if (xdrs->x_op == XDR_ENCODE) {			if ((size = fread(buf, sizeof(char), BUFSIZ,			  fp)) == 0 && ferror(fp)) {				fprintf(stderr, "can't fread\en");				return (1);			}		}		p = buf;		if (!xdr_bytes(xdrs, &p, &size, BUFSIZ))			return 0;		if (size == 0)			return 1;		if (xdrs->x_op == XDR_DECODE) {			if (fwrite(buf, sizeof(char), size,			  fp) != size) {				fprintf(stderr, "can't fwrite\en");				return (1);			}		}	}}.vs.DE.KE.ie t .DS.el .DS L.vs 11.ft I/* * The sender routines */.ft CW#include <stdio.h>#include <netdb.h>#include <rpc/rpc.h>#include <sys/socket.h>#include <sys/time.h>main(argc, argv)	int argc;	char **argv;{	int xdr_rcp();	int err;	if (argc < 2) {		fprintf(stderr, "usage: %s servername\en", argv[0]);		exit(-1);	}	if ((err = callrpctcp(argv[1], RCPPROG, RCPPROC,	  RCPVERS, xdr_rcp, stdin, xdr_void, 0) != 0)) {		clnt_perrno(err);		fprintf(stderr, "can't make RPC call\en");		exit(1);	}	exit(0);}callrpctcp(host, prognum, procnum, versnum,           inproc, in, outproc, out)	char *host, *in, *out;	xdrproc_t inproc, outproc;{	struct sockaddr_in server_addr;	int socket = RPC_ANYSOCK;	enum clnt_stat clnt_stat;	struct hostent *hp;	register CLIENT *client;	struct timeval total_timeout;	if ((hp = gethostbyname(host)) == NULL) {		fprintf(stderr, "can't get addr for '%s'\en", host);		return (-1);	}	bcopy(hp->h_addr, (caddr_t)&server_addr.sin_addr,		hp->h_length);	server_addr.sin_family = AF_INET;	server_addr.sin_port =  0;	if ((client = clnttcp_create(&server_addr, prognum,	  versnum, &socket, BUFSIZ, BUFSIZ)) == NULL) {		perror("rpctcp_create");		return (-1);	}	total_timeout.tv_sec = 20;	total_timeout.tv_usec = 0;	clnt_stat = clnt_call(client, procnum,		inproc, in, outproc, out, total_timeout);	clnt_destroy(client);	return (int)clnt_stat;}.vs.DE.ie t .DS.el .DS L.vs 11.ft I/* * The receiving routines */.ft CW#include <stdio.h>#include <rpc/rpc.h>main(){	register SVCXPRT *transp;     int rcp_service(), xdr_rcp(); 	if ((transp = svctcp_create(RPC_ANYSOCK,	  BUFSIZ, BUFSIZ)) == NULL) {		fprintf("svctcp_create: error\en");		exit(1);	}	pmap_unset(RCPPROG, RCPVERS);	if (!svc_register(transp,	  RCPPROG, RCPVERS, rcp_service, IPPROTO_TCP)) {		fprintf(stderr, "svc_register: error\en");		exit(1);	}	svc_run();  /* \fInever returns\fP */	fprintf(stderr, "svc_run should never return\en");}rcp_service(rqstp, transp)	register struct svc_req *rqstp;	register SVCXPRT *transp;{	switch (rqstp->rq_proc) {	case NULLPROC:		if (svc_sendreply(transp, xdr_void, 0) == 0) {			fprintf(stderr, "err: rcp_service");			return (1);		}		return;	case RCPPROC_FP:		if (!svc_getargs(transp, xdr_rcp, stdout)) {			svcerr_decode(transp);			return;		}		if (!svc_sendreply(transp, xdr_void, 0)) {			fprintf(stderr, "can't reply\en");			return;		}		return (0);	default:		svcerr_noproc(transp);		return;	}}.vs.DE.NH 2\&Callback Procedures.IX RPC "callback procedures".LPOccasionally, it is useful to have a server become a client,and make an RPC call back to the process which is its client.An example is remote debugging,where the client is a window system program,and the server is a debugger running on the remote machine.Most of the time,the user clicks a mouse button at the debugging window,which converts this to a debugger command,and then makes an RPC call to the server(where the debugger is actually running),telling it to execute that command.However, when the debugger hits a breakpoint, the roles are reversed,and the debugger wants to make an rpc call to the window program,so that it can inform the user that a breakpoint has been reached..LPIn order to do an RPC callback,you need a program number to make the RPC call on.Since this will be a dynamically generated program number,it should be in the transient range,.I "0x40000000 - 0x5fffffff" .The routine.I gettransient()returns a valid program number in the transient range,and registers it with the portmapper.It only talks to the portmapper running on the same machine as the.I gettransient()routine itself.  The call to.I pmap_set()is a test and set operation,in that it indivisibly tests whether a program numberhas already been registered,and if it has not, then reserves it.  On return, the.I sockpargument will contain a socket that can be usedas the argument to an.I svcudp_create()or.I svctcp_create()call..ie t .DS.el .DS L.ft CW.vs 11#include <stdio.h>#include <rpc/rpc.h>#include <sys/socket.h>gettransient(proto, vers, sockp)	int proto, vers, *sockp;{	static int prognum = 0x40000000;	int s, len, socktype;	struct sockaddr_in addr;	switch(proto) {		case IPPROTO_UDP:			socktype = SOCK_DGRAM;			break;		case IPPROTO_TCP:			socktype = SOCK_STREAM;			break;		default:			fprintf(stderr, "unknown protocol type\en");			return 0;	}	if (*sockp == RPC_ANYSOCK) {		if ((s = socket(AF_INET, socktype, 0)) < 0) {			perror("socket");			return (0);		}		*sockp = s;	}	else		s = *sockp;	addr.sin_addr.s_addr = 0;	addr.sin_family = AF_INET;	addr.sin_port = 0;	len = sizeof(addr);.ft I	/*	 * may be already bound, so don't check for error	 */.ft CW	bind(s, &addr, len)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩电影一区二区三区| 欧美午夜影院一区| 精品视频1区2区3区| www欧美成人18+| 午夜视频在线观看一区二区三区| 国产精品羞羞答答xxdd| 欧美日本在线观看| 亚洲色图丝袜美腿| 风间由美一区二区av101| 日韩亚洲欧美在线| 亚洲午夜激情网站| 色欧美乱欧美15图片| 国产午夜三级一区二区三| 美腿丝袜一区二区三区| 欧美日韩亚洲综合在线| 亚洲精品一卡二卡| 色又黄又爽网站www久久| 国产亚洲欧美一级| 国产一区二区视频在线| 欧美videofree性高清杂交| 婷婷一区二区三区| 欧美三级乱人伦电影| 亚洲欧洲综合另类在线 | 国产精品乱码人人做人人爱| 精品一区二区日韩| 精品国产免费人成电影在线观看四季| 五月天网站亚洲| 欧美人牲a欧美精品| 亚洲成人手机在线| 欧美日韩aaaaaa| 日韩成人精品在线观看| 欧美日韩不卡在线| 日韩av中文字幕一区二区三区| 欧美天天综合网| 日韩在线卡一卡二| 91精品国产一区二区三区蜜臀 | 国产成人在线视频免费播放| 日韩一区二区精品在线观看| 日本欧美一区二区| 欧美一区二区人人喊爽| 激情另类小说区图片区视频区| 精品国产区一区| 成人国产精品免费观看动漫| 亚洲女厕所小便bbb| 在线免费一区三区| 日本女优在线视频一区二区 | 国产一区二区三区在线观看精品| 久久久久久久久97黄色工厂| 成人爽a毛片一区二区免费| 日韩一区有码在线| 欧美老肥妇做.爰bbww| 激情六月婷婷久久| 18涩涩午夜精品.www| 欧美日韩极品在线观看一区| 九色综合狠狠综合久久| 亚洲欧美综合网| 欧美一区二区三区免费在线看| 国内精品写真在线观看| 国产精品成人在线观看| 51午夜精品国产| 成人在线一区二区三区| 一区二区欧美在线观看| 日韩视频123| 波多野结衣中文一区| 日韩精品成人一区二区在线| 久久精品视频免费| 欧美日韩精品欧美日韩精品一 | 亚洲精品国产一区二区精华液 | 亚洲人成网站精品片在线观看| 欧美久久久久久久久中文字幕| 国产在线看一区| 亚洲国产裸拍裸体视频在线观看乱了| 精品国产a毛片| 欧美性做爰猛烈叫床潮| 国产综合色产在线精品| 一区二区日韩电影| 国产日韩综合av| 欧美精品久久99| 成年人国产精品| 日本欧美一区二区| 亚洲激情在线激情| 久久久无码精品亚洲日韩按摩| 91视频免费播放| 国产毛片精品视频| 日韩精品成人一区二区三区| 国产三级精品在线| 精品久久久久99| 欧美老女人第四色| 欧美唯美清纯偷拍| 日本久久电影网| 成人黄色免费短视频| 国产精一品亚洲二区在线视频| 天堂成人免费av电影一区| 中文字幕一区二区三区四区不卡| 91精品国产福利在线观看 | 成人成人成人在线视频| 久久99久久久欧美国产| 亚洲夂夂婷婷色拍ww47| 亚洲免费色视频| ㊣最新国产の精品bt伙计久久| 国产亚洲综合性久久久影院| 91麻豆精品国产91久久久久| 欧美综合久久久| 欧洲av在线精品| 欧美日韩精品一区二区在线播放| 色域天天综合网| 欧美在线播放高清精品| 在线观看91视频| 欧美日韩和欧美的一区二区| 欧美性猛交xxxx乱大交退制版 | 久久成人久久爱| 美女精品一区二区| 蜜臀精品久久久久久蜜臀| 日本中文在线一区| 久久99国产精品麻豆| 韩国一区二区三区| 国产精品99久久久久久宅男| 99视频国产精品| 91麻豆精东视频| 在线亚洲欧美专区二区| 欧美色国产精品| 3atv一区二区三区| 精品奇米国产一区二区三区| 久久久亚洲国产美女国产盗摄| 久久久精品国产99久久精品芒果| 国产亚洲精品精华液| 国产精品理伦片| 一区二区三区精密机械公司| 亚洲影视在线播放| 免费在线一区观看| 国产在线精品不卡| 99久久伊人网影院| 精品1区2区3区| 久久蜜臀中文字幕| 欧美激情在线看| 一级特黄大欧美久久久| 日韩高清一区二区| 丰满岳乱妇一区二区三区| 色狠狠综合天天综合综合| 欧美高清dvd| 亚洲国产激情av| 亚洲国产日韩av| 国产伦精品一区二区三区免费迷| 99久久亚洲一区二区三区青草| 在线观看亚洲a| 国产午夜一区二区三区| 亚洲午夜久久久久久久久电影院| 麻豆91在线播放免费| caoporm超碰国产精品| 日韩视频在线一区二区| 国产精品久久夜| 美女视频一区二区三区| 91免费在线看| 精品sm捆绑视频| 亚洲一区中文在线| 丁香婷婷综合网| 欧美一区在线视频| 亚洲男人的天堂网| 国产伦精品一区二区三区免费| 91成人免费在线| 国产欧美日本一区视频| 日韩一区精品视频| av在线一区二区三区| 精品国产乱码久久久久久浪潮 | 黄色成人免费在线| 欧美性猛交xxxx乱大交退制版| 久久久久国产精品麻豆ai换脸| 亚洲一区二区三区激情| 成人小视频在线| 精品国产乱码久久久久久蜜臀| 亚洲福利视频导航| 91美女在线观看| 国产校园另类小说区| 久久精品免费看| 欧美欧美午夜aⅴ在线观看| **欧美大码日韩| 国产91色综合久久免费分享| 日韩欧美在线综合网| 激情丁香综合五月| 欧美日韩国产精品成人| 综合激情成人伊人| 不卡的av中国片| 国产精品久久久爽爽爽麻豆色哟哟| 久久精品国产99久久6| 91精品在线麻豆| 日韩精品五月天| 在线播放/欧美激情| 亚洲一区二区三区四区在线| av电影在线观看一区| 国产精品美女久久久久久久久| 麻豆一区二区99久久久久| 9191国产精品| 日本欧美在线观看| 日韩欧美一区二区免费| 日本午夜精品一区二区三区电影 | 一本大道久久a久久精品综合| 亚洲国产岛国毛片在线| 国内精品久久久久影院一蜜桃| 久久免费看少妇高潮| 国产91精品露脸国语对白|