通过netweaver跳转向tomcat中的项目传递登录者工号,单点登录

来源:互联网 发布:安卓平板 知乎 编辑:程序博客网 时间:2024/06/05 20:44


1 .  ManageController .java

package com.want.address.controller;

import java.net.URLEncoder;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletResponse;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;
import com.want.address.mo.UserContext;
import com.want.address.threadlocal.UserThreadLocal;

/**
 * 
 * @author 00301957
 *当前登录人跳转controller
 */
@Controller
public class ManageController {

@RequestMapping(value="manage")
    public ModelAndView testLogin(HttpServletResponse response) throws Exception{
ModelAndView modelAndView = new ModelAndView("manage");
       // 获取当前登录人员信息
        UserContext userContext = UserThreadLocal.get();

        //生成16位随机字符串
//        String string = "qwertyuiopasdfghjklzxcvbnmQAZWSXEDCRFVTGBYHNUJMIKOLP";
//        StringBuffer sb = new StringBuffer();
//        int len = string.length();
//        for (int i=0; i<16; i++) {
//            sb.append(string.charAt((int)Math.round(Math.random()*(len-1))));ssss//        }
//        String keyStr = sb.toString();
// String plainText = userContext.getAccount();

//加密工号
// String encUserCode = CryptAES.AES_Encrypt(keyStr, plainText);

modelAndView.addObject("key", userContext.getAccount());

//设置cookie
Cookie cookie = new Cookie("encUserCode", URLEncoder.encode("encUserCode", "UTF-8"));
cookie.setDomain("want-want.com");
cookie.setPath("/");
        response.addCookie(cookie);
        return modelAndView;
    }

}

2. UserThreadLocal.java

package com.want.address.threadlocal;
import com.want.address.mo.UserContext;

public class UserThreadLocal {
    private static final ThreadLocal<UserContext> USER = new ThreadLocal<UserContext>();
    public static void set(UserContext userContext) {
        USER.set(userContext);
    }
    public static UserContext get() {
        return USER.get();
    }
    public static void clear() {
        set(null);
    }
}


3. UserContext .java

package com.want.address.mo;
public class UserContext {
    public static final String USER_CONTEXT_KEY = "discussUserContext";
    private String account;
    private String userName;
    public String getAccount() {
        return account;
    }
    public void setAccount(String account) {
        this.account = account;
    }
    public String getUserName() {
        return userName;
    }
    public void setUserName(String userName) {
        this.userName = userName;
    }
}

4. 过滤器UserContextHandlerInterceptor .java

package com.want.address.intercepter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;
import com.sap.security.api.IUser;
import com.sap.security.api.UMFactory;
import com.want.address.mo.UserContext;
import com.want.address.threadlocal.UserThreadLocal;

public class UserContextHandlerInterceptor extends HandlerInterceptorAdapter {

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
            throws Exception {
        HttpSession session = request.getSession();
        UserContext userContext = (UserContext) session.getAttribute(UserContext.USER_CONTEXT_KEY);

        // 判断session中有没有记录当前登录人员的信息
        if (userContext == null) {
            // 创建空的 UserContext
            userContext = new UserContext();
            // 未登录清空ThreadLocal中的数据
            UserThreadLocal.clear();
            // 取得当前登录人员对应的account
            IUser user = UMFactory.getAuthenticator().forceLoggedInUser(request, response);

            userContext.setAccount(user.getUniqueName());
            userContext.setUserName(user.getLastName());

            // 将 UserContext 加入到 Session
            session.setAttribute(UserContext.USER_CONTEXT_KEY, userContext);
        }
        // 将用户存在ThreadLocal中
        UserThreadLocal.set(userContext);
        return super.preHandle(request, response, handler);
    }
}

5. springMVC-servlet.xml

<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
        http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd">
<!-- 注解驱动 -->
<mvc:annotation-driven>
<mvc:message-converters>
<!-- 避免IE执行AJAX时,返回JSON出现下载文件和406问题 -->
<bean id="mappingJacksonHttpMessageConverter"
class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
<property name="supportedMediaTypes">
<list>
<value>text/html;charset=UTF-8</value>
</list>
</property>
</bean>
</mvc:message-converters>
</mvc:annotation-driven>
<mvc:resources location="/image/" mapping="/image/**" />
<mvc:resources location="/css/" mapping="/css/**" />
<mvc:resources location="/js/" mapping="/js/**" />


<!-- 扫描包 -->
<context:component-scan base-package="com.want.address.controller" />

<!-- 视图解析器 -->
<bean
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="viewClass"
value="org.springframework.web.servlet.view.JstlView" />
<property name="prefix" value="/WEB-INF/view/" />
<property name="suffix" value=".jsp" />
</bean>

<mvc:interceptors>
<!-- 监测用户是否登录 -->
<mvc:interceptor>
<mvc:mapping path="/**" />
<bean class="com.want.address.intercepter.UserContextHandlerInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>

</beans>


6.  applicationContext.xml


<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
        http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd">
<!-- import properties -->
<!--<context:property-placeholder location="classpath:properties/*.properties" />-->
<!-- 扫描包 -->
<context:component-scan base-package="com.want.address" />
</beans>


7.  web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
  <display-name>DID_BPM_D~stand~address-book-export~war~com.want</display-name>
    
  <!-- 加载spring相关配置文件 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/applicationContext.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

<!-- 编码过滤器,以UTF8编码 -->
<filter>
<filter-name>encodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

<!-- 配置springMVC -->
<servlet>
<servlet-name>address-book-export</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/springMVC-servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>address-book-export</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>


8.  WEB-INF/view/manage.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort()
+ path + "/";
%>
<!DOCTYPE html>
<html>
<head>
<base href="<%=basePath%>">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>

</head>
<body>
正在加载中...
<script type="text/javascript">

window.onload = function(){

//alert("${key}");
var key = "${key}";
//开发环境
var URL = "http://tomcatdev.com/tomcatProject/login";
//获取域名  window.location.host 或  document.domain; 获取页面完整地址  window.location.href;
var domain = document.domain;

//判断域名为测试机域名,则地址切换测试地址
if(domain == "netweavertest.com"){
//测试环境
URL = "http://tomcattest.com/tomcatProject/login";
}
//判断域名为正式机域名,则地址切换正式地址
if(domain == "netweaverprd.com"){
//正式环境
URL = "http://tomcattest.com/tomcatProject/login";
}
    //设置样式为隐藏
    var formStr = '<form style="visibility:hidden;" method="POST" action="' + URL + '">' +
        '<input type="hidden" name="key" value="' + key + '" />' +
        '<input type="hidden" name="domain" value="' + domain + '" />' +
        '</form>';
        
    // document.body.innerHTML:表示获取或者设置body内包含的HTML代码
    document.body.innerHTML = formStr;   
    //document.forms[0]:表示获取当前页面的第一个表单 
    document.forms[0].submit();
}; 

</script>
</body>
</html>