前后台分离使用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数组。需要遍历。

目录
相关文章
|
6月前
|
存储 安全 关系型数据库
安全开发-PHP应用&留言板功能&超全局变量&数据库操作&第三方插件引用&后台模块&Session&Cookie&Token&身份验证&唯一性
安全开发-PHP应用&留言板功能&超全局变量&数据库操作&第三方插件引用&后台模块&Session&Cookie&Token&身份验证&唯一性
|
存储 编解码 Android开发
后台(13)——Cookie
探索Android软键盘的疑难杂症 深入探讨Android异步精髓Handler 详解Android主流框架不可或缺的基石 站在源码的肩膀上全解Scroller工作机制 Android多分...
1426 0
|
1天前
|
存储 前端开发 Java
【SpringMVC】——Cookie和Session机制
获取URL中参数@PathVarible,上传文件@RequestPart,HttpServerlet(getCookies()方法,getAttribute方法,setAttribute方法,)HttpSession(getAttribute方法),@SessionAttribute
|
1月前
|
存储 安全 搜索推荐
理解Session和Cookie:Java Web开发中的用户状态管理
理解Session和Cookie:Java Web开发中的用户状态管理
72 4
|
1月前
|
存储 缓存 网络协议
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点,GET、POST的区别,Cookie与Session
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点、状态码、报文格式,GET、POST的区别,DNS的解析过程、数字证书、Cookie与Session,对称加密和非对称加密
|
2月前
|
缓存 Java Spring
servlet和SpringBoot两种方式分别获取Cookie和Session方式比较(带源码) —— 图文并茂 两种方式获取Header
文章比较了在Servlet和Spring Boot中获取Cookie、Session和Header的方法,并提供了相应的代码实例,展示了两种方式在实际应用中的异同。
209 3
servlet和SpringBoot两种方式分别获取Cookie和Session方式比较(带源码) —— 图文并茂 两种方式获取Header
|
2月前
|
存储 安全 数据安全/隐私保护
Cookie 和 Session 的区别及使用 Session 进行身份验证的方法
【10月更文挑战第12天】总之,Cookie 和 Session 各有特点,在不同的场景中发挥着不同的作用。使用 Session 进行身份验证是常见的做法,通过合理的设计和管理,可以确保用户身份的安全和可靠验证。
35 1
|
3月前
|
存储 缓存 数据处理
php学习笔记-php会话控制,cookie,session的使用,cookie自动登录和session 图书上传信息添加和修改例子-day07
本文介绍了PHP会话控制及Web常用的预定义变量,包括`$_REQUEST`、`$_SERVER`、`$_COOKIE`和`$_SESSION`的用法和示例。涵盖了cookie的创建、使用、删除以及session的工作原理和使用,并通过图书上传的例子演示了session在实际应用中的使用。
php学习笔记-php会话控制,cookie,session的使用,cookie自动登录和session 图书上传信息添加和修改例子-day07
|
3月前
|
存储 前端开发 Java
JavaWeb基础7——会话技术Cookie&Session
会话技术、Cookie的发送和获取、存活时间、Session钝化与活化、销毁、用户登录注册“记住我”和“验证码”案例
JavaWeb基础7——会话技术Cookie&Session