一个WEB应用:类似商城吧,有很多用户注册,每个用户都有自己的购物车,用户A登录(与服务器密码比对,),这个用户提交一个表单表示自己要买这个东西,服务器接收数据,给购物车添加数据。
问题:
那个提交的表单是不是一定要附上用户的信息呢,要不然服务器怎么知道给的购物车添加数据呢?
一般实际应用中,怎么确认请求时用户A发来的而不是其他人
java 扫盲问题
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- jinnianshilongnian 2012-08-30 19:25关注
有两种方案:
1、Session:把数据存储在客户端
只要用户登录后,把用户信息放到session中(每个session是和客户端绑定的);
购物车数据也存在session中;每个登录的用户 只能拿到自己的session(不会冲突),这个是客户端JSESSIONID发送到服务器,服务器再根据JSESSIONID去取session,JSESSIONID是不重复的,因此每个客户只能拿到自己的Session;
这种方案缺点:session有过期时间,购物车数据会伴随session销毁而销毁
2、Coookie:把数据存储在客户端
用户登录后会写一个cookie 存储用户信息,每次用户请求都会把这个cookie带过去,然后根据cookie信息拿到用户信息;
购物车数据 也是存储在cookie中,比如默认30天失效,这样只要客户端不清理cookie 则数据一直是在的;
比如京东就是这么干:id是产品编号 n是数量
cart-jd="{&mgs&:[{&i&:22676557$&n&:1$&st&:10$&ps&:[{&i&:11004098$&n&:1$&at&:0$&ct&:1}${&i&:11020839$&n&:1$&at&:0$&ct&:1}${&i&:11020024$&n&:1$&at&:0$&ct&:1}${&i&:11046388$&n&:1$&at&:0$&ct&:1}${&i&:11046389$&n&:1$&at&:0$&ct&:1}${&i&:11046387$&n&:1$&at&:0$&ct&:1}]}]$&y&:{}$&by&:false$&rs&:[11004098$11020839$11020024$11046388$11046389$11046387]$&tm&:&Aug 24$ 2012 9:22:27 AM&$&st&:&bo&}当当比京东稍微做的好点:在客户端只存储数量 和 购物车id
cart_items_count=2;cart_id=1206021344147237;
然后在服务器端会存储购物车id 和 购物车数据(比如memcached或数据库等)相对来说 京东的比较简单 当当的稍微复杂 但性能肯定比京东快点(不需要来回传大量cookie数据) 而且cookie一般有大小限制 如4k
所以京东的购物车 有大小限制,,当当的理论上无限制
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 QT6颜色选择对话框显示不完整
- ¥20 能提供一下思路或者代码吗
- ¥15 用twincat控制!
- ¥15 请问一下这个运行结果是怎么来的
- ¥15 单通道放大电路的工作原理
- ¥30 YOLO检测微调结果p为1
- ¥15 DS18B20内部ADC模数转换器
- ¥15 做个有关计算的小程序
- ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
- ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下