《Linux操作系統(tǒng)》課程設(shè)計報告購物管理系統(tǒng)

上傳人:仙*** 文檔編號:28033951 上傳時間:2021-08-22 格式:DOC 頁數(shù):29 大?。?54.50KB
收藏 版權(quán)申訴 舉報 下載
《Linux操作系統(tǒng)》課程設(shè)計報告購物管理系統(tǒng)_第1頁
第1頁 / 共29頁
《Linux操作系統(tǒng)》課程設(shè)計報告購物管理系統(tǒng)_第2頁
第2頁 / 共29頁
《Linux操作系統(tǒng)》課程設(shè)計報告購物管理系統(tǒng)_第3頁
第3頁 / 共29頁

下載文檔到電腦,查找使用更方便

15 積分

下載資源

還剩頁未讀,繼續(xù)閱讀

資源描述:

《《Linux操作系統(tǒng)》課程設(shè)計報告購物管理系統(tǒng)》由會員分享,可在線閱讀,更多相關(guān)《《Linux操作系統(tǒng)》課程設(shè)計報告購物管理系統(tǒng)(29頁珍藏版)》請在裝配圖網(wǎng)上搜索。

1、 河南城建學(xué)院 《Linux操作系統(tǒng)》課程設(shè)計報告 題目:購物管理系統(tǒng) 姓 名: 齊 超 學(xué) 號: 061408139 班 級: 0614081班 指導(dǎo)老師:邵國金、楊斌、魏新紅 專 業(yè): 計算機(jī)科學(xué)與技術(shù) 2011年 09 月 09 日 前 言 隨著Internet國際互聯(lián)網(wǎng)的發(fā)展,越來越多的企業(yè)開始建造自己的網(wǎng)站。基于Internet的信息服務(wù),商務(wù)服務(wù)已經(jīng)成為現(xiàn)代企業(yè)一項不可缺少的內(nèi)容。很多企業(yè)都已不滿足于建

2、立一個簡單的僅僅能夠發(fā)布信息的靜態(tài)網(wǎng)站?,F(xiàn)代企業(yè)需要的是一個功能強(qiáng)大的,能提供完善的電子商務(wù)服務(wù)的動態(tài)商務(wù)網(wǎng)站。 目 錄 系統(tǒng)目的 隨著時代的發(fā)展,信息技術(shù)、Internet/Intranet技術(shù)、數(shù)據(jù)庫技術(shù)的不斷發(fā)展完善,網(wǎng)絡(luò)進(jìn)程的加快,傳統(tǒng)的購物方式也越來越不能滿足人們快節(jié)奏的生活需求,使得企業(yè)的IT部門已經(jīng)認(rèn)識到Internet的優(yōu)勢,電子商務(wù)就是在這樣一個背景下產(chǎn)生發(fā)展起來的。伴隨著電子商務(wù)技術(shù)的不斷成熟,電子商務(wù)的功能也越來越強(qiáng)大,注冊用戶可以在網(wǎng)上搜索購買到自己想要的各種商品,

3、初步讓人們體會到了足不出戶,便可隨意購物的快感。這次的設(shè)計就正是一個電子商務(wù)系統(tǒng)的開發(fā)---網(wǎng)上購物系統(tǒng)。 設(shè)計說明 本系統(tǒng)是一個中小型的電子商務(wù)系統(tǒng)----網(wǎng)上購物系統(tǒng),可以為各類用戶提供方便的在線購物環(huán)境,符合目前國內(nèi)流行的電子商務(wù)模式。用戶可以在系統(tǒng)中實(shí)現(xiàn)驗證、瀏覽商品、搜索查詢商品、下定單、處理定單等功能; 系統(tǒng)的組成有以下幾個子系統(tǒng)組成: 1. 主頁,顯示歡迎界面,提供近期的商品。 3. 查詢系統(tǒng),通過商品類別、名稱來查詢是否有自己需要的商品。 4. 購物車,處理訂購并顯示想要訂購的商品。 5. 用戶身份驗證系統(tǒng)。 6. 用戶資金驗證系統(tǒng)。 系統(tǒng)結(jié)構(gòu)簡介 l

