- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在创建一个信息系统来处理财务信息、联系人等。我正在使用面向对象的编程(类、函数等)从头开始开发网站。大部分数据将来自 MySQL 数据库。用户将能够获取数据并将其提交到数据库。
我已经在使用散列函数来加密数据,例如密码、序列号。我还对进入数据库的所有其他数据使用 preg_replace() 函数。
我需要采取哪些其他安全措施来确保从数据库提交和获取数据不会危及安全性?
最佳答案
md5 是 cryptographic hash function 。一旦散列,它不能被“取消散列”回到原始值(单向)而不是 encryption这是双向的(加密-解密)。
为了您的数据安全,考虑这些场景和预防方法而不仅仅是加密:
cross-site request forgeries (CRSF) - 防止使用表单标记
SSL connection (“httpS://”)以防止传输中的数据拦截
hash salting进一步保护(但不是完全)散列密码免受字典攻击。弱密码和普通密码是这种情况下的目标。
散列不是绝对的。散列中字母和数字的组合数量是有限制的。在某些时候,截然不同的字符串可能具有相同的哈希值。这被称为 collision
哈希容易受到暴力/字典攻击。尽管哈希是一种方式,但可以创建一个字符串哈希字典,匹配哈希并找出其背后的字符串。
cross-site scripting (XSS),其中可能包括(但不限于)cookie 窃取、点击劫持等。
SQL injection - 在表单未清理时欺骗 SQL 的方法
消耗品 session ids跟踪用户 session - 它应该在给定的时间内过期,因此有一个自动注销机制。
确定您的用户!用户 ip 地址、浏览器检测等来分析您的用户。任何奇怪的数据(如 IP、位置等的突然变化)都应在一定的阈值内考虑。 (facebook 有这个功能。我曾经使用代理访问我的 facebook - 自动锁定)
关于PHP 和 MySQL $_POST 安全和 md5() 散列函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9073440/
我想在 md-toolbar 中使用 mf-tabs,我使用 Sithdown 在 https://github.com/angular/material/issues/1076 中提供的解决方案 它
我是新手,我设法用服务提供的数据实现了我的 md-table。现在我正在尝试实现过滤器、排序和分页功能,但我认为我做错了什么。 这是我的组件: import { Component, OnInit,
我必须打开一个 md-dialog,其中包含一个带有两个选项卡的 md-tab-group。 md-dialog 可以从两个按钮打开,这两个按钮应该打开相应的选项卡。打开 md-dialog 的模板:
我正在尝试做这样的事情: {{item}}
我正在尝试使用 md-datepicker 遍历一个月的时间间隔,因此我创建了这个 codepen 示例以便更好地演示: http://codepen.io/anon/pen/ygBGOg 当单击“P
这是关于 Codepen 的例子. 我正在设置 md-row-height="30px" 然后计算 md-rowspan 使其等于元素数 + 1。(头部加一) {{ t
当我频繁切换 md-tabs 时,Md-tabs 切换正确但多个 md-tab-item 元素同时具有“md-active”类,所以我看不到选项卡的内容是事件的,因为它与其右侧选项卡的内容重叠。 据我
我想将操作放在同一数据行上,我有两个操作,为此我使用按钮和图标作为下面的代码。 {{item.codigo}} {{it
在我的对象列表中,我可以激活/非事件对象。因此,一个图标执行事件操作,另一个图标执行非事件操作,并且两者都在同一个 md-list 中。 This is what i'm tring to do 代码
如前所述 Angular-Material md-autocomplete's documentation : The md-autocomplete uses the the md-virtual-
我也在使用 Angular 1 和 Angular Material 。我想在 ng-repeat 中使用 md-subheader 和多个 md-virtual-repeat-container。您
我正在使用 Angular Material 。 当我创建自己的指令并将其添加到 md-tab-label 时,例如 Label 然后自定义指令也应用于一些“md-dummy-tab”。 但是
我在我的项目中使用 Angular Material 有一段时间了。在使用 md-select 时,我遇到了一个问题,即出现重复的 md-option 值错误。 我知道 md-options 采用唯一
我正在根据单选按钮选择设置自动完成验证 md-require-match = true/false。 默认验证是 md-require-match = true 这样用户应该从自动完成列表中选择一个项
这个问题在这里已经有了答案: Changing capitalization of filenames in Git (11 个答案) 关闭 3 年前。 我使用“readme.md”创建了我的存储库
Github有办法吗?在例如 README.md 中包含 md 文件? # Headline Text [include](File:load_another_md_file_here.md) 它不应
我正在使用 AngularJs 开发这个动态过滤系统,并试图找出如何将 color 和 size 选项转换为在两个下拉列表中(每个类别一个)。 我尝试了以下代码,该代码成功添加了下拉列表以及选择框中的
var app = angular.module('tabsDemo', ['ngMaterial']); app.controller('TabsController',tabsController
在 md-tab 指令内嵌套 md-select 和搜索输入时遇到问题。 有两个问题: 选择框展开后,必须向上滚动才能查看搜索输入 搜索输入实际上不接受任何文本 我做了一个codepen为了更好地说明
我正在尝试处理这个片段,其中自动完成功能嵌入在芯片中。但从自动完成中选择的项目不会转换为筹码。 自动完成的数据采用以下方式:{name:"John Doe", id:"1"} 哪里错了,请指教。 问候
我是一名优秀的程序员,十分优秀!