66 if (mode==
ON) sz = sz - hs;
83 if (buf==NULL || buf->
vldsz<0 || buf->
buf==NULL) nobody =
TRUE;
89 if (!
strcasecmp((
const char*)(pp->ldat.key.buf),
"Content-Length")) {
176 if (fname!=NULL) sz =
file_size((
char*)fname);
183 if (!
strcasecmp((
const char*)(pp->ldat.key.buf),
"Content-Length")) {
192 if (fname!=NULL && sz!=0) fp = fopen(fname,
"rb");
194 html = (
unsigned char*)malloc(sz+1);
201 memset(html, 0, sz+1);
202 rs = fread(html, sz, 1, fp);
263 if (fp!=NULL) fwrite(mbuf.
buf, cc, 1, fp);
298 if (*pl!=NULL) (*pl)->ldat.id = com;
299 if (state!=NULL) *state = connect;
301 if (sz==0 && cc==0)
return 0;
326 if (hbuf.
buf!=NULL) {
327 *len = atoi((
const char*)hbuf.
buf);
366 if (state!=NULL) *state =
TRUE;
369 if (sz>0 && fp!=NULL) fwrite(buf->
buf, sz, 1, fp);
377 if (fp!=NULL) fwrite(rcv.
buf, cc, 1, fp);
382 if (state!=NULL) *state =
FALSE;
413 int chnksz, hdsz, tlsz;
414 if (state!=NULL) *state =
TRUE;
422 if (state!=NULL) *state =
FALSE;
437 if (chnksz+hdsz+tlsz > tmp.
vldsz) {
452 for (i=0; i<tmp.
vldsz-chnksz-hdsz-tlsz; i++) {
453 tmp.
buf[i] = tmp.
buf[chnksz + hdsz + tlsz + i];
469 if (fp!=NULL) fwrite(buf->
buf, buf->
vldsz, 1, fp);
493 if (chnksz<=sz)
return 0;
540 if (fp!=NULL) fwrite(rcv.
buf, cc, 1, fp);
585 if (hdonly!=NULL) *hdonly =
FALSE;
591 if (state!=NULL) *state = connect;
592 if (hs<=0)
return hs;
594 if (hdonly!=NULL) *hdonly =
TRUE;
595 if (pl!=NULL) *pl = lp;
639 if (pl!=NULL) *pl = lp;
641 if (cc>0) cc = cc + hs;
643 if (state!=NULL) *state = connect;
667int recv_http_file(
int sofd,
tList** pl,
const char* fname,
const char* wdir,
int tsecond,
int* hdonly,
int* state)
672 const char tmpd[] =
"/tmp";
675 if (hdonly!=NULL) *hdonly =
FALSE;
679 if (state!=NULL) *state = connect;
680 if (hs<=0)
return hs;
682 if (hdonly!=NULL) *hdonly =
TRUE;
720 if (fname!=NULL) fp = fopen(fname,
"wb");
737 DEBUG_MODE PRINT_MESG(
"RECV_HTTP_FILE: WARNING: Content-Encoding is [%s]. But zlib is not installed!!\n", buf.
buf);
739 if (wdir==NULL) wdir = tmpd;
774 if (state!=NULL) *state = connect;
801 if (pl==NULL || recvfn==NULL)
return 0;
804 if (xml!=NULL) *xml = NULL;
807 int cc =
recv_http_file(cofd, pl, *recvfn, wdir, timeout, &header, state);
808 if (cc<=0 || *pl==NULL) {
820 if (xml!=NULL && *pl!=NULL && *recvfn!=NULL && cc>0) {
823 if (*xml!=NULL && (*xml)->state<0)
del_all_xml(xml);
882 if (hbuf.
buf!=NULL) {
902 if (pl==NULL)
return ret;
922 if (pl==NULL)
return;
944 if (fp==NULL) fp = stderr;
950 if (!
strcasecmp((
const char*)ld.key.buf,
"Content-Type")) {
956 fprintf(fp,
"[%d] [%d] [%s] [%d]\n", ld.id, ld.lv, ld.key.buf, ld.val.vldsz);
957 fdump(fp, (
unsigned char*)ld.val.buf, ld.val.vldsz);
960 fprintf(fp,
"[%d] [%d] [%s] [%s]\n", ld.id, ld.lv, ld.key.buf, ld.val.buf);
966 fprintf(fp,
"(List is NULL)\n");
983 int ck = 0, hd = 0, tl = 0;
987 while (ptr[i]!=0x0d && i<
L_32) {
992 if (hdsz!=NULL) *hdsz = 0;
993 if (tlsz!=NULL) *tlsz = 0;
997 if (ptr[i+1]==0x0a) hd = i + 2;
999 if (hdsz!=NULL) *hdsz = hd;
1004 if (ptr[ck+hd]==0x0d) {
1006 if (ptr[ck+hd+tl]==0x0a) tl++;
1008 if (tlsz!=NULL) *tlsz = tl;
1047 int len, nd, cc, state;
1052 unsigned short sport = 0;
1056 struct timeval timeout;
1066 timeout.tv_sec = btm*10;
1067 timeout.tv_usec = 0;
1069 FD_SET(bofd, &mask);
1070 nd = select(bofd+1, &mask, NULL, NULL, &timeout);
1073 while (FD_ISSET(bofd, &mask) && keep) {
1076 if (pl==NULL)
break;
1086 if (btm==0) btm = tmout;
1087 else btm =
Min(btm, 60);
1090 if (server.
buf!=NULL && sport!=0) {
1092 if (ipa!=NULL && !strcmp(ipa, myip)) {
1110 cc =
tcp_send(bofd, (
char*)
"HTTP/1.1 200 Connection established.\r\nProxy-Connection: close\r\n\r\n", 0);
1120 if (cc<len && state) {
1137 timeout.tv_sec = btm;
1138 timeout.tv_usec = 0;
1140 FD_SET(bofd, &mask);
1141 nd = select(bofd+1, &mask, NULL, NULL, &timeout);
1183 decomp_url(url, NULL, NULL, server, sport, &srvdir);
1187 if (server->
buf==NULL) {
1192 if (bufport.
buf!=NULL) *sport = atoi((
char*)bufport.
buf);
1196 if (*sport==0) *sport = 80;
1200 if (lst->ldat.val.buf!=NULL) *timeout = atoi((
char*)(lst->ldat.val.buf));
1206 if (!
strcasecmp((
char*)(lst->ldat.val.buf),
"keep-alive")) *keep =
TRUE;
1242 int len, cc, cx, sz, tout, state;
1263 if (lst!=NULL && lst->prev!=NULL) {
1266 snprintf(pxcn, 46,
"keep-alive, timeout=%d", btm);
1294 if (cc<=0 || (cc>0&&cx<=0))
return 0;
1341 struct timeval timeout;
1344 num =
Max(sofd, cofd);
1347 timeout.tv_sec = tm;
1348 timeout.tv_usec = 0;
1350 FD_SET(sofd, &mask);
1351 FD_SET(cofd, &mask);
1352 nd = select(num+1, &mask, NULL, NULL, &timeout);
1356 while (nd>0 && (FD_ISSET(cofd, &mask) || FD_ISSET(sofd, &mask))) {
1358 if (FD_ISSET(cofd, &mask)) {
1371 if (FD_ISSET(sofd, &mask)) {
1385 timeout.tv_sec = tm;
1386 timeout.tv_usec = 0;
1388 FD_SET(sofd, &mask);
1389 FD_SET(cofd, &mask);
1390 nd = select(num+1, &mask, NULL, NULL, &timeout);
1406 if (dat.
buf!=NULL) {
1409 if (num.
buf!=NULL) {
1410 pnum = atoi((
const char*)num.
buf);
1426 if (dat.
buf!=NULL) {
1429 if (num.
buf!=NULL) {
1430 ver = (float)atof((
char*)&num.
buf[5]);
1438 if (num.
buf!=NULL) {
1439 ver = (float)atof((
char*)&num.
buf[5]);
1472 tcp_send(sofd, (
char*)
"HTTP/1.1 200 OK\r\n", 0);
1473 tcp_send(sofd, (
char*)
"Accept-Ranges: bytes\r\n", 0);
1474 tcp_send(sofd, (
char*)
"Pragma: no-cache\r\n", 0);
1475 tcp_send(sofd, (
char*)
"Cache-Control: no-cache\r\n", 0);
1476 memset(buf, 0,
LBUF);
1481 tcp_send(sofd, (
char*)
"Keep-Alive: timeout=1800, max=100\r\n", 0);
1482 tcp_send(sofd, (
char*)
"Connection: Keep-Alive\r\n", 0);
1486 if (sz!=0) fp = fopen(fname,
"rb");
1490 html = (
char*)malloc(sz);
1495 memset(html, 0, sz);
1497 rs = fread(html, sz, 1, fp);
1508 tcp_send(sofd, (
char*)
"HTTP/1.1 401 Authorization Required\r\n", 0);
1509 tcp_send(sofd, (
char*)
"WWW-Authenticate: Basic realm=\"TTS\"\r\n", 0);
1510 tcp_send(sofd, (
char*)
"Pragma: no-cache\r\n", 0);
1511 tcp_send(sofd, (
char*)
"Cache-Control: no-cache\r\n", 0);
1512 tcp_send(sofd, (
char*)
"Connection: Close\r\n", 0);
1513 tcp_send(sofd, (
char*)
"Content-Length: 0\r\n", 0);
1514 tcp_send(sofd, (
char*)
"Content-Type: text/html\r\n\r\n", 0);
Buffer make_Buffer(int sz)
Buffer型変数のバッファ部をつくり出す.
int cat_b2Buffer(void *src, Buffer *dst, int len)
任意のバイナリデータsrcを Buffer型変数dstへ lenバイト catする.
void clear_Buffer(Buffer *str)
Buffer型変数 のバッファ部を 0クリアする.
void free_Buffer(Buffer *buf)
Buffer型変数のバッファ部を解放する
Buffer init_Buffer()
初期化したBuffer型変数を返す.
Buffer dup_Buffer(Buffer buf)
Buffer型変数のコピーをつくる.
int copy_i2Buffer(int src, Buffer *dst)
整数 srcを文字列に変換して,dstへ copyする.
int cat_Buffer(Buffer *src, Buffer *dst)
Buffer変数 srcから dstへバッファを catする.
int copy_Buffer(Buffer *src, Buffer *dst)
Buffer型変数 srcから dstへバッファをコピーする.
Buffer cawk_Buffer(Buffer str, char cc, int n)
Buffer文字列に対する(変形の)awk.
#define copy_s2Buffer(src, dst)
copy_b2Buffer()
#define make_Buffer_str(str)
set_Buffer()
#define cat_s2Buffer(src, dst)
cat_b2Buffer()
#define make_Buffer_bystr(str)
set_Buffer()
#define LEN_INT
log 2^64 + '\0' + 1(予備)
#define WORK_FILENAME_LEN
#define JBXL_ARGS_ERROR
不正な引数(NULLなど)
#define JBXL_NET_RECV_ERROR
データの受信エラー
#define JBXL_MALLOC_ERROR
メモリ確保エラー
#define JBXL_FILE_OPEN_ERROR
ファイルオープン エラー
#define JBXL_NET_RECV_TIMEOUT
受信タイムアウト
int tcp_send(int sock, char *smsg, int size)
char * get_ipaddr_byname(const char *hostname, int family)
ホスト名 → IPv4/IPv6 アドレス(文字列)
int socket_close(int sofd)
call shutdown(), close()
int recv_wait(int sock, int tm)
#define tcp_client_socket(h, p)
Buffer search_protocol_header(tList *list, char *key, int no)
int set_protocol_header(tList *list, char *key, char *value, int no, int add_mode)
Buffer restore_protocol_header(tList *list, char *deli, int mode, int *hdsz)
tList * get_protocol_header_list_seq(tList *lp, Buffer buf, char deli, int fstline, int rcntnt)
#define delete_protocol_header(p, k, n)
#define HDLIST_CONTENTS_KEY
#define HDLIST_FIRST_LINE_KEY
#define add_protocol_header(p, k, v)
int vldsz
データの長さ.バイナリデータの場合も使用可能.文字列の場合は 0x00 を含まない.
unsigned char * buf
バッファの先頭へのポインタ.str[bufsz]は必ず 0x00となる.
tList * del_tList(tList **pp)
指定したリストノード以降のリストを削除.
tList * strncasecmp_tList(tList *pl, const char *key, int len, int no)
char* 型変数によるノードのサーチ.大文字小文字を無視する
tList * del_tList_node(tList **node)
リスト用のノードを削除.
tList * find_tList_top(tList *pl)
リストの最初のノードを探す.
#define add_tList_node_Buffer(p, k, v)
add_tList_node_byBuffer()
#define add_tList_node_str(p, k, v)
add_tList_node_bystr()
tXML * xml_parse_file(const char *fn)
ファイルから読み込んでパースする.
#define del_all_xml(p)
XMLツリーの全ノードの削除.ポインタ ppのノードを含むXMLツリー全体を削除する.