草庐IT

password-protection

全部标签

php - 为什么人们在声明类时经常省略 public/private/protected?

我经常在最近的代码中甚至在这里看到这种格式:classClass{functionthis(){}}代替classClass{[public/private/protected]functionthis(){}}难道不建议总是指定功能范围?第一种方法不是很老吗?在第一种方法中,如何定义为私有(private)和protected功能? 最佳答案 当您声明一个没有任何默认public关键字的函数时。Isn'titrecommendedtoalwaysspecifythefunctionscope?如果要将它们用作私有(private)

PHP password_hash() password_verify() 最大密码长度?

我可以在PHP5.5password_hash()和password_verify()中使用的最大密码长度是多少? 最佳答案 好的,让我们来看看这个。函数确实有密码长度限制。就像PHP中的所有字符串一样,它被限制为2^31-1个字节。需要明确的是,PHP无法处理比这更大的任何事情(至少在今天)。所以功能本身是有限的。但是底层的加密算法呢。BCrypt仅限于处理密码的前72个字符。然而,这通常不是问题asexplainedinthisanswer.所以简而言之,是的它确实有一个有效的限制(它只会使用默认且唯一的算法“使用”前72个字符

PHP 无法覆盖 protected 静态

我似乎无法覆盖protectedstatic变量。这很烦人,因为您也不能覆盖任何私有(private)变量。我该如何解决?(必须支持PHP5.2)showStuff();//Output:Foo$b->showStuff();//Output:Foo?> 最佳答案 您需要使用latestaticbindings,PHP5.3中引入的一个特性。在您的类Foo中,self指的是Foo类。您想要引用发起调用的类。您需要使用关键字static:showStuff();//Output:Foo$b->showStuff();//Output:

php - 让我的网站更安全,我使用的 password_hash 是否正确?

这个问题在这里已经有了答案:SecurehashandsaltforPHPpasswords(14个答案)关闭7年前。我有一个非常小的网站,最近我一直在努力让它更安全,我过去常常以纯文本形式存储我的密码。我认为我做的是对的,但作为一个“业余”程序员,我想确定一下所以我问你们,专业人士当用户注册时,我执行:password_hash($their_password,PASSWORD_DEFAULT)并将其存储在用户表的“密码”列中。我使用PASSWORD_DEFAULT因为根据php.net这似乎是最好的。Notethatthisconstantisdesignedtochangeove

php - 不使用 PHPUnit 测试 protected /私有(private)方法时的代码覆盖率

我知道可以使用反射或其他变通方法测试PHPUnit的私有(private)/protected方法。但大多数消息来源告诉我,为类内部的私有(private)方法编写测试不是最佳实践。您应该像测试“黑匣子”一样测试该类—您只需通过比较输入和输出来测试预期行为,而不考虑内部机制。为类编写测试还应该通过显示缺少代码覆盖率来通知您未使用的私有(private)方法。当我测试我的类并生成HTML报告时,它显示私有(private)方法未被测试覆盖,即使调用它们的行已完全执行/覆盖。我知道私有(private)方法已执行,因为如果它们不执行,我的类上的断言将不会通过。这是PHPUnit中的预期行为

php - protected 构造函数是否被视为良好做法?

我正在编写一些小助手类来处理树。基本上,我有一个节点和一个代表树的特殊根节点。我想让它保持通用和简单。这是代码的一部分:findNodeById($parent_id)){$parent->addChildById($node_id,$generic_content);}}}classTreeNode{publicfunction__construct($node_id,$parent_id,$generic_content){//...}protectedfunctionaddChildById($node_id,$generic_content){$this->children[]

php - 您可以在回调中使用 $this 来获取 phpunit 中模拟类的 protected 属性吗?

你能在回调中使用$this来获取phpunit中模拟类的protected属性吗?或者有其他方法可以实现吗?$mock=$this->getMock('A',array('foo'));$mock->expects($this->any())->method('foo')->will($this->returnCallback(function(){return$this->bar;}));如果您考虑注入(inject)模拟对象,这可能非常有用。有时类对其他类具有硬编码依赖性,但它使用理论上可以模拟并创建模拟对象而不是硬编码对象的方法来创建它。请看另一个例子。classA{protec

c# - 寻找 c# 相当于 php 的 password-verify()

我需要将一堆用户帐户Moodle导入到用c#编写的系统中。Moodle使用password_hash()函数来创建密码哈希。我需要能够在C#中验证这些密码。换句话说,我正在寻找PHP密码验证功能的C#实现(http://www.php.net/manual/en/function.password-verify.php).我用谷歌搜索了一下,但真的找不到任何接近的东西,所以我问是希望避免重新发明轮子:-)谢谢! 最佳答案 知道了!首先安装CryptSharp通过NuGet包。(使用2.0“官方”包),顺便说一下,BCrypt.net

php - 访问同一类的另一个对象的 protected 属性的方法

一个对象的方法是否应该能够访问同一类的另一个对象的protected属性?我正在用PHP编写代码,我刚刚发现允许通过同一类的方法访问一个对象的protected属性,即使不是同一对象也是如此。在示例中,首先,您将在输出中获得“3”——因为函数readOtherUser将成功访问该值——之后将发生PHPfatalerror——因为主程序将无法访问相同的值。property;}}$user=newuser();$user->readOtherUser();print$user->property;?>这是一个PHP错误还是预期的行为(我将不得不重新学习这个概念……:))(是否有对事实的引用

php - 从适用于 PHP 的 AWS 开发工具包提取 protected 请求响应

我正在使用新的AmazonElasticTranscoder服务,并且是AWS-SDK的新手。我创建了一个成功的脚本,该脚本运行createJob请求,将AmazonS3文件从一种格式转码为另一种格式。问题是,我似乎无法访问发出请求时返回的响应$data。我可以看到它,它包含我需要的信息,但是当我尝试存储它时收到此错误:fatalerror:无法访问protected属性Guzzle\Service\Resource\Model::$data这是我的请求:'XXXXXXXXX','secret'=>'XXXXXXXXX','region'=>'us-east-1'));//Create