⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ajp_utils.c

📁 Apache官方在今天放出产品系列2.2的最新版本2.2.11的源码包 最流行的HTTP服务器软件之一
💻 C
字号:
/* Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements.  See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License.  You may obtain a copy of the License at * *     http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */#include "ajp.h"/* * Handle the CPING/CPONG */apr_status_t ajp_handle_cping_cpong(apr_socket_t *sock,                                    request_rec *r,                                    apr_interval_time_t timeout){    ajp_msg_t *msg;    apr_status_t rc, rv;    apr_interval_time_t org;    apr_byte_t result;    ap_log_error(APLOG_MARK, APLOG_DEBUG, 0, r->server,                         "Into ajp_handle_cping_cpong");    rc = ajp_msg_create(r->pool, AJP_PING_PONG_SZ, &msg);    if (rc != APR_SUCCESS) {        ap_log_error(APLOG_MARK, APLOG_ERR, 0, r->server,               "ajp_handle_cping_cpong: ajp_msg_create failed");        return rc;    }    rc = ajp_msg_serialize_cping(msg);    if (rc != APR_SUCCESS) {        ap_log_error(APLOG_MARK, APLOG_ERR, 0, r->server,               "ajp_handle_cping_cpong: ajp_marshal_into_msgb failed");        return rc;    }    rc = ajp_ilink_send(sock, msg);    if (rc != APR_SUCCESS) {        ap_log_error(APLOG_MARK, APLOG_ERR, 0, r->server,               "ajp_handle_cping_cpong: ajp_ilink_send failed");        return rc;    }    rc = apr_socket_timeout_get(sock, &org);    if (rc != APR_SUCCESS) {        ap_log_error(APLOG_MARK, APLOG_ERR, 0, r->server,               "ajp_handle_cping_cpong: apr_socket_timeout_get failed");        return rc;    }    /* Set CPING/CPONG response timeout */    rc = apr_socket_timeout_set(sock, timeout);    if (rc != APR_SUCCESS) {        ap_log_error(APLOG_MARK, APLOG_ERR, 0, r->server,               "ajp_handle_cping_cpong: apr_socket_timeout_set failed");        return rc;    }    ajp_msg_reuse(msg);    /* Read CPONG reply */    rv = ajp_ilink_receive(sock, msg);    if (rv != APR_SUCCESS) {        ap_log_error(APLOG_MARK, APLOG_ERR, 0, r->server,               "ajp_handle_cping_cpong: ajp_ilink_receive failed");        goto cleanup;    }    rv = ajp_msg_get_uint8(msg, &result);    if (rv != APR_SUCCESS) {        ap_log_error(APLOG_MARK, APLOG_ERR, 0, r->server,               "ajp_handle_cping_cpong: invalid CPONG message");        goto cleanup;    }    if (result != CMD_AJP13_CPONG) {        ap_log_error(APLOG_MARK, APLOG_ERR, 0, r->server,               "ajp_handle_cping_cpong: awaited CPONG, received %d ",               result);        rv = APR_EGENERAL;        goto cleanup;    }cleanup:    /* Restore original socket timeout */    rc = apr_socket_timeout_set(sock, org);    if (rc != APR_SUCCESS) {        ap_log_error(APLOG_MARK, APLOG_ERR, 0, r->server,               "ajp_handle_cping_cpong: apr_socket_timeout_set failed");        return rc;    }    ap_log_error(APLOG_MARK, APLOG_DEBUG, 0, r->server,                         "ajp_handle_cping_cpong: Done");    return rv;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -