请问Article表把主键暴露在URL中好吗?
Django
为每个表自动生成了id字段,但这个问题跟Django联系不大。
假设有一个Article表
,包含主键
,那么我在url访问时直接使用该表的主键id
,从安全性和性能
方面考虑,这样好吗?比如说,Article表中有一条记录,id
为10051
,而网址http://example.com/article/10051
来显示该文章。
这样做能方便用户访问,因为知道某个文章的id,可以猜测其他文章的id来访问不同文章,但是直接把主键暴露在url中,会不会让黑客很容易能猜到数据库的结构从而引起安全方面
的问题。
这样的应用场景,有没有什么要注意的或者一般方案呢?
使用UUID。
你的担心,主要在防范黑客入侵上面。
为什么不找找这方面的资料?
例如: PPTP、L2TP、SSL、...?
太少的信息也不会引起猜测表结构
来一次加随机盐的hash不就行了,随机盐直接明文保存在客户端session里就行了。
并没有什么不妥的地方。但是要考虑场景。比如电商系统
中,如果查看订单号,把自增主键暴漏了,那无疑是暴露了平台的销售情况,给竞争对手来说无疑是绝好的资料。但是至于安全方面却没有什么值得注意的地方,无非还是防止注入什么的。再比如多用户博客系统,暴漏id那就无疑暴漏了平台的总注册用户数、总文章数、总发帖、评论回复数等。同样也对安全没有什么影响。
如果是公开的问题不大的。但是如果是涉及权限,例如 id A不能被用户x 看到,那么就需要注意,因为用户可以通过改动id来跳转到不同的文章(暂且这么叫)
玩蛇网文章,转载请注明出处和文章网址:https://www.iplaypy.com/wenda/wd18600.html
相关文章 Recommend
- • 列表里边是元组数据,用python正则怎么完成匹配
- • 想转业学python,请问应该如何规划自己的学习计划
- • Python正则表达式匹配不成功,值为None
- • python web框架webpy urls对应表在修改之后不会立即生
- • SQLAlchemy修改了模型结构后,如何更新到已有数据
- • 请问python外部模块可以在Jinja2模板里使用吗?
- • 自定义form表单如何能让内容全显示在一行上
- • 请问APNS推送消息条数有什么限制?最大一次能发多
- • Python语言**kwargs同*args各代表什么含义及使用范围
- • Python MySQLdb模块问题多表连接key查询
- • 请问Python语言中is与双等号==有什么区别及作用
- • python提交表单并获取页面操作方法,求解答
必知PYTHON教程 Must Know PYTHON Tutorials
- • python 解释器
- • python idle
- • python dir函数
- • python 数据类型
- • python type函数
- • python 字符串
- • python 整型数字
- • python 列表
- • python 元组
- • python 字典
- • python 集合
- • python 变量
- • python print
- • python 函数
- • python 类定义
- • python import
- • python help
- • python open
- • python 异常处理
- • python 注释
- • python continue
- • python pass
- • python return
- • python global
- • python assert
- • python if语句
- • python break
- • python for循环
- • python while循环
- • python else/elif
- • lambda匿名函数
必知PYTHON模块 Must Know PYTHON Modules
- • os 模块
- • sys 模块
- • re 正则表达式
- • time 日期时间
- • pickle 持久化
- • random 随机
- • csv 模块
- • logging 日志
- • socket网络通信
- • json模块
- • urlparse 解析URL
- • urllib 模块
- • urllib2 模块
- • robotparser 解析
- • Cookie 模块
- • smtplib 邮件
- • Base64 编码
- • xmlrpclib客户端
- • string 文本
- • Queue 线程安全
- • math数学计算
- • linecache缓存
- • threading多线程
- • sqlite3数据库
- • gzip压缩解压
最新内容 NEWS
- • django app提供pv信息的方法是什么
- • Django项目版本升级如何操作?
- • django较多数据传递如何优雅的呈现
- • django1.7获取参数问题求助
- • Django1.7使用内置comment遇到问题
- • python mysql数据库做insert操作时报_mysql_ex
- • 关于python mysql的duplicate insert机制的疑问
- • pymongo使用insert函数批量插入被中断要怎么
- • Python程序员解决棘手问题的常用库
- • 求助关于restfull api接口几个问题
图文精华 RECOMMEND
-
django1.7获取参数问题求助
-
Python程序员解决棘手问题的常用库
-
求问str()同__str__原理上有什么不同
-
scrapy框架里面用link extractor怎么能
-
python {}.fromkeys创建字典append添加操
-
python3 类型Type str doesn't support th
热点文章 HOT
- 学习Python有什么好的书籍推荐?
- Python匿名函数 Lambda表达式作用
- Python与Java、C、Ruby、PHP等编程语言有什么
- Python 正则中文网页字符串提取问题
- 如何为实时性应用存取经纬度?django my
- 想用python做个客户端,在二维码登录这个地
- 有让IDE可识别Python函数参数类型的方法吗
- Python字符串转换成列表正则疑问