V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
tctc4869
V2EX  ›  Java

现在的 Java web 用原生的 Session 做用户状态控制不安全吗?

  •  
  •   tctc4869 · 2019-12-15 22:37:47 +08:00 · 3649 次点击
    这是一个创建于 1837 天前的主题,其中的信息可能已经有所发展或是发生改变。

    如题,session,是指浏览器里的 cookie 里的那个 JSESSIONID 么?服务端根据 cookie 里的这个来做客户端状态控制?能凭那个 JSESSIONID 就能劫持攻击吗?如果是这样的话,那得自己用缓存框架,根据安全需要来定制用户状态控制了?或者用 token ?

    10 条回复    2019-12-26 11:26:16 +08:00
    joooooker21
        1
    joooooker21  
       2019-12-15 22:40:11 +08:00
    还要考虑集群环境下 session 如果共享的问题
    joooooker21
        2
    joooooker21  
       2019-12-15 22:40:22 +08:00
    如果 -> 如何
    tctc4869
        3
    tctc4869  
    OP
       2019-12-15 22:44:42 +08:00
    @joooooker21 目前硬件环境还只是单个服务器,用 session,只是简单方便。如果是为了集群分布式,那是以后了,我现在比较关心的是 session 的安全问题
    jugelizi
        4
    jugelizi  
       2019-12-15 22:45:18 +08:00
    xss 和 csrf 了解下 如何防御
    chendy
        5
    chendy  
       2019-12-16 07:54:43 +08:00
    浏览器环境还是 cookie-session + csrf token
    dilu
        6
    dilu  
       2019-12-16 08:44:47 +08:00 via Android
    其实你这是逻辑问题,不是技术问题。
    假设你用了 token,我作为一个第三者,都能拿到用户 session 了为什么不能拿到 token ?
    要在逻辑上去处理,例如充值提现这种敏感操作需要短信验证等等。
    jorneyr
        7
    jorneyr  
       2019-12-16 08:50:15 +08:00
    源头泄漏没有什么好办法能够阻止了,一般的被劫持指的是中间环节。
    coang
        8
    coang  
       2019-12-16 10:48:09 +08:00
    现在 web 前后端分离 没有 session 一说 一开始就使用自己模拟 session 往后扩展可以少一点坑
    tctc4869
        9
    tctc4869  
    OP
       2019-12-17 09:01:36 +08:00
    @coang 只能使用 redis 之类的远程缓存库框架来做 session 缓存吗
    coang
        10
    coang  
       2019-12-26 11:26:16 +08:00
    @tctc4869 单机可以直接用 EhCache 到时候扩展再用别的也行..
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5291 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 03:45 · PVG 11:45 · LAX 19:45 · JFK 22:45
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.