Token技术的功能及实现
来源:互联网 发布:北京数据堂公司英语 编辑:程序博客网 时间:2024/06/05 22:51
Token功能及其技术及其实现
目前就知道Token功能就两种:
1.防止表单重复提交
2.用来作身份验证
1.下面来介绍其用法
下面根据以上流程用代码演示
我写了两个页面 一个是主页 会跳转到添加页面 第二个是添加页面 模拟用户提交数据场景
说明下 token一般放在隐藏域中 在这里方便大家看 没有隐藏
主要说明下后台的代码
token其实只要是任何字符串都行 这里用到的是uuid 是通用唯一识别码,而且每次请求到添加页面都会生成不同的uuid(token)
//跳转到添加页面 @RequestMapping("/add.do") public String add(HttpServletRequest request,HttpServletResponse response){ //生成token UUID token=UUID.randomUUID(); System.out.println("token的值"+token); //放入session中 request.getSession().setAttribute("token", token.toString()); //放入request作用域中传到前台 request.setAttribute("token", token); return "add"; } //前台穿过来的token进行比对 @RequestMapping("/addMessage.do") public synchronized String addMessage(HttpServletRequest request){ //获取session中的token Object token1=request.getSession().getAttribute("token"); //获取前台穿过来的token String token=request.getParameter("token"); System.out.println("token1的值"+token1); if(token1==null){ System.out.println("提交出错"); } else if(!token1.equals(token)){ System.out.println("提交出错"); }else{ System.out.println("提交成功"); //移除session 防止重复提交 request.getSession().removeAttribute("token"); } return ""; }
后台显示结果
token的值589a5d93-ceab-4b95-9820-b9e6d980be6ftoken1的值589a5d93-ceab-4b95-9820-b9e6d980be6f提交成功
2.基于Token的身份验证
使用基于 Token 的身份验证方法,在服务端不需要存储用户的登录记录。大概的流程是这样的:
1.客户端使用用户名跟密码请求登录
2.服务端收到请求,去验证用户名与密码验证成功后,服务端会签发一个 Token,再把这个 Token 发送给客户端
3.客户端收到 Token 以后可以把它存储起来,比如放在 Cookie 里或者 Local Storage 里客户端每次向服务端请求资源的时候需要带着服务端签发的 Token服务端收到请求,然后去验证客户端请求里面带着的 Token,如果验证成功,就向客户端返回请求的数据
看过一篇文章好像ofo里面也有用到Token。目前只知道这么多了,有问题的都可以评论,留言指出大家共同进步。
阅读全文
3 0
- Token技术的功能及实现
- 物理隔离功能及实现技术分析
- Git及Token的使用
- token的使用及原理
- token的使用及原理
- 利用php-cli和任务计划实现刷新token的功能
- 网闸——物理隔离功能及实现技术分析
- 车牌识别算法实现的技术功能
- rest token的一个实现
- 利用GUID/UUID生成token及验证token的正确性
- hbase分页功能的实现及源码
- Linux inotify的功能及实现原理
- 实现一组功能的步骤及模板
- 论区域健康一卡通的技术及功能
- Dorado7功能及技术特点
- 半透明及透明位图的实现技术
- 标签页及分页技术的实现
- 常用的基于token的实现方案
- React Native 源码浅析
- java
- caffe下学习速率调整策略
- Struts2+poi实现Excel文件上传并插入数据库的操作
- 线段树部分总结 (单点,区间)更新,区间求和,求最大值(敌兵布阵&I Hate It&A Simple Problem with Integers)
- Token技术的功能及实现
- ExecutorService+LruCache+DiskLruCache用一个类打造图片加载库
- Ajax简单介绍及使用
- Linux安装软件方式介绍
- Etcd常用命令
- leetcode-- Maximmum Product of Three Numbers
- Intent
- 8.20 NP问题
- mysql解压版 使用方式——for windows