4、 用戶可以瀏覽網(wǎng)站 l 驗證用戶身份 l 提供搜索引擎,使用戶能夠按特定的條件對所需商品進(jìn)行搜索 l 用戶下定單購買商品 l 用戶處理定單 l 用戶資金驗證 l 用戶查看定單處理步驟 系統(tǒng)運(yùn)行環(huán)境配置 操作系統(tǒng):Windows XP,Microsoft SQL server,linux 操作系統(tǒng)。 CPU:沒有很高的要求,只要能夠順利運(yùn)行Windows系列操作系統(tǒng)就可以了。 內(nèi)存:最低配置32MB,建議使用64MB以上內(nèi)存,如果使用Windows 2000或Windows XP建議使

5、用128MB以上內(nèi)存。 硬盤空間:至少需要50MB以上的硬盤空間來安裝所需的組件。 系統(tǒng)數(shù)據(jù)庫介紹 服務(wù)器方數(shù)據(jù)庫表結(jié)構(gòu): 服務(wù)器商品表:商品號,端口號,單價,數(shù)量。 處理記錄:端口號,流水賬號,成功與否。 消費(fèi)表:消費(fèi)表編號,密碼,金額。 中間件第三方表: 端口表:端口號,地址信息。 消費(fèi)記錄表:端口號,流水賬號,消費(fèi)商品號,購買數(shù)量,消費(fèi)編號。 客戶端表: 客戶商品表:商品號,商品名稱,數(shù)量,單價。 消費(fèi)表:端口號

6、,流水賬號,消費(fèi)品號,購買數(shù)量,消費(fèi)編號。 模塊設(shè)計概述 網(wǎng)上商品系統(tǒng)的主要體系結(jié)構(gòu)包括: 數(shù)據(jù)服務(wù)器 linux 操作系統(tǒng)平臺 客戶端 購物系統(tǒng)流程圖: 用戶模塊的程序流圖: 用戶瀏覽商品 選定商品 放入購物車 是否購買 確認(rèn)購買 訂單詳情 商品信息 否 否 否 否 是 是 是 用戶 第三方中間件流程圖: 請求消費(fèi) 判定消費(fèi)卡 購買信息 中間件記錄數(shù)據(jù) 傳入服務(wù)器 判斷資金是否足夠 1. 處理大中資金

7、數(shù)據(jù) 2. 處理服務(wù)器商品數(shù)量 3. 發(fā)出發(fā)貨信息 1. 客戶端商品數(shù)量減少 2. 出貨時間 是否繼續(xù)交易 退 出 退 出 報 錯! 信息無法購買 報 錯! 報 錯! 用戶 N N N N N Y Y Y Y Y N Y 給中間件傳輸 系統(tǒng)其它功 (1) 用戶驗證 用戶一旦成為本網(wǎng)站的會員后,即可在登陸頁面中登陸,用戶只要輸入自己的用戶名和密碼即可實(shí)現(xiàn)登陸。這里有ASP函數(shù)對用戶名和密碼進(jìn)行判斷,以此來保證用戶的合法性為了能更方便地使用網(wǎng)站的各項功能,用戶登錄也是必不可少的。當(dāng)用戶登錄以后,便可進(jìn)行查閱/更改自己的個人資料、修改/

8、處理個人定單等操作。 (2) 購物車 當(dāng)用戶選好自己想要的商品后可把商品放入購物車中,購物車將自動產(chǎn)生相應(yīng)的定單。當(dāng)然,用戶也可以從購物車?yán)飫h除掉選好的商品,而相應(yīng)定單的也會刪除。 (3) 用戶資金驗證 程序代碼 數(shù)據(jù)庫程序代碼: #include #include #include #include #include #include #include #include

