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

📄 jk_urimap.h

📁 Tomcat 4.1与WebServer集成组件的源代码包.
💻 H
字号:
/* ========================================================================= * *                                                                           * *                 The Apache Software License,  Version 1.1                 * *                                                                           * *          Copyright (c) 1999-2001 The Apache Software Foundation.          * *                           All rights reserved.                            * *                                                                           * * ========================================================================= * *                                                                           * * Redistribution and use in source and binary forms,  with or without modi- * * fication, are permitted provided that the following conditions are met:   * *                                                                           * * 1. Redistributions of source code  must retain the above copyright notice * *    notice, this list of conditions and the following disclaimer.          * *                                                                           * * 2. Redistributions  in binary  form  must  reproduce the  above copyright * *    notice,  this list of conditions  and the following  disclaimer in the * *    documentation and/or other materials provided with the distribution.   * *                                                                           * * 3. The end-user documentation  included with the redistribution,  if any, * *    must include the following acknowlegement:                             * *                                                                           * *       "This product includes  software developed  by the Apache  Software * *        Foundation <http://www.apache.org/>."                              * *                                                                           * *    Alternately, this acknowlegement may appear in the software itself, if * *    and wherever such third-party acknowlegements normally appear.         * *                                                                           * * 4. The names  "The  Jakarta  Project",  "Jk",  and  "Apache  Software     * *    Foundation"  must not be used  to endorse or promote  products derived * *    from this  software without  prior  written  permission.  For  written * *    permission, please contact <apache@apache.org>.                        * *                                                                           * * 5. Products derived from this software may not be called "Apache" nor may * *    "Apache" appear in their names without prior written permission of the * *    Apache Software Foundation.                                            * *                                                                           * * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED WARRANTIES * * INCLUDING, BUT NOT LIMITED TO,  THE IMPLIED WARRANTIES OF MERCHANTABILITY * * AND FITNESS FOR  A PARTICULAR PURPOSE  ARE DISCLAIMED.  IN NO EVENT SHALL * * THE APACHE  SOFTWARE  FOUNDATION OR  ITS CONTRIBUTORS  BE LIABLE  FOR ANY * * DIRECT,  INDIRECT,   INCIDENTAL,  SPECIAL,  EXEMPLARY,  OR  CONSEQUENTIAL * * DAMAGES (INCLUDING,  BUT NOT LIMITED TO,  PROCUREMENT OF SUBSTITUTE GOODS * * OR SERVICES;  LOSS OF USE,  DATA,  OR PROFITS;  OR BUSINESS INTERRUPTION) * * HOWEVER CAUSED AND  ON ANY  THEORY  OF  LIABILITY,  WHETHER IN  CONTRACT, * * STRICT LIABILITY, OR TORT  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN * * ANY  WAY  OUT OF  THE  USE OF  THIS  SOFTWARE,  EVEN  IF  ADVISED  OF THE * * POSSIBILITY OF SUCH DAMAGE.                                               * *                                                                           * * ========================================================================= * *                                                                           * * This software  consists of voluntary  contributions made  by many indivi- * * duals on behalf of the  Apache Software Foundation.  For more information * * on the Apache Software Foundation, please see <http://www.apache.org/>.   * *                                                                           * * ========================================================================= *//** * Manages the request mappings. It includes the internal mapper and all * properties associated with a location ( or virtual host ). The information * is set using: *   - various autoconfiguration mechanisms. *   - uriworkers.properties *   - JkMount directives *   - <SetHandler> and apache specific directives. *   - XXX workers.properties-like directives ( for a single config file ) *   - other server-specific directives * * The intention is to allow the user to use whatever is more comfortable * and fits his needs. For 'basic' configuration the autoconf will be enough, * server-specific configs are the best for fine-tunning, properties are * easy to generate and edit. * * * Author: Gal Shachor <shachor@il.ibm.com> * author: Costin Manolache */#ifndef JK_URIMAP_H#define JK_URIMAP_H#include "jk_global.h"#include "jk_env.h"#include "jk_logger.h"#include "jk_uriEnv.h"#include "jk_map.h"#include "jk_pool.h"#ifdef __cplusplusextern "C" {#endif /* __cplusplus */struct jk_uriMap;struct jk_map;struct jk_env;struct jk_pool;    typedef struct jk_uriMap jk_uriMap_t;struct jk_uriMap {    struct jk_bean *mbean;    /* All mappings */    struct jk_map *maps;    struct jk_workerEnv *workerEnv;    /* Virtual host map. For each host and alias there is one     * entry, the value is a uriEnv that corresponds to the vhost top     * level.     */    struct jk_map *vhosts;    /* Virtual host map cache. Once processed the mapped host     * will be cached for performance reasons.     */    struct jk_map *vhcache;    /* ---------- Methods ---------- */    /** Initialize the map. This should be called after all workers        were added. It'll check if mappings have valid workers.    */    int (*init)( struct jk_env *env, jk_uriMap_t *_this);    void (*destroy)( struct jk_env *env, jk_uriMap_t *_this );        int (*addUriEnv)(struct jk_env *env,                     struct jk_uriMap *uriMap,                     struct jk_uriEnv *uriEnv);    /** Check the uri for potential security problems     */    int (*checkUri)( struct jk_env *env, jk_uriMap_t *_this,                     const char *uri );    /** Mapping the uri. To be thread safe, we need to pass a pool.        Or even better, create the jk_service structure already.        mapUri() can set informations on it as well.                MapUri() method should behave exactly like the native apache2        mapper - we need it since the mapping rules for servlets are        different ( or we don't know yet how to 'tweak' apache config        to do what we need ). Even when we'll know, uriMap will be needed        for other servers.     */    struct jk_uriEnv *(*mapUri)(struct jk_env *env, jk_uriMap_t *_this,                                const char *vhost,                                int port,                                const char *uri);        /* -------------------- @deprecated -------------------- */    /* used by the mapper, temp storage ( ??? )*/    /* pool for mappings. Mappings will change at runtime, we can't     * recycle the main pool.    */    struct jk_pool  *pool;};    #ifdef __cplusplus}#endif /* __cplusplus */#endif /* JK_URI_MAP_H */

⌨️ 快捷键说明

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