服务器端的程序一般有如下几个过程,首先是bind,然后再是listen,最后是accept。再往后就是客户端与服务器连接后的各种操作了。

相比之下,客户端的程序就比较简单了,只需先获得sock_id,再与对应的sock进行connect,其他如下。

服务器端代码:

 #include<stdio.h>
#include<unistd.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include<netdb.h>
#include<time.h>
#include<string.h>
#define PORTNUM 15000
#define HOSTLEN 256
#define oops(msg) {printf("error:%s\n",msg);return 1;}
int main(int ac,char * av[]){
struct sockaddr_in saddr;
struct hostent * hp;
char hostname[HOSTLEN];
int sock_id,sock_fd;
FILE * sock_fpi,* sock_fpo;
FILE * pipe_fp;
char dirname[BUFSIZ];
char command[BUFSIZ];
int dirlen,c;
sock_id=socket(PF_INET,SOCK_STREAM,);//set socket
if(sock_id==-)
oops("socket");
bzero((void *)&saddr,sizeof(saddr));//empty saddr
gethostname(hostname,HOSTLEN);
printf("hostname:%s\n",hostname);
hp=gethostbyname(hostname);
bcopy((void *)hp->h_addr,(void *)&saddr.sin_addr,hp->h_length);
saddr.sin_port=htons(PORTNUM);
saddr.sin_family=AF_INET;
if(bind(sock_id,(struct sockaddr *)&saddr,sizeof(saddr))!=)//bind address
oops("bind");
if(listen(sock_id,)!=)//listen
oops("listen");
while(){
sock_fd=accept(sock_id,NULL,NULL);//start accept
if(sock_fd==-)
oops("accept");
if((sock_fpi=fdopen(sock_fd,"r"))==NULL)
oops("fdopen reading");
if(fgets(dirname,BUFSIZ-,sock_fpi)==NULL)
oops("reading dirname");
sanitize(dirname);
if((sock_fpo=fdopen(sock_fd,"w"))==NULL)
oops("fdopen writing");
sprintf(command,"ls %s",dirname);
if((pipe_fp=popen(command,"r"))==NULL)
oops("popen");
while((c=getc(pipe_fp))!=EOF)
putc(c,sock_fpo);
pclose(pipe_fp);
pclose(sock_fpo);
pclose(sock_fpi);
}
}
sanitize(char * str){
char * src,* dest;
for(src=dest=str;*src;src++)
if(*src=='/'||isalnum(*str))
*dest++=*src;
*dest='\0';
}

客户端代码:

 #include<stdio.h>
#include<linux/types.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include<netdb.h>
#define oops(msg) {printf("error:%s\n",msg);return 1;}
#define PORTNUM 15000
main(int ac,char * av[]){
struct sockaddr_in servadd;
struct hostent * hp;
int sock_id,sock_fd;
char message[BUFSIZ];
char buffer[BUFSIZ];
int messlen,n_read;
sock_id=socket(PF_INET,SOCK_STREAM,);//attention:PF_INT NOT AF_INT
if(sock_id==-)
oops("socket");
bzero(&servadd,sizeof(servadd));
hp=gethostbyname(av[]);
if(hp==NULL)
oops(av[]);
bcopy(hp->h_addr,(struct sockaddr *)&servadd.sin_addr,hp->h_length);
servadd.sin_port=htons(PORTNUM);
servadd.sin_family=AF_INET;
if(connect(sock_id,(struct sockaddr *)&servadd,sizeof(servadd))!=)//connect
oops("connect");
if(write(sock_id,av[],strlen(av[]))==-)
oops("write");
if(write(sock_id,"\n",)==-)
oops("write");
while((n_read=read(sock_id,buffer,BUFSIZ))>)
if(write(,buffer,n_read)==-)
oops("write");
close(sock_id);
}

调用如下:

服务器启动:./rlsd&

客户端访问:./rls jsonzhang-Vostro-23-3340 ~/桌面/workplace/

