A系统跨域访问其他系统页面

本文探讨了在一个新系统中嵌套老系统的实现方法及遇到的问题,特别是跨域问题的解决方案,包括修改jessionId名称尝试解决冲突及通过添加过滤器来允许特定源访问。

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

由于项目是对老系统进行技术升级改造,需要很长一段时间才会改造完毕,在改造过程为了不影响客户使用,所以决定在新系统不断改造的过程中,依然可以访问老系统,就是将老系统的页面嵌套见新系统,在嵌套的过程中遇到如下问题:当新系统拿着用户信息登陆进老系统,老系统的页面成功嵌套进新系统,但是在此点击老系统里面的功能时,弹出老系统的登陆界面。

1.认为是两个系统写在cookie中的jessionId冲突了,随即修改一个系统的jessionId名称,但是问题依然存在。

2.在新系统访问旧系统的时候,在旧系统添加过滤器代码带上Access-Control-Allow-Origin头信息解决跨域问题。

后台添加过滤器
 public void doFilter(ServletRequest servletRequest,
        ServletResponse servletResponse, FilterChain filterChain)
        throws IOException, ServletException {
       // TODO Auto-generated method stub
        //log.info("Adding Access Control Response Headers");
        HttpServletResponse response = (HttpServletResponse) servletResponse;
       // String origin =((HttpServletRequest) servletRequest).getHeader("Origin");
       String origin ="http://localhost:8080";
        response.setHeader("Access-Control-Allow-Origin", origin);
        response.setHeader("Access-Control-Allow-Credentials", "true");
        response.setHeader("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, HEAD, OPTIONS");
        response.setHeader("Access-Control-Allow-Headers", 
                "X-Requested-With, Origin, Accept, X-Request-With, Content-Type, Access-Control-Request-Method, Access-Control-Request-Headers, Date, Server, Cache-Control, withCredentials, AccessToken, User-Agent");
        response.setHeader("P3P", "CP=\"ALL IND DSP COR ADM CONo CUR CUSo IVAo IVDo PSA PSD TAI TELo OUR SAMo CNT COM INT NAV ONL PHY PRE PUR UNI\"");
        HttpServletRequest request = (HttpServletRequest) servletRequest;
        if ( request.getMethod().equals( "OPTIONS" ) ) {
            (response).setStatus(HttpServletResponse.SC_OK);
            return;
        }
        filterChain.doFilter(request, response);
    }

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值