0
我有簡單的代理應用程序,在端口4711然後應用程序發送請求到服務器(自己的應用程序)偵聽來自瀏覽器連接,並比較了本地緩存請求數據的服務器的版本,然後再應用於的區別並將數據發送回瀏覽器。問題與網絡應用
我的工作,直到有非常簡單的站點,內容只有主頁。但是,只有在IE 10中才能正常工作。我測試了FF,Chrome,Safari,但它們不起作用。他們在請求代理時掛起。
該應用程序是寫在C,使用SDL,並SDL_Net網絡功能。使用非阻塞TCP套接字。我使用VS 2010和Windows 8
請建議我應該首先檢查調試。我知道我非常簡短地描述了這個問題,但如果需要,我可以提供更多信息(代碼片斷等)。
好的。在這裏放一些代碼。
typedef struct _UA_REQUEST
{
My_string full_url ;
uint32_t url_adler32 ;
TCPsocket sock_ua ;
uint32_t status_flag ; // ref Enum STATUS
} UA_REQUEST ;
UA_REQUEST GLB_ARRAY__UA_REQ[ NUM_UA_SOCK ] ;
TCPsocket GLB_SOCK_SS={0} , GLB_LSOCK_UA={0} ;
while(1)
{
nrdy = SDLNet_CheckSockets(GLB_SOCK_SET, -1 /*1000*/);
if(nrdy == -1)
break ;
if(!nrdy)
continue ;
check_listener_socket() ;
check_user_agent_sockets() ;
check_single_stream_socket() ;
}
//==================================================================
// Check and handle connection request from UA (user agent)
//==================================================================
void check_listener_socket()
{
uint32_t index ;
UA_REQUEST*ar = GLB_ARRAY__UA_REQ ;
if(!SDLNet_SocketReady(GLB_LSOCK_UA))
{
puts("check_listener_socket(): GLB_LSOCK_UA is not ready!");
return ;
}
TCPsocket sock_ua = SDLNet_TCP_Accept(GLB_LSOCK_UA) ; // accept connection from browser
if(!sock_ua)
{
printf("ERR__TCP_Accept: %s\n", SDLNet_GetError());
goto quit ;
} else
printf("Accepted.\n");
for(index=0 ; (index < NUM_UA_SOCK) ; index++)
if(STATUS(ar,index) == ST_SOCK_CLOSED)
break ;
if(index >= NUM_UA_SOCK)
return;
SOCK_UA(ar , index) = sock_ua;
STATUS(ar , index) = ST_SOCK_AVLBL ;
SDLNet_TCP_AddSocket(GLB_SOCK_SET , SOCK_UA(ar, index)) ;
quit:
return;
}
//==================================================================
// Check and receive data from UA
//==================================================================
void check_user_agent_sockets()
{
UA_REQUEST *ar = GLB_ARRAY__UA_REQ ;
uint32_t index ;
for(index=0 ; index < NUM_UA_SOCK ; index++)
{
int ready = SDLNet_SocketReady(SOCK_UA(ar,index));
if(/*STATUS(ar,index) != ST_SOCK_CLOSED &&*/
ready /*SDLNet_SocketReady(SOCK_UA(ar,index)) */
)
{
printf("index = %i\n", index);
handle_ua_sock_ready(index) ;
}
}
}
void handle_ua_sock_ready(uint32_t i)
{
My_string _req_mstr ;
MY_ALLOC(_req_mstr , MAXLEN)
byte*request = _req_mstr.c_str ;
byte*pcrlf = NULL ;
RESET_BUF(request)
UA_REQUEST*ar = GLB_ARRAY__UA_REQ ;
//uint32_t
int nrcv; // : Slava
nrcv = SDLNet_TCP_Recv(SOCK_UA(ar,i) , request , MAXLEN) ;
if(nrcv<=0)
{
puts("handle_ua_sock_ready() before handle_ua_sock_closed");
handle_ua_sock_closed(ar , i) ;
puts("handle_ua_sock_ready() after handle_ua_sock_closed");
goto quit;
}
puts("1") ;
if(
(STATUS(ar,i) == ST_TUNNEL)
|| (MATCH(request , CONN , strlen(CONN)))
)
{
FULL_URL(ar , i).c_str[0] = 0 ;
FULL_URL(ar , i).len = 0 ;
STATUS(ar , i) = ST_TUNNEL ;
request[nrcv] = 0 ;
send_to_server(TUNNEL_REQ ,request, nrcv, i);
goto quit;
}
puts("11") ;
if(get_hdrs_and_full_url(request, i ,(uint32_t*)&nrcv,pcrlf) == -1)
{
puts("handle_ua_sock_ready() test 2");
goto quit ;
}
My_string *purl_mstr = &FULL_URL(ar , i) ;
log_msg(purl_mstr->c_str , purl_mstr->len , __LINE__) ;
URL_ADLER32(ar, i) = my_adler_32(1 , purl_mstr->c_str , purl_mstr->len) ;
fwrite(FULL_URL(ar,i).c_str , sizeof(byte), FULL_URL(ar,i).len , GLB_REQ_LOG) ;
puts("111") ;
CHECK_AND_HANDLE_GET_HEAD_REQ(i , request , nrcv)
CHECK_AND_HANDLE_UNSUPPORTED(ar,i,request)
uint32_t uv = nrcv;
CHECK_AND_HANDLE_POST_OPT_REQ(ar,i,request ,/*nrcv*/ uv)
quit:
MY_FREE(_req_mstr)
return ;
}
//==================================================================
// Check and receive reply from "Server"
//==================================================================
void check_single_stream_socket()
{
puts("-- before return");
if(!SDLNet_SocketReady(GLB_SOCK_SS))
{
return ;
}
puts("-- before receive_data_from_server()");
receive_data_from_server() ;
}
//==================================================================
//
// receive_data_from_server/0 :: First 4 bytes of "Payload" are eql to length of rest of Payload
//
//==================================================================
void receive_data_from_server()
{
My_string payload ;
MY_ALLOC(payload , MAXLEN)
int ncnt; // : Slava
uint32_t nreply , req_index , rep_index ;
uint32_t aallocated, ffreed ;
byte err[100] ;
bool bExitFlag = false;
puts("30001") ;
payload.len = 0 ;
if(get_payload(&payload) == -1)
goto quit ;
UA_REQUEST*req_arr = GLB_ARRAY__UA_REQ ;
SS_REPLY*rep_arr = GLB_ARRAY__SS_REPLY ;
puts("30002") ;
// printf("rep_type :: %u \nreq_id :: %u \n" , payload.c_str[0] , SDLNet_Read32(payload.c_str+1)) ;
uint8_t rep_type = payload.c_str[0] ;
if((rep_type == 1)
|| (rep_type == 3)
|| (rep_type==4)
) /*ie req_id == req_arr index*/
{
puts("30003") ;
req_index = SDLNet_Read32(payload.c_str+1) ;
nreply = payload.len-5 ;
ncnt = SDLNet_TCP_Send(
SOCK_UA(req_arr,req_index)
, payload.c_str+5 , nreply
) ;
if(ncnt < nreply)
{
sprintf((char*)err , "ERR__SOCK_WRITE :: bytes to be written: %u ;; actual num:: %u" , nreply , ncnt) ;
log_msg(err , strlen((char*)err) , __LINE__) ;
handle_ua_sock_closed(req_arr , req_index) ;
}
}
else if(payload.c_str[0] == 2) /* < req_id == "url_adler32" > */
{
puts("30004") ;
uint32_t url_adler32 = SDLNet_Read32(payload.c_str+1) ;
for(req_index = 0 ; req_index<NUM_UA_SOCK ; req_index++)
{
if(URL_ADLER32(req_arr , req_index) == url_adler32)
{
puts("30005") ;
My_string reply_mstr ;
MY_ALLOC(reply_mstr , MAXLEN)
update_cache__and__read_in_mystr( payload.c_str+5 ,payload.len-5
,&reply_mstr ,req_index
) ;
nreply = reply_mstr.len ;
puts("30006") ;
ncnt = SDLNet_TCP_Send(
SOCK_UA(req_arr , req_index)
, reply_mstr.c_str // reply_mstr
, nreply
) ;
if(ncnt < nreply)
{
sprintf((char*)err , "ERR__SOCK_WRITE :: bytes to be written: %u ;; actual num:: %u" , nreply , ncnt) ;
log_msg(err , strlen((char*)err) , __LINE__) ;
handle_ua_sock_closed(req_arr , req_index) ;
}
else
reset_req_arr_element(req_index) ;
MY_FREE(reply_mstr)
bExitFlag = true; // : Slava
break;
}
}
if (!bExitFlag)
{
for(rep_index = 0 ; rep_index<NUM_SS_REPLY ; rep_index++)
if(STATUS(rep_arr , rep_index)==ST_EMPTY)
break ;
My_string*pdel_mstr = &(REPLY(rep_arr , rep_index)) ;
if(pdel_mstr->len)
pdel_mstr->len = 0 ;
append(pdel_mstr , payload.c_str+5 , payload.len-5) ;
puts("30007") ;
STATUS(rep_arr , rep_index) = ST_OCCUPIED ;
}
} /*</ id_type != "socket"> */
quit:
MY_FREE(payload)
}
我還可以添加應用程序不會發送甚至需要數據包到瀏覽器。我爲此目標使用了SoftPerfect嗅探器。
你應該提供aditional的信息,具體代碼,預期結果和實際結果。 –
您運行網絡嗅探器並檢查應用程序是否發回響應。如果沒有,則使用調試器運行應用程序,並檢查發生意外事件的位置,以防止它發回響應。如果它確實發送了響應,但瀏覽器卻沒有看到它們,那麼您可以責怪防火牆,或者指責應用程序錯誤地實現了HTTP協議,或者指責您的應用程序錯誤地實現了HTML。 –
感謝您的意見。我禁用了我個人電腦中的所有防火牆,包括Windows防火牆,仍然存在相同的問題。我認爲在代碼中存在問題。你認爲在不同瀏覽器中的協議可能有所不同,因爲IE仍在運行? – vns955