协议


SCGI(Simple Common Gateway Interface),简单通用网关接口。是CGI的替代协议,与FastCGI相似,但更简单。据测试SCGI实现的效率比CGI和FastCGI更高,也更稳定。

SCGI和CGI一样,分为客户端和服务器端。客户端放在http服务器侧。如apache有mod_scgi,lighthttpd有内置的SCGI支持。2008.12.29 最新版本 scgi 1.13, 服务器实现是python,但放在http服务器侧的客户端实现是C语言。 


标准原版:http://python.ca/scgi/protocol.txt 
协议中,ASCII字符可以用< >括起来的16进制数字表示,也可以引号""括起来的ASCII表示。 
报文由报头和报体组成。报头格式: 
headers ::= header* 
header ::= name NUL value NUL 
name ::= notnull+ 
value ::= notnull* 
notnull ::= <01> | <02> | <03> | ... | 
NUL = <00> 
报头中不允许重复命名。首个报头必须名为"CONTENT_LENGTH", 
且其值为非空的ASCII数字序列,以十进制数形式给出了报文主体的长度。 
"CONTENT_LENGTH"报头必须总是存在,即使其值为"0"。 
同时必须始终有名为"SCGI"且值为"1"的报头。 
为了便于从CGI的迁移,标准CGI环境变量应该作为SCGI报头提供。 
报头采用Netstring编码。格式为“整个报文长度字符串:报头,报体” 
如下的示例: 
web服务器(一个SCGI客户端)打开一个连接,发送下面字符串的拼接: 

"70:" 
"CONTENT_LENGTH" <00> "27" <00> 
"SCGI" <00> "1" <00> 
"REQUEST_METHOD" <00> "POST" <00> 
"REQUEST_URI" <00> "/deepthought" <00> 
"," 
"What is the answer to life?" 
这是一个Netstring编码的报头+报体。开头的70表示报文长度70个8位。<00>表示0结尾的字符串。用“,”隔开报头和报体。 
SCGI服务器发送下面的响应: 

"Status: 200 OK" <0d 0A
"Content-Type: text/plain" <0d 0a> 
"" <0d 0a> 
"42" 

<0d 0a>表示换行。 
SCGI服务器关闭连接。 


posted on 2018-08-16 17:43  zhco  阅读(119)  评论(0编辑  收藏  举报

导航