9、 #define rec_length 20 void strsplit(char *,char **,char ); main(int argc, char **argv ) { //1 main struct sockaddr_in sin; struct servent *sp; int s,ns,pid; char d=|,tmp[1000],buff[500],cmd[500]; char *service,*log="svr.log"; // char s[]="1234|567|7|90|abcd|efghijklmnop|";

10、 char *str; char *v[100],*h[500]; int i,j,recs,flds,err_code,c,rd_l,wr_l; char *sat[]={ "OKOKOKOK","E_DBinit","E_DBconn","E_DBqry ","E_DBstor", "E_DBnDAT","E_TCPsvr","E_TCPnam","E_TCPsoc","E_TCPcon", "E_TCPsnd","E_TCPrcv","E_TCPbnd","E_TCPlsn","E_TCPacc" }; //declare structu

11、re and vars. MYSQL mysql; MYSQL_RES *result; MYSQL_ROW row; if(argc!=1) service=argv[1]; else { //2 fprintf(stderr,"NO service assigned!\nUsage:\n"); fprintf(stderr,"\t%s server_name!\n",argv[0]); fprintf(stderr,"Note: svr_name is defined in file /etc/services\n");

12、exit(-1); } //2 // sprintf(buf,"touch %s",log);system(buf);// touch or create log if((rd_l=open(log,O_WRONLY|O_CREAT|O_APPEND,0644))==-1) { fprintf(stderr,"Log file %s open error!\a\n",log); exit(-1); } close(rd_l); for(i=0;i<100;i++) v[i]=NULL; // initialize MYSQL st

13、ructure if(mysql_init(&mysql)==NULL) { //2 fprintf(stderr,"Error in mysql_init!\n"); err_code=1; goto end_1; } //2 //connect to DB if(!mysql_real_connect(&mysql,"localhost","root",0,"lyg",0,NULL,0)) { //2 fprintf(stderr,"Error in connection: %s [%d]\n",\ mysql_error(&mysql),

14、mysql_errno(&mysql)); mysql_close(&mysql); err_code=-2; goto end_1; // goto mysql_err; } //2 if((sp=getservbyname(service,"tcp"))==NULL) { //2 fprintf(stderr,"Error: getservbyname"); err_code=6; goto end_1; } //2 if((s=socket(AF_INET,SOCK_STREAM,0))==-1) { //2

15、 fprintf(stderr,"Error: socket create"); err_code=9;goto end_1; } //2 bzero(&sin,sizeof(sin)); sin.sin_port=sp->s_port; if(bind(s,&sin,sizeof(sin))==-1) { //2 fprintf(stderr,"Error: bind"); err_code=13;goto end_1; // close(s); exit(-6); } //2 if(listen(s,5)==-1

16、) { //2 fprintf(stderr,"Error: listen"); err_code=14;goto end_1; // close(s); exit(-6); } //2 while(1) { //2 while fprintf(stderr,"\n\t\t\t Now wait connect ...\n"); if((ns=accept(s,0,0))==-1) { // wait a connection //3 fprintf(stderr,"error: accept"); contin

17、ue; // err_code=14;goto end_1; }//3 err_code=0; if((pid=fork())==-1) { //conneted, and then create child proc//3 fprintf(stderr,"server: fork error!"); close(s); exit(-1); }//3 if(pid!=0) {//parent proce,nothing to do, and to the next loop//3 close(ns); wait

18、(0); continue; }//3 if(pid==0) { // entered child proccedure //3 pid=0 close(s); printf("Receive a client connect:%s\n",argv[1]); if((rd_l=read(ns,buff,500))==0) { //4 fprintf(stderr,"Read nothing from socket:ns\n"); err_code=12;goto end_1; } //4 printf

