springBoot集成jcifs

1、添加jcifs依赖包。

<dependency>
<groupId>jcifs</groupId>  
<artifactId>jcifs</artifactId>
<version>1.2.9</version>
</dependency>

2、在配置文件application.properties里添加jcifs的配置参数,也可新增独立的资源文件进行读取,在这里就不在赘述了。(账号密码自行向域控管理员申请)

jcifs.http.domainController=10.100.xxx.xx
jcifs.smb.client.domain=xxx.com
jcifs.smb.client.username=XXX
jcifs.smb.client.password=XXX

3、创建jcifs初始化NtlmHttpFilter 的子过滤器,在这里我只初始化了4个必须参数,其他参数见类中所展示的,根据项目需要进行配置。
注:在传统项目中是通过web.xml进行初始化,在springBoot项目中无法生效,难受~~~

import jcifs.Config;
import jcifs.http.NtlmHttpFilter;
/**
 * 初始化jcifs域控登录参数
 * @author ex_lihui
 * @date 2019/03/28
 */
public class JcifsFilter extends NtlmHttpFilter {

      public JcifsFilter(){};
      public JcifsFilter(String defaultDomain,String domainController,String loadBalance,String enableBasic,String insecureBasic,String realm,String level,String username,String password){
              Config.setProperty("jcifs.smb.client.domain",defaultDomain);            
              Config.setProperty("jcifs.http.domainController",domainController);    
              Config.setProperty("jcifs.smb.client.username",username);
              Config.setProperty("jcifs.smb.client.password",password);
            /*Config.setProperty("jcifs.http.loadBalance",loadBalance);            
            Config.setProperty("jcifs.http.enableBasic",enableBasic);            
            Config.setProperty("jcifs.http.insecureBasic",insecureBasic);            
            Config.setProperty("jcifs.http.basicRealm",realm);            
            Config.setProperty("jcifs.util.loglevel",level);*/
      };

}

附录,传统初始化方式。

 <filter> 
    <filter-name>NtlmHttpFilter</filter-name> 
    <filter-class>jcifs.http.NtlmHttpFilter</filter-class> 
    <init-param>
        <param-name>jcifs.smb.client.soTimeout</param-name>
      <param-value>5000</param-value>
    </init-param>
    <!--域服务器地址-->
    <init-param> 
        <param-name>jcifs.http.domainController</param-name> 
        <param-value>192.16.xxx.xx</param-value> 
    </init-param>
    <!--域服务器域名-->
    <init-param> 
        <param-name>jcifs.smb.client.domain</param-name> 
        <param-value>xxx</param-value> 
    </init-param> 
    <init-param> 
     <param-name>jcifs.util.loglevel</param-name> 
     <param-value>2</param-value> 
    </init-param>
    <!--域服务器账号-->
    <init-param>
        <param-name>jcifs.smb.client.username</param-name>
        <param-value>xxxxxx</param-value>
    </init-param>
    <!--域服务器密码-->
    <init-param>
        <param-name>jcifs.smb.client.password</param-name>
        <param-value>xxxxxx</param-value>
    </init-param>
    <init-param>
      <param-name>jcifs.smb.lmCompatibility</param-name>
      <param-value>0</param-value>
    </init-param>
    <init-param>
      <param-name>jcifs.smb.client.useExtendedSecurity</param-name>
      <param-value>false</param-value>
    </init-param>
 </filter> 
 <filter-mapping> 
    <filter-name>NtlmHttpFilter</filter-name> 
    <url-pattern>/*</url-pattern> 
 </filter-mapping>

 4、在springBoot启动类中进行拦截器的注册配置。

    /**
     * 代码方式注册Bean
     * @return
     */
    @Bean
    public FilterRegistrationBean setFilter(){

        FilterRegistrationBean filterBean = new FilterRegistrationBean();
        JcifsFilter ntl = new JcifsFilter(defaultDomain, domainController, loadBalance, enableBasic, insecureBasic, realm, level,username,password);
        filterBean.setFilter(ntl);
        filterBean.setName("NtlmHttpFilter");
        //配置需要获取域控的请求路径也可以直接配置 '/*'(代表全部都会进行域控加载)
            filterBean.addUrlPatterns(
                /*"/",*/
                "/index/*"
                );
        filterBean.setOrder(1);//设置级别最高
        return filterBean;
    }

5、启动项目访问即可获取域用户,在需要的地方调用如下方法即可获取,一般放在过滤器中,当session中没有用户信息再去域控获取。

例:
String userId = (String) request.getSession().getAttribute(ConstKey.SESSION_USERID.getKey());
if(StringUtils.isBlank(userId)){
        userId=UserUtil.parseUserName(request);
}

UserUtil.class
//获取域控userId的封装方法
public static String parseUserName(HttpServletRequest request){
        String userId = request.getRemoteUser(); // JAAS 认证通过
        if (userId != null && userId.indexOf("\\") > 0)
        {
            userId = userId.substring(userId.indexOf("\\") + 1).trim();
        } else if (userId != null && userId.indexOf("@") > 0)
        {
            userId = userId.substring(0, userId.indexOf("@")).trim();
        }
        return userId;
    }

 

posted @ 2020-03-10 15:43  曾经的路  阅读(2510)  评论(1编辑  收藏  举报