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

📄 jk_service_apache13.c

📁 Tomcat 4.1与WebServer集成组件的源代码包.
💻 C
📖 第 1 页 / 共 2 页
字号:
                return JK_ERR;             }                         }        /*         * To allow server push. After writing full buffers         */        ap_bflush(rr);    }    return JK_OK;}/* ========================================================================= *//* Utility functions                                                         *//* ========================================================================= */static int jk2_get_content_length(jk_env_t *env, request_rec *r){    if(r->clength > 0) {        return r->clength;    } else {        char *lenp = (char *)ap_table_get(r->headers_in, "Content-Length");        if(lenp) {            int rc = atoi(lenp);            if(rc > 0) {                return rc;            }        }    }    return 0;}static int JK_METHOD jk2_init_ws_service(jk_env_t *env, jk_ws_service_t *s,                               jk_worker_t *worker, void *serverObj){    char *ssl_temp      = NULL;    jk_workerEnv_t *workerEnv=worker->workerEnv;    request_rec *r=serverObj;    int need_content_length_header=JK_FALSE;    /* Common initialization */    /* XXX Probably not needed, we're duplicating */    jk2_requtil_initRequest(env, s);        s->ws_private = r;    s->response_started = JK_FALSE;    s->read_body_started = JK_FALSE;    s->workerEnv=workerEnv;    workerEnv->childId = r->connection->child_num;    s->jvm_route        = NULL;    /* Used for sticky session routing */    s->auth_type    = NULL_FOR_EMPTY(r->connection->ap_auth_type);    s->remote_user  = NULL_FOR_EMPTY(r->connection->user);    s->protocol     = r->protocol;    s->remote_host  = (char *)ap_get_remote_host(r->connection,                                                 r->per_dir_config, REMOTE_HOST);    s->remote_host  = NULL_FOR_EMPTY(s->remote_host);    s->remote_addr  = NULL_FOR_EMPTY(r->connection->remote_ip);    /* get server name */    s->server_name= (char *)(r->hostname ? r->hostname :                 r->server->server_hostname);    s->server_port = htons(r->connection->local_addr.sin_port);    s->server_software = (char *)ap_get_server_version();    s->method         = (char *)r->method;    s->content_length = jk2_get_content_length(env, r);    s->is_chunked     = r->read_chunked;    s->no_more_chunks = 0;    s->query_string   = r->args;    /*     * The 2.2 servlet spec errata says the uri from     * HttpServletRequest.getRequestURI() should remain encoded.     * [http://java.sun.com/products/servlet/errata_042700.html]     *     * We use JkOptions to determine which method to be used     *     * ap_escape_uri is the latest recommanded but require     *               some java decoding (in TC 3.3 rc2)     *     * unparsed_uri is used for strict compliance with spec and     *              old Tomcat (3.2.3 for example)     *     * uri is use for compatibilty with mod_rewrite with old Tomcats     */    switch (workerEnv->options & JK_OPT_FWDURIMASK) {        case JK_OPT_FWDURICOMPATUNPARSED :            s->req_uri      = r->unparsed_uri;            if (s->req_uri != NULL) {                char *query_str = strchr(s->req_uri, '?');                if (query_str != NULL) {                    *query_str = 0;                }            }        break;        case JK_OPT_FWDURICOMPAT :            s->req_uri = r->uri;        break;        case JK_OPT_FWDURIESCAPED :            s->req_uri      = ap_escape_uri(r->pool, r->uri);        break;        default :            return JK_ERR;    }    s->is_ssl       = JK_FALSE;    s->ssl_cert     = NULL;    s->ssl_cert_len = 0;    s->ssl_cipher   = NULL;        /* required by Servlet 2.3 Api,                                    allready in original ajp13 */    s->ssl_session  = NULL;    s->ssl_key_size = -1;        /* required by Servlet 2.3 Api, added in jtc */    if(workerEnv->ssl_enable || workerEnv->envvars_in_use) {        ap_add_common_vars(r);        if(workerEnv->ssl_enable) {            ssl_temp =                 (char *)ap_table_get(r->subprocess_env,                                       workerEnv->https_indicator);            if(ssl_temp && !strcasecmp(ssl_temp, "on")) {                s->is_ssl       = JK_TRUE;                s->ssl_cert     =                     (char *)ap_table_get(r->subprocess_env,                                           workerEnv->certs_indicator);                if(s->ssl_cert) {                    s->ssl_cert_len = strlen(s->ssl_cert);                }                /* Servlet 2.3 API */                s->ssl_cipher   =                     (char *)ap_table_get(r->subprocess_env,                                           workerEnv->cipher_indicator);                 s->ssl_session  =                     (char *)ap_table_get(r->subprocess_env,                                           workerEnv->session_indicator);                if (workerEnv->options & JK_OPT_FWDKEYSIZE) {                    /* Servlet 2.3 API */                    ssl_temp = (char *)ap_table_get(r->subprocess_env,                                                  workerEnv->key_size_indicator);                    if (ssl_temp)                        s->ssl_key_size = atoi(ssl_temp);                }            }        }        jk2_map_default_create(env, &s->attributes, s->pool );                if(workerEnv->envvars_in_use) {            int envCnt=workerEnv->envvars->size( env, workerEnv->envvars );            int i;            for( i=0; i< envCnt ; i++ ) {                char *name= workerEnv->envvars->nameAt( env, workerEnv->envvars, i );                char *val= (char *)ap_table_get(r->subprocess_env, name);                if(val==NULL) {                    val=workerEnv->envvars->valueAt( env, workerEnv->envvars, i );                }                s->attributes->put( env, s->attributes, name, val, NULL );            }        }    }    jk2_map_default_create(env, &s->headers_in, s->pool );    if(r->headers_in && ap_table_elts(r->headers_in)) {        const array_header *t = ap_table_elts(r->headers_in);        if(t && t->nelts) {            int i;            table_entry *elts = (table_entry *)t->elts;            for(i = 0 ; i < t->nelts ; i++) {                s->headers_in->add( env, s->headers_in,                                    elts[i].key, elts[i].val);            }        }    }    if(!s->is_chunked && s->content_length == 0) {        /* XXX if r->contentLength == 0 I assume there's no header           or a header with '0'. In the second case, put will override it          */        s->headers_in->put( env, s->headers_in, "content-length", "0", NULL );    }    jk2_map_default_create(env, &s->headers_out, s->pool );    return JK_OK;}/* * If the servlet engine didn't consume all of the * request data, consume and discard all further * characters left to read from client * *  XXX Is it the right thing to do ????? Why spend the *  bandwith, the servlet decided not to read the POST then *  jk shouldn't do it instead, and the user should get the *  error message ! */static void JK_METHOD jk2_service_apache13_afterRequest(jk_env_t *env, jk_ws_service_t *s ){        if (s->content_read < s->content_length ||        (s->is_chunked && ! s->no_more_chunks)) {                request_rec *r=s->ws_private;        char *buff = ap_palloc(r->pool, 2048);        if (buff != NULL) {            int rd;            while ((rd = ap_get_client_block(r, buff, 2048)) > 0) {                s->content_read += rd;            }        }    }}int jk2_service_apache13_init(jk_env_t *env, jk_ws_service_t *s){    if(s==NULL ) {        return JK_ERR;    }    s->head   = jk2_service_apache13_head;    s->read   = jk2_service_apache13_read;    s->write  = jk2_service_apache13_write;    s->init   = jk2_init_ws_service;    s->afterRequest     = jk2_service_apache13_afterRequest;        return JK_OK;}

⌨️ 快捷键说明

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