19、("%s get message from ns: %s\n",argv[0],buff); buff[rd_l]=\0; strcpy(tmp,buff); strsplit(buff,v,d); switch(v[0][0]) { //4 switch case 2: // query(); sprintf(cmd,"SELECT kid,money FROM K WHERE kid=%s and kpwd =%s",v[1],v[2]); //execute query printf("\nCMD=

20、%s\n",cmd); if(mysql_query(&mysql,cmd)!=0) { //5 fprintf(stderr,"Error in query: %s [%d]\n",\ mysql_error(&mysql),mysql_errno(&mysql)); err_code=3;goto end_1; } //5 //get result if((result=mysql_store_result(&mysql))==NULL) { //5 fprintf(stderr,

21、"Error in store_result: %s [%d]\n",\ mysql_error(&mysql),mysql_errno(&mysql)); mysql_free_result(result); err_code=4;goto end_1; } //5 //mysql_err: //sprintf(buff,"%2.2d|",err_code); if(err_code!=0) goto end_1; recs=mysql_num_rows(result); row=mysql_f

22、etch_row(result); sprintf(buff,"%d|%s",recs,row[1]); double money; printf("-----%s------",buff); //money=row[1]; /* if(recs==1) write(ns,"1",wr_l); else write(ns,"0",wr_l); flds=mysql_num_fields(result); for(i=0

23、;i

24、ns error!\n"); close(ns); exit(-4); } //5 char rebuf[500],rep[500],repp[500]; if((rd_l=read(ns,rebuf,500))==0) { //5 fprintf(stderr,"Read nothing from socket:ns\n"); err_code=12;goto end_1; } //5 mysql_free_result(result); //ma

25、y cause problem when no result printf("%s 接收信息: %s\n",argv[0],rebuf); strsplit(rebuf,h,d); double share=0; for(i=1;i<3;i=i+2) { // if(compare(h[i],"")) // break; sprintf(cmd,"SELECT sid,num,price FROM S WHERE sid=%s",h[i]);

26、 printf("\nCMD=%s\n",cmd); if(mysql_query(&mysql,cmd)!=0) { //5 fprintf(stderr,"Error in query: %s [%d]\n",\ mysql_error(&mysql),mysql_errno(&mysql)); err_code=3;goto end_1; } //5 //get result if((result=mysql_store_result(&mysql))==NULL) { /

27、/5 fprintf(stderr,"Error in store_result: %s [%d]\n",\ mysql_error(&mysql),mysql_errno(&mysql)); mysql_free_result(result); err_code=4;goto end_1; } //5 if(err_code!=0) goto end_1; recs=mysql_num_rows(result);

28、 row=mysql_fetch_row(result); printf("_______%s________%d___%d___",row[0],swit2(row[1]),swit1(row[2])); printf("TTTTTTTTTTTTTT%sTTTTTTTTT%sTT",h[i],h[i+1]); if(swit2(row[1])>=swit2(h[i+1]))//???????????????????????

29、???????? { sprintf(repp,"%s|%s|%s|",h[i],"1",h[i+1]); printf("%s商品數(shù)量足夠!",h[i]); strcat(rep,repp); //double ttt=swit2(h[i+1]) * row[2]; // ttt*=row[2];

30、 // share+=ttt; } else { sprintf(repp,"%s|%s|%s|",h[i],"0",row[1]); printf("%s商品數(shù)量不足!",h[i]); strcat(rep,repp); } } /* if(share<=money) { sprintf(repp,"%d",share); printf("%s卡上金額為:%d,所需金額為:%d!金額足夠!",v[1],mon

31、ey,share); strcat(rep,repp); double tt=money-share; sprintf(cmd,"update K set money=%d where kid=%s;",tt,v[1]); printf("\nCMD=%s\n",cmd); if(mysql_query(&mysql,cmd)!=0) { fprintf(stderr,"Error in query: %s [%d]\n",\ mysql_error(&mysql),mysql_errno(

32、&mysql)); err_code=3;goto end_1; } printf("數(shù)據(jù)庫更新成功!\n"); } else { sprintf(repp,"%d",money); printf("%s卡上金額為:%d,所需金額為:%d!金額不足!",v[1],money,share); strcat(rep,repp); } */ printf("++++++++%s",rep); wr_l=strlen(rep); if((wr_l=write(

33、ns,rep,wr_l))!=wr_l){ fprintf(stderr,"Write socket ns error!\n"); close(ns); exit(-4); } end_1: mysql_free_result(result); //may cause problem when no result mysql_close(&mysql); //may cause problem when no &mysql break; case 3: // trans(); nothing(

