- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 PHP 的新手,我正在为一个小类(class)做 OOP 登录/注册教程,所以它不适用于 www.一小时或 15 小时后,我卡在了一段似乎不起作用的代码上。我试图与我的一个 friend 一起解决这个问题,他对 PHP 有更多的了解,我搜索了谷歌,检查了多个论坛和所有 YouTube 评论以寻找解决方案,但我被卡住了。我知道所有其他代码都是正确的,因为到目前为止它都运行良好:
所以我的问题是:使独特案例起作用的正确 PHP 代码是什么。
case 'unique'
$check =$this->_db->get($rule_value,array($item,"=",
$value));
line 40> if($check->count()){
$this->addError("{$item} bestaat al.");
with this error:
! ) Fatal error: Call to a member function count() on a non-object in C:\wamp\www\websitegroop\classes\validate.php on line 40 调用堆栈
验证类:
class Validate {
private $_passed = false,
$_errors = array(),
$_db = null;
public function __construct() {
$this->_db = Database::getInstance();
}
public function check($source, $items = array()) {
foreach($items as $item => $rules) {
foreach($rules as $rule => $rule_value) {
$value = trim($source[$item]);
if($rule === 'required' && empty($value)) {
$this->addError("{$item} is required");
} else if(!empty($value)) {
switch($rule) {
case 'min':
if(strlen($value) < $rule_value) {
$this->addError("{$item} moet minimaal {$rule_value} letters of cijfers zijn.");
}
break;
case 'max':
if(strlen($value) > $rule_value) {
$this->addError("{$item} kan maximaal {$rule_value} letters of cijfers zijn.");
}
break;
case 'matches':
if($value != $source[$rule_value]) {
$this->addError("{$rule_value} moet hetzelfde zijn als {$item}.");
}
break;
case 'unique':
$check = $this->_db->get($rule_value, array($item, "=", $value));
if($check->count()){
$this->addError("{$item} bestaat al.");
}
break;
}
}
}
}
if(empty($this->_errors)) {
$this->_passed = true;
}
return $this;
}
private function addError($error) {
$this->_errors[] = $error;
}
public function errors() {
return $this->_errors;
}
public function passed() {
return $this->_passed;
}
}
注册.php:
<?php
require_once 'core/init.php';
if(Input::exists()) {
if(Token::check(Input::get('token'))) {
$validate = new Validate();
$validation = $validate->check($_POST, array(
'gebruikersnaam' => array(
'required' => true,
'min' => 3,
'max' => 30,
'unique' => 'groopklanten'
),
'paswoord' => array(
'required' => true,
'min' => 6,
),
'paswoord_nogmaals' => array(
'required' => true,
'matches' => 'paswoord'
),
'bedrijfsnaam' => array(
'required' => true,
'min' => 3,
'max' => 30,
),
'kvknr' => array(
'required' => true,
'min' => 8,
'max' => 8,
'unique' => 'groopklanten'
),
'contactpersoon' => array(
'required' => true,
'min' => 4,
'max' => 30,
),
'functie' => array(
'required' => true,
'min' => 4,
'max' =>30,
),
'telbedrijf' => array(
'required' => true,
'min' => 10,
'max' => 12,
'unique' => 'groopklanten'
),
'adres' => array(
'required' => true,
'min' => 4,
'max' => 40,
'unique' => 'groopklanten'
),
'afleveradres' => array(
'min' => 4,
'max' => 40,
),
'postcode' => array(
'required' => true,
'min' => 6,
'max' => 7,
),
'woonplaats' => array(
'required' => true,
'min' => 3,
'max' => 30,
),
'emailadres' => array(
'required' => true,
'min' => 5,
'max' => 30,
'unique' => 'groopklanten'
)
));
if($validate->passed()) {
echo 'geregistreerd';
} else {
foreach($validation->errors() as $error) {
echo $error, '<br>';
}
}
}
}
?>
<form action="" method="post">
<div class="field">
<label for="gebruikersnaam">Gebruikersnaam:</label>
<input type="text" name="gebruikersnaam" id="gebruikersnaam">
</div>
<div class="field">
<label for="paswoord">Kies een paswoord:</label>
<input type="password" name="paswoord" id="paswoord">
</div>
<div class="field">
<label for="paswoord_nogmaals">Nogmaals uw paswoord:</label>
<input type="password" name="paswoord_nogmaals" id="paswoord_nogmaals">
</div>
<div class="field">
<label for="bedrijfsnaam">Bedrijfsnaam:</label>
<input type="text" name="bedrijfsnaam" id="bedrijfsnaam">
</div>
<div class="field">
<label for="kvknr">KvK nummer:</label>
<input type="text" name="kvknr" id="kvknr">
</div>
<div class="field">
<label for="contactpersoon">Naam contactpersoon:</label>
<input type="text" name="contactpersoon" id="contactpersoon">
</div>
<div class="field">
<label for="functie">Functie:</label>
<input type="text" name="functie" id="functie">
</div>
<div class="field">
<label for="telbedrijf">Telefoonnummer bedrijf:</label>
<input type="tell" name="telbedrijf" id="telbedrijf">
</div>
<div class="field">
<label for="adres">Adres:</label>
<input type="text" name="adres" id="adres">
</div>
<div class="field">
<label for="afleveradres"> Afwijkend aflever adres:</label>
<input type="text" name="afleveradres" id="afleveradres">
</div>
<div class="field">
<label for="postcode">Postcode:</label>
<input type="text" name="postcode" id="postcode">
</div>
<div class="field">
<label for="woonplaats">Woonplaats:</label>
<input type="text" name="woonplaats" id="woonplaats">
</div>
<div class="field">
<label for="emailadres">E-mail adres:</label>
<input type="email" name="emailadres" id="emailadres">
</div>
<input type="hidden" name="token" value="<?php echo Token::generate(); ?>">
<input type ="submit" value="Register">
<input type="reset" name="reset" value="Reset Velden">
<p> Bij het verzenden gaat u automatisch akoord met de <a href="algemenevoorwaarden.html"> algemene voorwaarden!</a></p>
输入类:
<?php
class input {
public static function exists($type = 'post') {
switch($type) {
case 'post':
return (!empty($_POST)) ? true : false;
break;
case 'get':
return (!empty($_GET)) ? true : false;
break;
default:
return false;
break;
}
}
public static function get($item) {
if(isset($_POST[$item])) {
return $_POST[$item];
} else if(isset($_GET[$item])) {
return $_GET[$item];
}
return '';
}
}
数据库类:
<?php
class Database {
private static $_instance = null;
private $_pdo,
$_qeury,
$_error = false,
$_result,
$_count = 0;
private function __construct() {
try {
$this->_pdo = new PDO('mysql:host=' . Config::get('mysql/host') . ';dbname=' . Config::get('mysql/db'), Config::get('mysql/username'), Config::get('mysql/password'));
} catch(PDOException $e) {
die($e->getMessage());
}
}
public static function getInstance() {
if(!isset(self::$_instance)) {
self::$_instance = new Database();
}
return self::$_instance;
}
public function query($sql, $params = array()) {
$this->_error = false;
if($this->_query = $this->_pdo->prepare($sql)) {
$x = 1;
if(count($params)) {
foreach($params as $param) {
$this->_query->bindValue($x, $param);
$x++;
}
}
if($this->_query->execute()) {
$this->_results = $this->_query->fetchALL(PDO::FETCH_OBJ);
$this->_count = $this->_query->rowCount();
} else {
$this->_error = true;
}
}
return $this;
}
public function action($action, $table, $where = array()) {
if(count($where) === 3) {
$operators = array('=', '>', '<', '>=', '<=');
$field = $where[0];
$operator = $where[1];
$value = $where[2];
if(in_array($operator, $operators)) {
$sql = "{$action} FROM {$table} WHERE {$field} {$operator} {value} ?";
if(!$this->query($sql, array($value))->error()) {
return $this;
}
}
}
return false;
}
public function get($table, $where) {
return $this->action('SELECT *', $table, $where);
}
public function delete($table, $where) {
return $this->action('DELETE *', $table, $where);
}
public function insert($table, $fields =array()) {
if(count($fields)) {
$keys = array_keys($fields);
$values = null;
$x = 1;
foreach($fields as $field) {
$values .= '?';
if ($x < count($fields)) {
$values .= ', ';
}
$x++;
}
$sql = "INSERT INTO groopklanten (`" . implode('`, `', $keys)."`) VALUES ({$values})";
if(!$this->query($sql, $fields)->error()) {
return true;
}
}
return false;
}
public function update($table, $id, $fields) {
$set = '';
$x = 1;
foreach($fields as $name => $value) {
$set .= "{$name} = ?";
if($x < count($fields)) {
$set .= ', ';
}
$x++;
}
$sql = "UPDATE {$table} SET {$set} WHERE id = {$id}";
if(!$this->query($sql, $fields)->error()) {
return true;
}
return false;
}
public function results() {
return $this->_results;
}
public function first() {
return $this->_results[0];
}
public function error() {
return $this->_error;
}
public function count() {
return $this->_count;
}
}
初始化文件
<?php
session_start();
$GLOBALS['config'] = array(
'mysql' => array(
'host' => 'localhost',
'username' => 'nick16061983',
'password' => 'N1sn0p1!A',
'db' => 'websitegroop'
),
'remember' => array(
'cookie_name' => 'hash',
'cookie_expiry' => 604800
),
'session' => array(
'session_name' => 'groopklanten',
'token_name' => 'token'
)
);
spl_autoload_register(function($class) {
require_once 'classes/' .$class. '.php';
});
到目前为止我尝试过的所有其他事情都告诉我,我总是可以注册一个现有的用户名,否则它总是会说它已经注册了。当用户名不在我的数据库中时。
提前致谢
尼克
最佳答案
Fatal error: Call to a member function count() on a non-object in C:\wamp\www\websitegroop\classes\validate.php on line 40 Call Stack
那是因为 action()
方法返回的是 false
而不是当前对象,这意味着您的查询执行失败。这主要有两个原因:
首先,请看下面的代码片段。这里有一个小语法错误,
class Database {
private static $_instance = null;
private $_pdo,
$_qeury, // syntax error
...
应该是,
class Database {
private static $_instance = null;
private $_pdo,
$_query,
...
其次,你的声明 $sql = "{$action} FROM {$table} WHERE {$field} {$operator} {value} ?";
inside action()
方法不对,应该是这样的:
$sql = "{$action} FROM {$table} WHERE {$field} {$operator} ?";
所以你的整个 Database
类应该是这样的:
<?php
class Database {
private static $_instance = null;
private $_pdo,
$_query,
$_error = false,
$_result,
$_count = 0;
private function __construct() {
try {
$this->_pdo = new PDO('mysql:host=' . Config::get('mysql/host') . ';dbname=' . Config::get('mysql/db'), Config::get('mysql/username'), Config::get('mysql/password'));
} catch(PDOException $e) {
die($e->getMessage());
}
}
public static function getInstance() {
if(!isset(self::$_instance)) {
self::$_instance = new Database();
}
return self::$_instance;
}
public function query($sql, $params = array()) {
$this->_error = false;
if($this->_query = $this->_pdo->prepare($sql)) {
$x = 1;
if(count($params)) {
foreach($params as $param) {
$this->_query->bindValue($x, $param);
$x++;
}
}
if($this->_query->execute()) {
$this->_results = $this->_query->fetchALL(PDO::FETCH_OBJ);
$this->_count = $this->_query->rowCount();
} else {
$this->_error = true;
}
}
return $this;
}
public function action($action, $table, $where = array()) {
if(count($where) === 3) {
$operators = array('=', '>', '<', '>=', '<=');
$field = $where[0];
$operator = $where[1];
$value = $where[2];
if(in_array($operator, $operators)) {
$sql = "{$action} FROM {$table} WHERE {$field} {$operator} ?";
if(!$this->query($sql, array($value))->error()) {
return $this;
}
}
}
return false;
}
public function get($table, $where) {
return $this->action('SELECT *', $table, $where);
}
public function delete($table, $where) {
return $this->action('DELETE *', $table, $where);
}
public function insert($table, $fields =array()) {
if(count($fields)) {
$keys = array_keys($fields);
$values = null;
$x = 1;
foreach($fields as $field) {
$values .= '?';
if ($x < count($fields)) {
$values .= ', ';
}
$x++;
}
$sql = "INSERT INTO groopklanten (`" . implode('`, `', $keys)."`) VALUES ({$values})";
if(!$this->query($sql, $fields)->error()) {
return true;
}
}
return false;
}
public function update($table, $id, $fields) {
$set = '';
$x = 1;
foreach($fields as $name => $value) {
$set .= "{$name} = ?";
if($x < count($fields)) {
$set .= ', ';
}
$x++;
}
$sql = "UPDATE {$table} SET {$set} WHERE id = {$id}";
if(!$this->query($sql, $fields)->error()) {
return true;
}
return false;
}
public function results() {
return $this->_results;
}
public function first() {
return $this->_results[0];
}
public function error() {
return $this->_error;
}
public function count() {
return $this->_count;
}
}
?>
关于php - OOP 登录/注册,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34666051/
我有一个问题,想知道如何在已经使用常规登录/注册系统的网站上集成第 3 方登录(也进行静默注册)。 基本上当前登录还是比较规律的: 当用户进入网站 session 时类(class)决定他是否需要重新
我在学习 Hyperledger Fabric 并运行示例代码。 我仍在尝试正确了解事情的运作方式,尤其是在使用证书和加密 Material 的用户/管理员注册和注册中。 我想知道以下如何工作。 1)
我正在尝试使用从我的 Android 设备的 PassWallet 应用程序中保存的票证中获取的 token 向我的设备发送消息。 设备发送使用苹果钱包规范更新通行证所需的所有信息。但是,我正在使用
使用 Passport 本地示例,我可以登录工作。没有关于如何注册用户的文档。 我想为用户提供一个“电子邮件”和“密码”字段,他们可以使用它们来注册该网站。我怎样才能做到这一点?有什么原因没有记录下来
在之前的一些 WSO2IS 版本中,有一个默认的 self 注册功能。但是,我在 5.0 版本中找不到它。 阅读 WSO2IS 5.0 文档,我发现有 2 个用于此功能的 API: getUserId
我已将 Airship SDK 集成到 Android 应用程序中。在应用程序启动和飞艇起飞后,我在日志中得到以下调试信息: 07-27 12:46:31.916 XXX - UALib( 1545)
Delphi 中设计时包的可怕错误之一是以下错误,这意味着注册安装新组件到您的 Palette 上的包: Component TSomething can't be registered by pac
我发现的大部分内容都使用 php 或类似的东西。 我有一个 Angular 前端和 Node/express 服务器代码。还没有后端。我不确定如何继续用户注册。 最佳答案 在没有后端的情况下进行注册等
我正在使用 Drupal 6 开发一个网站。我正在使用我自己的主题,并且一切正常。现在我需要使用我的自定义主题在我的网站上创建一个自定义登录/注册表单。我尝试了很多方法,但一切都重定向到我的管理主题,
我在运行此代码时收到 Sip 异常。这是因为 manager.register(me,20,listener)。 下面是我的代码,所以请帮我更正这段代码。我正在使用 SipDemo 代码注册我的帐户。
在过去的几天里,我一直在尝试为基于 VUE 的 excel 制作任务 Pane 插件。 我已按照 link 的指南进行操作我试图为 onSelectionChange 注册一个事件处理程序。它已经有些
我需要在使用 django-registration 应用程序的登录表单中实现一个“记住我”按钮。任何ane可以帮助我向我展示这样做的方法吗? 谢谢 最佳答案 一种方法是更改 session 到期
我发现,如果您使用 Django 1.5 版本,则 django 注册模块会中断,因为在最新的 django 开发版本中,simple.py 类已被删除。 最佳答案 此问题现已修复: hg clone
我正在尝试将 facebook connect 实现到我的网站,但有几个问题。 1:是否可以使用用户当前的 Facebook 电子邮件/密码在我的网站上注册用户。 假设用户点击链接通过 faceboo
我使用 Facebook 注册来允许人们在我的网站上注册。有没有可能,在注册后,他在我的网站注册的成员(member)墙上会张贴? 最佳答案 这可能不是您正在寻找的答案,但我强烈建议您不要这样做。用户
I would like to use a slash (/) for a search during a vimscript, but I don't want to overwrite the "
我正在使用 jqgrid 并且有显示日期的列,但是来自服务器的日期以 json 格式出现,如下所示, "CommentedDate": "\/Date(1304324941000+0530)\/" 如
我希望用户可以直接登录主页,而不是在“../account/login/”页面上登录。我应该做什么才能使它成为可能?如何将主页上的输入字段与 allauth 连接?我不知道这样是否太复杂而无法以这种方
This question already has answers here: Understanding NSString comparison (7个答案) 5年前关闭。 我正在尝试制作注册表。有
我正在使用 Django 注册。它提供了处理 registration_form.html 的 View ,该 html 当前包含用户名、密码 1、密码 2 和电子邮件作为我的应用程序中的用户可输入字
我是一名优秀的程序员,十分优秀!