openfire插件中servlet的配置

本文介绍如何在Openfire插件中设置特定Servlet服务,使其可以在不经过认证的情况下被外部访问。通过修改AreaBroadcastServlet类及web-custom.xml配置文件,可以实现免认证访问功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录结构


1.servlet-AreaBroadcastServlet.java

如Openfire插件中提供对外的Servlet服务,访问地址: http://server:9090/plugins/xxxservice/xxservlet 
默认情况下访问该地址是会转向到Openfire认证界面,即需要认证才能访问该地址。 
要免认证访问,需要如以下代码实现: 
关键点是:SERVICE_NAME 采用插件所在文件夹名+servlet地址的写法。
public class AreaBroadcastServlet extends HttpServlet {
     private static final String SERVICE_NAME = "areaBroadcast/abservlet"; 
    @Override
    public void init(ServletConfig servletConfig) throws ServletException { 
        super.init(servletConfig); 
        AuthCheckFilter.addExclude(SERVICE_NAME); 

    } 
    
    @Override
public void doPost(HttpServletRequest request, HttpServletResponse response)
     {
//TODO:做你想做的处理

     }
    
    @Override
    public void doGet(HttpServletRequest request, HttpServletResponse response)
{
    doPost(request, response);
        }
    
    @Override
    public void destroy() { 
    super.destroy(); 
           AuthCheckFilter.removeExclude(SERVICE_NAME); 

    } 
}

2.web-custom.xml

<?xml version='1.0' encoding='ISO-8859-1'?>
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd">
<web-app>
    <!-- Servlets -->
    <servlet>
        <servlet-name>AreaBroadcastServlet</servlet-name>
        <servlet-class>com.channelsoft.openfire.plugin.AreaBroadcastServlet</servlet-class>
    </servlet>


    <!-- Servlet mappings -->
    <servlet-mapping>
        <servlet-name>AreaBroadcastServlet</servlet-name>
        <url-pattern>/ abservlet</url-pattern>
    </servlet-mapping>
    
</web-app>

注意: <url-pattern>/ abservlet</url-pattern>这个标黄的地方 一定要全小写,否则jsp页面无法找到该servlet,具体原因不明。


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值