rls与rlsd的更多相关文章

  1. RLS自适应滤波器中用矩阵求逆引理来避免求逆运算

    在RLS自适应滤波器的实现过程中,难免不涉及矩阵的求逆运算.而求逆操作双是非常耗时的,一个很自然的想法就是尽可能的避免直接对矩阵进行求逆运算.那么,在RLS自适应滤波器的实现中,有没有一种方法能避免直 ...

  2. Power BI 行级别安全性 (RLS)

    在 Power BI Desktop 中定义角色和规则 你可以在 Power BI Desktop 中定义角色和规则. 发布到 Power BI 时,它还会发布角色定义. 若要定义安全角色,请执行以下 ...

  3. Power BI 报表服务器中的行级别安全性 (RLS)

    在 Power BI Desktop 中定义角色和规则 你可以在 Power BI Desktop 中定义角色和规则. 发布到 Power BI 时,它还会发布角色定义. 若要定义安全角色,请执行以下 ...

  4. PowerBI开发 第十八篇:行级安全(RLS)

    PowerBI可以通过RLS(Row-level security)限制用户对数据的访问,过滤器在行级别限制数据的访问,用户可以在角色中定义过滤器,通过角色来限制数据的访问.在PowerBI Serv ...

  5. 数据权限筛选(RLS)的两种实现介绍

    在应用程序中,尤其是在统计的时候, 需要使用数据权限来筛选数据行. 简单的说,张三看张三部门的数据, 李四看李四部门的数据:或者员工只能看自己的数据, 经理可以看部门的数据.这个在微软的文档中叫Row ...

  6. Envoy熔断限流实践(二)Rainbond基于RLS服务全局限流

    Envoy 可以作为 Sevice Mesh 微服务框架中的代理实现方案,Rainbond 内置的微服务框架同样基于 Envoy 实现.本文所描述的全局限速实践也是基于 Envoy 已有的方案所实现. ...

  7. In-Memory:在内存中创建临时表和表变量

    在Disk-Base数据库中,由于临时表和表变量的数据存储在tempdb中,如果系统频繁地创建和更新临时表和表变量,大量的IO操作集中在tempdb中,tempdb很可能成为系统性能的瓶颈.在SQL ...

  8. Security Policy:行级安全(Row-Level Security)

    行级安全RLS(Row-Level Security)是在数据行级别上控制用户的访问,控制用户只能访问数据库表的特定数据行.断言是逻辑表达式,在SQL Server 2016中,RLS是基于安全断言( ...

  9. Sql Server 2016新功能之 Row-Level Security

    Sql Server 2016 有一个新功能叫 Row-Level Security ,大概意思是行版本的安全策略(原来我是个英语渣_(:з」∠)_) 直接上例子.这个功能相当通过对表添加一个函数作为 ...

随机推荐

  1. cropper实现图片剪切上传

    一.引入文件 <script src="jquery.min.js"></script> <link rel="stylesheet&quo ...

  2. js判断客户端是pc还是手机及获取浏览器版本

    //判断是pc还是移动端 function browserRedirect() { var sUserAgent = navigator.userAgent.toLowerCase(); var bI ...

  3. #14 Python模块

    前言 前面的文章中,有许多地方都用到了Python的模块,这个到底是个什么神奇的东西呢?让我们来一起盘它! 一.什么是模块 在前几节中,我们已经接触了一些模块:math.random.time等,它们 ...

  4. 四层和七层负载均衡的特点及常用负载均衡Nginx、Haproxy、LVS对比

    一.四层与七层负载均衡在原理上的区别 图示: 四层负载均衡与七层负载均衡在工作原理上的简单区别如下图: 概述: 1.四层负载均衡工作在OSI模型中的四层,即传输层.四层负载均衡只能根据报文中目标地址和 ...

  5. int和Integer有什么区别?

    Java提供两种不同的类型:引用类型和原始类型(或内置类型): int是Java的原始数据类型,Integer是java为int提供的封装类. java为每个原始类型提供了封装类: 原始类型:bool ...

  6. Linux中配置别名

    Linux中修改配置别名 ####用到的命令: alias是用来查看系统中有什么别名 source 让配置生效 临时取消别名的方法 unalias 临时取消别名 \cp /mnt/test.txt / ...

  7. 解决升级Spark2.0之后,DataFrame map操作报错

    当我们在使用spark1.6的时候,当我们创建SQLContext读取一个文件之后,返回DataFrame类型的变量可以直接.map操作,不会报错.但是升级之后会包一个错误,如下: 报错:No imp ...

  8. kafka安装与简单使用

    一.kafka安装 安装是非常简单的,现在推荐安装0.8的版本,这个版本是非常稳定的,而且公司里面也多用此版本. 简单的安装: 这个是我使用的版本,kafka_2.11-0.8.2.2.tgz 直接t ...

  9. Fundebug前端JavaScript插件更新至1.2.0

    摘要: Fundebug的前端JavaScript错误监控插件更新至1.2.0:支持监控WebSocket连接错误:修复了监控unhandledrejection错误的BUG,即未用catch处理的P ...

  10. blfs(systemd版本)学习笔记-编译安装sudo并创建普通用户配置sudo权限

    我的邮箱地址:zytrenren@163.com欢迎大家交流学习纠错! blfs书中sudo的安装配置章节:http://www.linuxfromscratch.org/blfs/view/stab ...