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

📄 setcharacterencodingfilter.java~

📁 J2EE & Tomcat books published by hope
💻 JAVA~
字号:
/* * SetCharacterEncoding.java * * Created on February 5, 2002, 5:44 PM */package com.sun.j2ee.workflow.control.filters;import java.io.IOException;import javax.servlet.Filter;import javax.servlet.FilterChain;import javax.servlet.FilterConfig;import javax.servlet.ServletException;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import javax.servlet.http.HttpSession;import javax.servlet.ServletRequest;import javax.servlet.ServletResponse;import javax.servlet.UnavailableException;/** * Example filter that unconditionally sets the character encoding to be used * in parsing the incoming request to a value specified by the * <strong>encoding</string> filter initialization parameter in the web app * deployment descriptor (</code>/WEB-INF/web.xml</code>).  This filter could * easily be extended to be more intelligent about what character encoding to * set, based on characteristics of the incoming request (such as the values * of the <code>Accept-Language</code> and <code>User-Agent</code> headers, * or a value stashed in the current user's session). * * @author Craig McClanahan * @version $Revision: 1.1 $ $Date: 2002/02/08 00:30:09 $ *///modified by James Caipublic class SetCharacterEncodingFilter implements Filter {        // ----------------------------------------------------- Instance Variables            /**     * The default character encoding to set for requests that pass through     * this filter.     */    protected String encoding = null;            /**     * The filter configuration object we are associated with.  If this value     * is null, this filter instance is not currently configured.     */    protected FilterConfig filterConfig = null;            // --------------------------------------------------------- Public Methods            /**     * Take this filter out of service.     */    public void destroy() {                this.encoding = null;        this.filterConfig = null;            }            /**     * Select and set (if specified) the character encoding to be used to     * interpret request parameters for this request.     *     * @param request The servlet request we are processing     * @param result The servlet response we are creating     * @param chain The filter chain we are processing     *     * @exception IOException if an input/output error occurs     * @exception ServletException if a servlet error occurs     */    public void doFilter(ServletRequest request, ServletResponse response,    FilterChain chain)    throws IOException, ServletException {                // Select and set (if needed) the character encoding to be used        HttpServletRequest httprequest = (HttpServletRequest)request;        String encoding = null;        HttpSession session = httprequest.getSession();        String language = (String)session.getAttribute("tplanguage");        System.out.println("SetCharacterEncoding: language=" + language);                if ((language==null)&&(request.getParameter("language")!=null)) {            session.setAttribute("tplanguage", request.getParameter("language"));        }                if ((language!=null)&&(language.equals("Chinese"))) {            encoding = "gb2312";        }                if (encoding != null)            request.setCharacterEncoding(encoding);        // Pass control on to the next filter locale        chain.doFilter(request, response);        if ((language!=null)&&(language.equals("Chinese"))) {            response.setContentType("text/html;charset=gb2312");        }                    }            /**     * Place this filter into service.     *     * @param filterConfig The filter configuration object     */    public void init(FilterConfig filterConfig) throws ServletException {                this.filterConfig = filterConfig;        this.encoding = filterConfig.getInitParameter("encoding");            }            // ------------------------------------------------------ Protected Methods            /**     * Select an appropriate character encoding to be used, based on the     * characteristics of the current request and/or filter initialization     * parameters.  If no character encoding should be set, return     * <code>null</code>.     * <p>     * The default implementation unconditionally returns the value configured     * by the <strong>encoding</strong> initialization parameter for this     * filter.     *     * @param request The servlet request we are processing     */    protected String selectEncoding(ServletRequest request) {                return (this.encoding);            }        }

⌨️ 快捷键说明

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