34、buff); break; default: fprintf(stderr,"Func. code error in:\n%s",buff); } //4 switch //寫日志 strncat(tmp,buff,wr_l);wr_l+=rd_l; tmp[wr_l]=\0; strcat(tmp,"\n");++wr_l; printf("\nTMP(%d:%d)=%s\n",strlen(tmp),wr_l,tmp); if((flds=open(log,O_WRONLY|O_APPEND))

35、==-1){ fprintf(stderr,"File %s open error!\n",log); exit(-5); } if(write(flds,tmp,wr_l)!=wr_l){ fprintf(stderr,"File %s write error!\n",log); close(flds);exit(-6); } close(flds); close(ns); exit(0); } //3 } //2 while } //1 main void strsplit(char

36、 *s,char **v,char d) { int i,j,l; j=0;v[j]=s; l=strlen(s); for(i=0;i

37、t++) { int i=s[t]-48; sum+=i*pow(10,strlen(s)-1-t); } sum/=pow(10,strlen(s)-t); t++; d=strlen(s)-t; for(t;t

38、t sum=0; int t=0; for(t;t #include #include #include #include #include #include #

39、include #include #include #define rec_length 500 char str[512]; main(int argc, char **argv ) { char *d="|"; char *v[100]; int sql=0,rslt=0; // structure defined for request as a client struct hostent *hp1; struct sockaddr_in sin1; struct serv

40、ent *sp1; char sbuf[1000],*log="mid.log"; int ss,spid,rd_l,wr_l,rd1l; char *sservice,*sdest; // structure defined for request as a server struct sockaddr_in sin; struct servent *sp; int s,ns,pid,err_code,recs,flds; char buf[500],tmp[1000],cmd[500]; char *service; int i,j,c; cha

41、r *sat[]={ "OKOKOKOK","E_DBinit","E_DBconn","E_DBqry ","E_DBstor", "E_DBnDAT","E_TCPsvr","E_TCPnam","E_TCPsoc","E_TCPcon", "E_TCPsnd","E_TCPrcv","E_TCPbnd","E_TCPlsn","E_TCPacc" }; //declare structure and vars for MySQL MYSQL mysql; MYSQL_RES *result; MYSQL_ROW row; // test

42、 the environment parameter: lservice, dservice, server_name if(argc==4) { service=argv[1];sservice=argv[2]; sdest=argv[3]; } else { fprintf(stderr,"Parameter assigned Error!\nUsage:\n"); fprintf(stderr,"\t%s lservice dservice server_name!\n",argv[0]); fprintf(stderr,"Note: se

43、rver_name is defined in file /etc/hosts\n"); fprintf(stderr,"and: lservice dservice are defined in file /etc/services\n"); exit(-1); } // sprintf(buf,"touch %s",log);system(buf);// touch or create log if((rd1l=open(log,O_WRONLY|O_CREAT|O_APPEND,0644))==-1) { fprintf(stderr,"Log file

44、 %s open error!\a\n",log); exit(-1); } close(rd1l); err_code=0; if((sp=getservbyname(service,"tcp"))==NULL) { fprintf(stderr,"Error: getservbyname"); err_code=6; exit(err_code); } if((s=socket(AF_INET,SOCK_STREAM,0))==-1) { fprintf(stderr,"Error: socket create"); err_c

45、ode=8; exit(err_code); } bzero(&sin,sizeof(sin)); sin.sin_port=sp->s_port; if(bind(s,&sin,sizeof(sin))==-1) { fprintf(stderr,"Error: bind"); err_code=13; close(s); exit(err_code); } if(listen(s,5)==-1) { fprintf(stderr,"Error: listen"); err_code=14; close(s); exit(e

46、rr_code); } // initialize MYSQL structure if(mysql_init(&mysql)==NULL) { strcpy(tmp,"Error in mysql_init!"); fprintf(stderr,"%s\n",tmp); err_code=1; goto end_1; } sql=1; //connect to DataBase if(!mysql_real_connect(&mysql,"localhost","root",0,"lyg",0,NULL,0)) { sprintf(

47、tmp,"數(shù)據(jù)庫連接錯誤: %s [%d]",\ mysql_error(&mysql),mysql_errno(&mysql)); fprintf(stderr,"%s\n",tmp); err_code=-2; goto end_1; } while(1) { fprintf(stderr,"\n\t\t\t Now wait connect ...\n"); if((ns=accept(s,0,0))==-1) { // wait a connection */ fprintf(stderr,"error: acc

48、ept"); continue; } if((pid=fork())==-1) { // conneted, and then create child proc fprintf(stderr,"server: fork error!"); close(s); exit(-1); } if(pid!=0) { //parent proce, nothing to do, and to the next loop close(ns);wait(0);continue; } if(pid==0) { // entered

49、 child proccedure close(s); printf("Receive a client connect:%s\n",argv[1]); sprintf(cmd,"SELECT * FROM S;"); // 構(gòu)造命令 if(mysql_query(&mysql,cmd)!=0) { //execute query fprintf(stderr,"Error in query: %s [%d]\n",\ mysql_error(&mysql),mysql_errno(&mysql)); err_code=

50、3;goto end_1; } if((result=mysql_store_result(&mysql))==NULL) { //get result fprintf(stderr,"Error in store_result: %s [%d]\n",\ mysql_error(&mysql),mysql_errno(&mysql)); err_code=4;goto end_1; } rslt=1; sprintf(buf,"%2.2d|",err_code); if(err_code!=0) goto

51、 end_1; recs=mysql_num_rows(result); // 獲得行數(shù) flds=mysql_num_fields(result); // 獲得域數(shù) fprintf(stderr,"records=%d & fields=%d\n",recs,flds); for(i=0;i

52、",row[j]); strcat(buf,cmd); } // fprintf(stderr,"%s\n",buf); // 顯示返回信息 } wr_l=strlen(buf); if((wr_l=write(ns,buf,wr_l))!=wr_l) { strcat(tmp,"Write socket ns error!\n"); fprintf(stderr,"Write socket error!\n"); } else { strncat(tmp,buf,wr_l)

53、;wr_l+=rd_l; } // close(s); char buff[500]; if((rd_l=read(ns,buff,rec_length))==0) { fprintf(stderr,"Read nothing from socket:ns\n"); err_code=12; close(ns); exit(err_code); } wr_l=rd_l; buff[rd_l]=\0; // strcpy(sbuf,buf); fprintf(stderr,"%s get mes

54、sage from ns: %s\n",argv[0],buff); //buff[rd_l]=\0; strcpy(tmp,buff); strsplit(buff,v,d); // 拆分請求信息 // printf("%c",v[0][0]); switch(v[0][0]) { // 分析請求功能,并執(zhí)行相關(guān)工作。這里只實(shí)現(xiàn)了查詢功能. 其它功能由自己模仿查詢功能來實(shí)現(xiàn) case 1: // query(); sprintf(cmd,"SELECT * FROM S WHERE sname like %%%s%;",v[

55、1]); // 構(gòu)造命令 if(mysql_query(&mysql,cmd)!=0) { //execute query fprintf(stderr,"Error in query: %s [%d]\n",\ mysql_error(&mysql),mysql_errno(&mysql)); err_code=3;goto end_1; } if((result=mysql_store_result(&mysql))==NULL) { //get result fprintf(stder

56、r,"Error in store_result: %s [%d]\n",\ mysql_error(&mysql),mysql_errno(&mysql)); err_code=4;goto end_1; } rslt=1; sprintf(buf,"%2.2d|",err_code); if(err_code!=0) goto end_1; recs=mysql_num_rows(result); // 獲得行數(shù) flds=mysql_num_fields(result); // 獲得域數(shù) fp

