php password 怎么使用
这样试试呢我在后盾人看视频时看见老师讲这个问题的php5.5提供的Password Hashing API就能很好的解决这些问题。
我们先来看password_hash()函数:string password_hash ( string $password , integer $algo [, array $options ])它有三个参数:密码、哈希算法、选项。
前两项为必须的。
让我们使用password_hash()简单的创建一个哈希密码:$pwd = "123456";$hash = password_hash($pwd, PASSWORD_DEFAULT);echo $hash;上例输出结果类似:$2y$10$4kAu4FNGuolmRmSSHgKEMe3DbG5pm3diikFkiAKNh.Sf1tPbB4uo2并且刷新页面该哈希值也会不断的变化。
哈希值创建完毕,我们可以用password_verify()来校验密码是否和哈希值匹配:boolean password_verify ( string $password , string $hash )它接收2个参数:密码和哈希值,并返回布尔值。
检查之前生成的哈希值是否和密码匹配:if (password_verify($pwd,'$2y$10$4kAu4FNGuolmRmSSHgKEMe3DbG5pm3diikFkiAKNh.Sf1tPbB4uo2')) { echo "密码正确";} else { echo "密码错误";}基本上使用以上这2个函数就能安全的创建和校验hash密码了,还有另外2个API函数:password_get_info() //查看哈希值的相关信息password_needs_rehash() //检查一个hash值是否是使用特定算法及选项创建的,希望对你有用,(〃???〃)
用php的CI框架怎么写登录和注册
第一步:login.php //登陆方法 public function login(){ //如果用户名和密码为空,则返回登陆页面 if(empty($_POST['username']) || empty($_POST['password'])){ $data['verifycode'] = rand(1000,9999);//生成一个四位数字的验证码 //将验证码放入session中,注意:参数是数组的格式 $this->session->set_userdata($data); //注意:CI框架默认模板引擎解析的模板文件中变量不需要$符号 //$this->parser->parse("admin/login",$data); //smarty模板变量赋值 $this->tp->assign("verifycode",$data['verifycode']); //ci框架在模板文件中使用原生态的PHP语法输出数据 //$this->load->view('login',$data);//登陆页面,注意:参数2需要以数组的形式出现 //显示smarty模板引擎设定的模板文件 $this->tp->display("admin/login.php"); }else{ $username = isset($_POST['username'])&&!empty($_POST['username'])?trim($_POST['username']):'';//用户名 $password = isset($_POST['password'])&&!empty($_POST['password'])?trim($_POST['password']):'';//密码 $verifycode = isset($_POST['verifycode'])&&!empty($_POST['verifycode'])?trim($_POST['verifycode']):'';//验证码 //做验证码的校验 if($verifycode == $this->session->userdata('verifycode')){ //根据用户名及密码获取用户信息,注意:参数2是加密的密码 $user_info=$this->user_model->check_user_login($username,md5($password)); if($user_info['user_id'] > 0){ //将用户id、username、password放入cookie中 //第一种设置cookie的方式:采用php原生态的方法设置的cookie的值 //setcookie("user_id",$user_info['user_id'],86500); //setcookie("username",$user_info['username'],86500); //setcookie("password",$user_info['password'],86500); //echo $_COOKIE['username']; //第二种设置cookie的方式:通过CI框架的input类库 $this->input->set_cookie("username",$user_info['username'],3600); $this->input->set_cookie("password",$user_info['password'],3600); $this->input->set_cookie("user_id",$user_info['user_id'],3600); //echo $this->input->cookie("password");//适用于控制器 //echo $this->input->cookie("username");//适用于控制器 //echo $_COOKIE['username'];//在模型类中可以通过这种方式获取cookie值 //echo $_COOKIE['password'];//在模型类中可以通过这种方式获取cookie值 //第三种设置cookie的方式:通过CI框架的cookie_helper.php函数库文件 //这种方式不是很灵验,建议大家采取第二种方式即可 //set_cookie("username",$user_info['username'],3600); //echo get_cookie("username"); //session登陆时使用:将用户名和用户id存入session中 //$data['username']=$user_info['username']; //$data['user_id']=$user_info['user_id']; //$this->session->set_userdata($data); //跳转到指定页面 //注意:site_url()与base_url()的区别,前者带index.php,后者不带index.php header("location:".site_url("index/index")); } }else{ //跳转到登陆页面 header("location:".site_url("common/login")); } } } } 第二步:User_model.php//cookie登陆:检测用户是否登陆,如果cookie值失效,则返回false,如果cookie值未失效,则根据cookie中的用户名和密码从数据库中获取用户信息,如果能获取到用户信息,则返回查询到的用户信息,如果没有查询到用户信息,则返回0 public function is_login(){ //获取cookie中的值 if(empty($_COOKIE['username']) || empty($_COOKIE['password'])){ $user_info = false; }else{ $user_info=$this->check_user_login($_COOKIE['username'],$_COOKIE['password']); } return $user_info; } //根据用户名及加密密码从数据库中获取用户信息,如果能获取到,则返回获取到的用户信息,否则返回false,注意:密码为加密密码 public function check_user_login($username,$password){ //这里大家要注意:$password为md5加密后的密码 //$this->db->query("select * from "); //快捷查询类的使用:能为我们提供快速获取数据的方法 //此数组为查询条件 //注意:关联数组 $arr=array( 'username'=>$username,//用户名 'password'=>$password,//加密密码 'status'=>1 //账户为开启状态 ); //在database.php文件中已经设置了数据表的前缀,所以此时数据表无需带前缀 $query = $this->db->get_where("users",$arr); //返回二维数组 //$data=$query->result_array(); //返回一维数组 $user_info=$query->row_array(); if(!empty($user_info)){ return $user_info; }else{ return false; } } 第三步:其它控制器:public function __construct(){ //调用父类的构造函数 parent::__construct(); $this->load->library('tp'); //smarty模板解析类 $this->load->helper('url'); //url函数库文件 $this->load->model("user_model");//User_model模型类实例化对象 $this->cur_user=$this->user_model->is_login(); if($this->cur_user === false){ header("location:".site_url("common/login")); }else{ //如果已经登陆,则重新设...
PHP做的会员登陆系统,第一次输入好用户名与密码按登陆没反应,...
$url = ''; //POST地址$password = ''; //密码$curl = curl_init($url);curl_setopt($curl, CURLOPT_POSTFIELDS, 'username='.$_COOKIE['username'].'&password='.$password);/*** 如果$url是https则需要取消下面两行注释* curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);* curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);*/curl_exec($curl);curl_close($curl);
用php的CI框架怎么写登录和注册
展开全部 第一步:login.php //登陆方法 public function login(){ //如果用户名和密码为空,则返回登陆页面 if(empty($_POST['username']) || empty($_POST['password'])){ $data['verifycode'] = rand(1000,9999);//生成一个四位数字的验证码 //将验证码放入session中,注意:参数是数组的格式 $this->session->set_userdata($data); //注意:CI框架默认模板引擎解析的模板文件中变量不需要$符号 //$this->parser->parse("admin/login",$data); //smarty模板变量赋值 $this->tp->assign("verifycode",$data['verifycode']); //ci框架在模板文件中使用原生态的PHP语法输出数据 //$this->load->view('login',$data);//登陆页面,注意:参数2需要以数组的形式出现 //显示smarty模板引擎设定的模板文件 $this->tp->display("admin/login.php"); }else{ $username = isset($_POST['username'])&&!empty($_POST['username'])?trim($_POST['username']):'';//用户名 $password = isset($_POST['password'])&&!empty($_POST['password'])?trim($_POST['password']):'';//密码 $verifycode = isset($_POST['verifycode'])&&!empty($_POST['verifycode'])?trim($_POST['verifycode']):'';//验证码 //做验证码的校验 if($verifycode == $this->session->userdata('verifycode')){ //根据用户名及密码获取用户信息,注意:参数2是加密的密码 $user_info=$this->user_model->check_user_login($username,md5($password)); if($user_info['user_id'] > 0){ //将用户id、username、password放入cookie中 //第一种设置cookie的方式:采用php原生态的方法设置的cookie的值 //setcookie("user_id",$user_info['user_id'],86500); //setcookie("username",$user_info['username'],86500); //setcookie("password",$user_info['password'],86500); //echo $_COOKIE['username']; //第二种设置cookie的方式:通过CI框架的input类库 $this->input->set_cookie("username",$user_info['username'],3600); $this->input->set_cookie("password",$user_info['password'],3600); $this->input->set_cookie("user_id",$user_info['user_id'],3600); //echo $this->input->cookie("password");//适用于控制器 //echo $this->input->cookie("username");//适用于控制器 //echo $_COOKIE['username'];//在模型类中可以通过这种方式获取cookie值 //echo $_COOKIE['password'];//在模型类中可以通过这种方式获取cookie值 //第三种设置cookie的方式:通过CI框架的cookie_helper.php函数库文件 //这种方式不是很灵验,建议大家采取第二种方式即可 //set_cookie("username",$user_info['username'],3600); //echo get_cookie("username"); //session登陆时使用:将用户名和用户id存入session中 //$data['username']=$user_info['username']; //$data['user_id']=$user_info['user_id']; //$this->session->set_userdata($data); //跳转到指定页面 //注意:site_url()与base_url()的区别,前者带index.php,后者不带index.php header("location:".site_url("index/index")); } }else{ //跳转到登陆页面 header("location:".site_url("common/login")); } } } } 第二步:User_model.php//cookie登陆:检测用户是否登陆,如果cookie值失效,则返回false,如果cookie值未失效,则根据cookie中的用户名和密码从数据库中获取用户信息,如果能获取到用户信息,则返回查询到的用户信息,如果没有查询到用户信息,则返回0 public function is_login(){ //获取cookie中的值 if(empty($_COOKIE['username']) || empty($_COOKIE['password'])){ $user_info = false; }else{ $user_info=$this->check_user_login($_COOKIE['username'],$_COOKIE['password']); } return $user_info; } //根据用户名及加密密码从数据库中获取用户信息,如果能获取到,则返回获取到的用户信息,否则返回false,注意:密码为加密密码 public function check_user_login($username,$password){ //这里大家要注意:$password为md5加密后的密码 //$this->db->query("select * from "); //快捷查询类的使用:能为我们提供快速获取数据的方法 //此数组为查询条件 //注意:关联数组 $arr=array( 'username'=>$username,//用户名 'password'=>$password,//加密密码 'status'=>1 //账户为开启状态 ); //在database.php文件中已经设置了数据表的前缀,所以此时数据表无需带前缀 $query = $this->db->get_where("users",$arr); //返回二维数组 //$data=$query->result_array(); //返回一维数组 $user_info=$query->row_array(); if(!empty($user_info)){ return $user_info; }else{ return false; } } 第三步:其它控制器:public function __construct(){ //调用父类的构造函数 parent::__construct(); $this->load->library('tp'); //smarty模板解析类 $this->load->helper('url'); //url函数库文件 $this->load->model("user_model");//User_model模型类实...
登网站后台显示This server could not verify that you are authorized to ...
1. 服务器无法识别你对你所请求的文件的访问资格。
要么是你提交了错误的数字证书,比如打错密码,要么是你的浏览器不能正常提交需要的证书。
建议升级或更换浏览器。
2. 如果你输入的网址里面含有index.php,那就有可能这个页面已经不存在了,直接输入域名打开即可,如果是你登录的时候自己跳转到这里的,那就是网站本身的问题index.php可能被管理员误删了,这就不是你能解决的了,等网站运营恢复吧。
如果你输入的网址里面含有index.php,那就有可能这个页面已经不存在了,直接输入域名打开即可,如果是你登录的时候自己跳转到这里的,那就是网站本身的问题了,index.php可能被管理员误删了,这就不是你能解决的了,等网站运营恢复吧。
标点哪里有问题了哥们你说一下。
*Re
因为,PHP CURL库默认1024字节的长度不等待数据的返回,所以你那段代码需增加一项配置:curl_setopt($ch, CURLOPT_HTTPHEADER, array('Expect:'));给你一个更全面的封装方法:function req_curl($url, &$status = null, $options = array()){ $res = ''; $options = array_merge(array( 'follow_local' => true, 'timeout' => 30, 'max_redirects' => 4, 'binary_transfer' => false, 'include_header' => false, 'no_body' => false, 'cookie_location' => dirname(__FILE__) . '/cookie', 'useragent' => 'Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1', 'post' => array() , 'referer' => null, 'ssl_verifypeer' => 0, 'ssl_verifyhost' => 0, 'headers' => array( 'Expect:' ) , 'auth_name' => '', 'auth_pass' => '', 'session' => false ) , $options); $options['url'] = $url; $s = curl_init(); if (!$s) return false; curl_setopt($s, CURLOPT_URL, $options['url']); curl_setopt($s, CURLOPT_HTTPHEADER, $options['headers']); curl_setopt($s, CURLOPT_SSL_VERIFYPEER, $options['ssl_verifypeer']); curl_setopt($s, CURLOPT_SSL_VERIFYHOST, $options['ssl_verifyhost']); curl_setopt($s, CURLOPT_TIMEOUT, $options['timeout']); curl_setopt($s, CURLOPT_MAXREDIRS, $options['max_redirects']); curl_setopt($s, CURLOPT_RETURNTRANSFER, true); curl_setopt($s, CURLOPT_FOLLOWLOCATION, $options['follow_local']); curl_setopt($s, CURLOPT_COOKIEJAR, $options['cookie_location']); curl_setopt($s, CURLOPT_COOKIEFILE, $options['cookie_location']); if (!empty($options['auth_name']) && is_string($options['auth_name'])) { curl_setopt($s, CURLOPT_USERPWD, $options['auth_name'] . ':' . $options['auth_pass']); } if (!empty($options['post'])) { curl_setopt($s, CURLOPT_POST, true); curl_setopt($s, CURLOPT_POSTFIELDS, $options['post']); //curl_setopt($s, CURLOPT_POSTFIELDS, array('username' => 'aeon', 'password' => '111111')); } if ($options['include_header']) { curl_setopt($s, CURLOPT_HEADER, true); } if ($options['no_body']) { curl_setopt($s, CURLOPT_NOBODY, true); } if ($options['session']) { curl_setopt($s, CURLOPT_COOKIESESSION, true); curl_setopt($s, CURLOPT_COOKIE, $options['session']); } curl_setopt($s, CURLOPT_USERAGENT, $options['useragent']); curl_setopt($s, CURLOPT_REFERER, $options['referer']); $res = curl_exec($s); $status = curl_getinfo($s, CURLINFO_HTTP_CODE); curl_close($s); return $res;}
php激活账户的脚本出现无厘头问题,求帮助~~我要做注册功能邮箱
你可以用 mail,sendmail 和 smtp 三种方式来借助 Mail 类发送邮件。
话说几天前刚买了个 BlueHost 的空间,在上面跑程序的时候用 PHP 发邮件搞出点心得来,放在这里跟大家分享。
首先我在系统中添加了一个邮件账户 test,密码 123456,然后写下了如下代码: require_once( 'Mail.php'); $conf = array( 'host' => 'mail.yourdomail.com', 'auth' => true, 'username' => 'test', 'password' => '123456' ); $headers['From'] = 'noreply@yourdomain.com'; $headers['To'] = $To; $headers['Subject'] = '=?GB2312?B?' . base64_encode( $Subject) . '?='; $headers['Content-Type'] = 'text/plain; charset=utf-8'; $Mail = & Mail::factory( 'smtp', $conf); $res = $Mail->send( $To, $headers, $Content); ?> $To 是想要发送到的信箱地址,比如 foobar@gmail.com,$Subject 是邮件主题,$Content 是 GB2312 编码的邮件正文。
结果用以上程序屡试屡败,后来经过多次试验才得出在 BlueHost 主机上用 PHP 以 SMTP 方式发送邮件的正确方法,注意事项如下:1) BlueHost 帮助信息中说跟你账户(域名)相对应的 SMTP 主机地址是 mail.yourdomain.com,但其实应该是 localhost。
你用 mail.yourdomain.com 只会得到 SMTP 拒绝链接的错误信息。
2) SMTP 服务器需要验证才能发邮件。
3) SMTP 验证时用户名需要写 user+yourdomain.com,不能写 user@yourdomain.com。
想想这个也好理解,在虚拟主机上一个 SMTP server 要支撑很多个账户,这种写法应该是为了区别发件的账户。
4) 邮件头中的发件邮件账户一定要是存在于系统中的真实账户,象我上面那样注册了一个 test@yourdomain.com,但是发件人账户又写 noreply@yourdomain.com 是不行的,只会得到这样的错误信息:SMTP: Invalid response code received from server (code: 550, response: Verification failed for No Such User Here Sender verify failed) 知道了上面这 4 个注意事项以后就好办了,删掉刚才注册的 test 邮件帐号,注册一个 noreply 帐号,修改程序如下: require_once( 'Mail.php'); $conf = array( 'host' => 'localhost', 'auth' => true, 'username' => 'noreply+yourdomain.com', 'password' => '123456' ); $headers['From'] = 'noreply@yourdomain.com'; $headers['To'] = $To; $headers['Subject'] = '=?GB2312?B?' . base64_encode( $Subject) . '?='; $headers['Content-Type'] = 'text/plain; charset=utf-8'; $Mail = & Mail::factory( 'smtp', $conf); $res = $Mail->send( $To, $headers, $Content); ?> 邮件被成功的发送出去了,而且由于邮件服务器在美国,发送到 GMail 信箱非常之快,一般这边一发那边刷新一下就能看到新邮件:) 这里再说些题外话,买了 BlueHost 的空间将近一周时间了,感觉美国的虚拟主机市场确实非常成熟,功能强大。
跟国内价格还行但是配置超受限的主机比起来性价比高的不得了!只要你选对了服务提供商,可以说绝对让你满意。
但是缺点也比较明显,就是速度实在是慢!这里面的原因众所周知,感谢伟大的电信运营商,感谢伟大的 GFW! 今天跟 HostMonster 的客户沟通了一下,问问他们那边从中国过去的访问速度怎么样,估计人家遇到这样的情况不是个别现象,上来就是一句,我们对来自中国的访问速度无法做出承诺。
国内的虚拟主机服务商有万网这样把大家当 SB 漫天要价的主,但是也有兢兢业业踏踏实实做服务的公司,不过性价比跟国外的运营商确实没法比。
一边是价格高不了多少,动辄几十 G 空间几百 G 月流量,支持 SSH,支持多 Addon domain 的国外主机,一边是价廉物不太美的国内主机,我想诱惑力是不言而喻的。
但是速度,唉,伤心是一种说不出的痛!
转载请注明出处51数据库 » password_verify php