前后台分离使用cookie判断用户状态以及传递参数

简介: 在之前学习servlet的时候,当时做的小网站需要登陆并且判断信息,当时使用session传值,使用fitter过滤判断,当时感觉哇,session咋这么好用,cookie是啥玩意,还不方便。

前言


  • 在之前学习servlet的时候,当时做的小网站需要登陆并且判断信息,当时使用session传值,使用fitter过滤判断,当时感觉哇,session咋这么好用,cookie是啥玩意,还不方便。
  • 后来在学习ssm做项目遇到需要登陆的状态,在html无法使用session,只能学习cookie了,对于cookie只是在爬虫中用过,为了爬去登陆后的页面,看来那些网站都是用cookie保持会话的呢。
  • 用了cookie发现cookie也很方便。但是js操作cookie很麻烦用jquery就很简单。
    前端需要引入


<script type="text/javascript" src="js/jquery.min.js"></script>
<script type="text/javascript" src="js/jquery.cookie.js"></script>


.添加一个"会话cookie"

$.cookie('cookie’name, ‘cookievalue’);

读取cookie

$.cookie(‘the_cookie’);

5.删除cookie

$.cookie(‘cookiename’, null); //通过传递null作为cookie的值即可

还有更多操作请百度。


后端操作demo



@RequestMapping(value="/admin")
public String admin(HttpServletRequest request, HttpServletResponse respose)
    {
        if(request.getMethod().equals("GET"))
        {
            Cookie[] cookies = request.getCookies();
            if(cookies!=null &&cookies.length>0)//判断是否已经登陆已经登陆
            {
                for (Cookie cookie : cookies) {
                    if(cookie.getName().equals("userid")&&cookie.getValue()!=null)
                    {
                        List<Map> map = foodmapper.getadmin(cookie.getValue());
                        if(map.size()>0)
                        return "admin";
                        else
                        {
                            return  "login";
                        }
                    }
                }
            }
            return "login";
        }
        else
        {
            String username = request.getParameter("username");
            List<Map> map = foodmapper.getadmin(username);
            if(map.size()==0){return "login";}
            String password = (String) map.get(0).get("password");
            System.out.println(password);
            if (username.equals(map.get(0).get("username"))&&password.equals(request.getParameter("password"))) {
                Cookie cookie = new Cookie("userid", username);
                respose.addCookie(cookie);
                return "admin";
            }
            else
            return "default";
        }
    }


对比起来还是客户端的cookie好用,他就像map一条记录,而后台的更像是cookie数组。需要遍历。

目录
相关文章
|
存储 编解码 Android开发
后台(13)——Cookie
探索Android软键盘的疑难杂症 深入探讨Android异步精髓Handler 详解Android主流框架不可或缺的基石 站在源码的肩膀上全解Scroller工作机制 Android多分...
1381 0
|
1月前
|
存储 自然语言处理 API
Session、cookie、token有什么区别?
Session、cookie、token有什么区别?
24 1
|
2月前
|
存储 开发框架 NoSQL
ASP.NET WEB——项目中Cookie与Session的用法
ASP.NET WEB——项目中Cookie与Session的用法
29 0
|
2月前
|
存储 安全 API
Cookie,Session和Token
Cookie,Session和Token
|
4天前
|
存储 JSON 安全
|
1月前
|
数据采集 存储 安全
登录态数据抓取:Python爬虫携带Cookie与Session的应用技巧
登录态数据抓取:Python爬虫携带Cookie与Session的应用技巧
|
1月前
|
存储 安全 搜索推荐
Django中Cookie和Session的使用
Django中Cookie和Session的使用
21 0
|
1月前
|
存储 安全 对象存储
Cookie和Session的区别:从原理到应用
【2月更文挑战第18天】
54 6
|
1月前
|
存储 搜索推荐 安全
【Web开发】cookie和session
【Web开发】cookie和session
|
2月前
|
存储 搜索推荐 安全
Java Web开发中的会话管理:Cookie与Session对比
Java Web开发中的会话管理:Cookie与Session对比