57、rintf(stderr,"records=%d & fields=%d\n",recs,flds); for(i=0;i

58、 wr_l=strlen(buf); if((wr_l=write(ns,buf,wr_l))!=wr_l) { strcat(tmp,"Write socket ns error!\n"); fprintf(stderr,"Write socket error!\n"); } else { strncat(tmp,buf,wr_l); wr_l+=rd_l; } if(rslt!=0) mysql_free_result(result); // 釋放結(jié)果集

59、if(sql!=0) mysql_close(&mysql); // 釋放MYSQL對象 close(ns); // 關(guān)閉網(wǎng)絡(luò)鏈接 // 以下為寫日志部分 strcat(tmp,"\n"); ++wr_l; if((flds=open(log,O_WRONLY|O_APPEND))==-1) { // 打開日志文件 fprintf(stderr,"File %s open error!\n",log); exit(-5); } if(write(flds,tmp,strlen(tmp))!

60、=strlen(tmp)) { // 寫日志 fprintf(stderr,"File %s write error!\n",log); close(flds);exit(-6); } close(flds); break; case 2: printf("Receive a client connect:%s\n",argv[1]); fprintf(stderr,"%s get message from ns: %s\n",argv[0],buff); //訪問服務(wù)器端

61、 if((sp1=getservbyname(sservice,"tcp"))==NULL) { fprintf(stderr,"Error: getservbyname s1"); err_code=6;goto log; } if((hp1=gethostbyname(sdest))==0) { fprintf(stderr,"Error: gethostbyname s1"); err_code=7;goto log; } bzero(&sin1,sizeof(sin1));

62、 bcopy(hp1->h_addr,&sin1.sin_addr,hp1->h_length); sin1.sin_family=hp1->h_addrtype; sin1.sin_port=sp1->s_port; if((ss=socket(AF_INET,SOCK_STREAM,0))==-1) { fprintf(stderr,"Error: socket s1"); err_code=8;goto log; } if(connect(ss,&sin1,sizeof(sin1))==-1)

63、 { fprintf(stderr,"Error: connect s1"); close(ss); err_code=9;goto log; } printf("%s",buff); if(write(ss,buff,rd_l)!=rd_l) { //to server fprintf(stderr,"Write Socket ss ERROR! s1\n"); close(ss); err_code=10;goto log; }

64、 char rep[20]; if((rd1l=read(ss,rep,20))==0) { //from server fprintf(stderr,"Read Socket ss Error! s1\n"); close(ss); err_code=11;goto log; } rep[rd1l]=\0; printf("%s get reply: %s\n",argv[0],rep); // close(ss);

65、 //fprintf(stderr,"and,send it back to client: %s\n",sbuf); printf("rep:%s",rep); if((rd1l=write(ns,rep,20))!=rd1l) { fprintf(stderr,"Write socket ns error llll!\n"); close(ns); err_code=10;goto log; } // close(ns);

66、 char repp[500]; if((rd1l=read(ns,repp,500))==0) { //from server fprintf(stderr,"jieshouzhangdan error\n"); close(ns); err_code=11;goto log; } repp[rd1l]=\0; printf("%s 接收信息: %s\n",argv[0],repp); // close(ns); if((rd1l=write(ss,repp,200))!=rd1l) { fprintf(stderr,"Write socket ss>>>>>> error!\n"); close(ss); err_code=10;goto log; } //close(ss);

展開閱讀全文
溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號:ICP2024067431-1 川公網(wǎng)安備51140202000466號


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺,本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請立即通知裝配圖網(wǎng),我們立即給予刪除!