php curl_setopt与模拟用户登录

 更新时间:2016年11月25日 15:51  点击:1249

php教程 curl_setopt与模拟用户登录

bool curl_setopt (int ch, string option, mixed value)
 
curl_setopt()函数将为一个curl会话设置选项。option参数是你想要的设置,

value是这个选项给定的值。

//该例子为模拟登录  
$cookie_file = tempnam('./temp','cookie');//保存临时cookie  
$login_url = 'http://xxx/login.php';//登录页提交地址  
$post_fields = 'username=&password=';//传值参数  
 
$ch = curl_init($login_url);  
curl_setopt($ch, curlopt_header, 0);  
curl_setopt($ch, curlopt_returntransfer, 1);  
curl_setopt($ch, curlopt_post, 1);  
curl_setopt($ch, curlopt_postfields, $post_fields);  
curl_setopt($ch, curlopt_cookiejar, $cookie_file);  
curl_exec($ch);  
curl_close($ch); 


下列选项的值将被作为长整形使用(在option参数中指定):
 
curlopt_infilesize: 当你上传一个文件到远程站点,这个选项告诉php你上传文

件的大小。
curlopt_verbose: 如果你想curl报告每一件意外的事情,设置这个选项为一个非

零值。
curlopt_header: 如果你想把一个头包含在输出中,设置这个选项为一个非零值。
curlopt_noprogress: 如果你不会php为curl传输显示一个进程条,设置这个选项

为一个非零值。
注意:php自动设置这个选项为非零值,你应该仅仅为了调试的目的来改变这个选

项。
curlopt_nobody: 如果你不想在输出中包含body部分,设置这个选项为一个非零值


curlopt_failonerror: 如果你想让php在发生错误(http代码返回大于等于300)时

,不显示,设置这个选项为一人非零值。默认行为是返回一个正常页,忽略代码。
curlopt_upload: 如果你想让php为上传做准备,设置这个选项为一个非零值。
curlopt_post: 如果你想php去做一个正规的http post,设置这个选项为一个非零

值。这个post是普通的 application/x-www-from-urlencoded 类型,多数被html

表单使用。
curlopt_ftplistonly: 设置这个选项为非零值,php将列出ftp的目录名列表。
curlopt_ftpappend: 设置这个选项为一个非零值,php将应用远程文件代替覆盖它


curlopt_netrc: 设置这个选项为一个非零值,php将在你的 ~./netrc 文件中查找

你要建立连接的远程站点的用户名及密码。
curlopt_followlocation: 设置这个选项为一个非零值(象 'location: ')的头,

服务器会把它当做http头的一部分发送(注意这是递归的,php将发送形如

'location: '的头)。
curlopt_put: 设置这个选项为一个非零值去用http上传一个文件。要上传这个文

件必须设置curlopt_infile和curlopt_infilesize选项.
curlopt_mute: 设置这个选项为一个非零值,php对于curl函数将完全沉默。
curlopt_timeout: 设置一个长整形数,作为最大延续多少秒。
curlopt_low_speed_limit: 设置一个长整形数,控制传送多少字节。
curlopt_low_speed_time: 设置一个长整形数,控制多少秒传送

curlopt_low_speed_limit规定的字节数。
curlopt_resume_from: 传递一个包含字节偏移地址的长整形参数,(你想转移到的

开始表单)。
curlopt_sslversion: 传递一个包含ssl版本的长参数。默认php将被它自己努力的

确定,在更多的安全中你必须手工设置。
curlopt_timecondition: 传递一个长参数,指定怎么处理curlopt_timevalue参数

。你可以设置这个参数为timecond_ifmodsince 或 timecond_isunmodsince。这仅

用于http。
curlopt_timevalue: 传递一个从1970-1-1开始到现在的秒数。这个时间将被

curlopt_timevalue选项作为指定值使用,或被默认timecond_ifmodsince使用。
下列选项的值将被作为字符串:
 
curlopt_url: 这是你想用php取回的url地址。你也可以在用curl_init()函数初始

化时设置这个选项。
curlopt_userpwd: 传递一个形如[username]:[password]风格的字符串,作用php去

连接。
curlopt_proxyuserpwd: 传递一个形如[username]:[password] 格式的字符串去连

接http代理。
curlopt_range: 传递一个你想指定的范围。它应该是'x-y'格式,x或y是被除外的

。http传送同样支持几个间隔,用逗句来分隔(x-y,n-m)。
curlopt_postfields: 传递一个作为http “post”操作的所有数据的字符串。
curlopt_referer: 在http请求中包含一个'referer'头的字符串。
curlopt_useragent: 在http请求中包含一个'user-agent'头的字符串。
curlopt_ftpport: 传递一个包含被ftp 'post'指令使用的ip地址。这个post指令

告诉远程服务器去连接我们指定的ip地址。 这个字符串可以是一个ip地址,一个

主机名,一个网络界面名(在unix下),或是‘-’(使用系统默认ip地址)。
curlopt_cookie: 传递一个包含http cookie的头连接。
curlopt_sslcert: 传递一个包含pem格式证书的字符串。
curlopt_sslcertpasswd: 传递一个包含使用curlopt_sslcert证书必需的密码。
curlopt_cookiefile: 传递一个包含cookie数据的文件的名字的字符串。这个

cookie文件可以是netscape格式,或是堆存在文件中的http风格的头。
curlopt_customrequest: 当进行http请求时,传递一个字符被get或head使用。为

进行delete或其它操作是有益的,更pass a string to be used instead of get

or head when doing an http request. this is useful for doing or another,

more obscure, http request.
注意: 在确认你的服务器支持命令先不要去这样做。
下列的选项要求一个文件描述(通过使用fopen()函数获得):
 
curlopt_file: 这个文件将是你放置传送的输出文件,默认是stdout.
curlopt_infile: 这个文件是你传送过来的输入文件。
curlopt_writeheader: 这个文件写有你输出的头部分。
curlopt_stderr: 这个文件写有错误而不是stderr。

<?php
function curl_redir_exec($ch,$debug="")
{
    static $curl_loops教程 = 0;
    static $curl_max_loops = 20;

    if ($curl_loops++ >= $curl_max_loops)
    {
        $curl_loops = 0;
        return false;
    }
    curl_setopt($ch, curlopt_header, true);
    curl_setopt($ch, curlopt_returntransfer, true);
    $data = curl_exec($ch);
    $debbbb = $data;
    list($header, $data) = explode("nn", $data, 2);
    $http_code = curl_getinfo($ch, curlinfo_http_code);

    if ($http_code == 301 || $http_code == 302) {
        $matches = array();
        preg_match('/location:(.*?)n/', $header, $matches);
        $url = @parse_url(trim(array_pop($matches)));
        //print_r($url);
        if (!$url)
        {
            //couldn't process the url to redirect to
            $curl_loops = 0;
            return $data;
        }
        $last_url = parse_url(curl_getinfo($ch,

curlinfo_effective_url));
    /*    if (!$url['scheme'])
            $url['scheme'] = $last_url['scheme'];
        if (!$url['host'])
            $url['host'] = $last_url['host'];
        if (!$url['path'])
            $url['path'] = $last_url['path'];*/
        $new_url = $url['scheme'] . '://' . $url['host'] . $url['path']

. ($url['query']?'?'.$url['query']:'');
        curl_setopt($ch, curlopt_url, $new_url);
    //    debug('redirecting to', $new_url);

        return curl_redir_exec($ch);
    } else {
        $curl_loops=0;
        return $debbbb;
    }
}
?>

php教程 json中文乱码处理方法

网页特效客户端对中文的处理是使用utf-8内码的,并且json对中文的处理也是

使用utf-8,因此,ajax->php的时候,php需要utf8->gbk;php处理好后,在交给

json函数处理之前需要gbk->utf8,然后将结果php->ajax。

<?php
$code = json_encode($str);
$code = preg_replace("#u([0-9a-f]+)#ie", "iconv('ucs-2', 'utf-8',

pack('h4', '1'))", $code);
?>
json_encode() 给含有中文的内容进行编码时,会出现类似于u5c71u4e1c这样的

代码,虽然使用jquery或者json_decode()进行解码的时候


下面看个实例

<?php
$json = array (
0 =>
array (
'id' => '13',
'name' => '乒乓球',
),
1 =>
array (
'id' => '17',
'name' => '篮球',
)
)
?>
encode_json进行编码的话,输出结果是本篇文章来源于:开发学院
<?php
[{"id":"13","name":null}
,{"id":"13","name":null}]
?>

php教程多维数组排序与操作函数
function arraycd($arr){
static $res_arr=array();
if(is_array($arr))
{
 foreach($arr as $key=>$val)
   {
      if(is_array($val))
      {
         arraycd($val);
         }else{
         $res_arr[]=$val;
         }
         }
         }elseif(is_string($arr))
         {
            $res_arr[]=$arr;
            }
            return implode(",",$res_arr);
            }

$fruits = array (
"fruits" => array("a" => "orange", "b" => "banana", "c" => "apple"),
"numbers" => array(1, 2, 3, 4, 5, 6),
"holes" => array("first", 5 => "second", "third")
);

$strayy=arraycd($fruits);

var_dump($strayy);

看一个多维数组排序

<?php
function sortdata($data, $col, $order){
 if (count($data)) $temp_array[key($data)] = array_shift($data);

 foreach($data as $key => $val){
  $offset = 0;
  $found = false;
  foreach($temp_array as $tmp_key => $tmp_val){
   if(!$found and strtolower($val[$col]) >

strtolower($tmp_val[$col])){
    $temp_array = array_merge((array)

array_slice($temp_array,0,$offset),
     array($key => $val),
     array_slice($temp_array,$offset)
    );
    $found = true;
   }
   $offset++;
  }
  if(!$found) {
   $temp_array = array_merge($temp_array, array

($key => $val));
   }
 }
 if (strtolower($order)=="asc"){
  $array = array_reverse($temp_array);
 } else {
  $array = $temp_array;
 }
 return $array;
}

主函数

$data=array(
 array(
  'name'=>'alice',
  'key'=>'2fc4ab3d639e5400efdfc73bc27e83f1',
  'age'=>20
 ),
 array(
  'name'=>'claudia',
  'key'=>'831c2b79c1f19af39c7e3321e11e5f5e',
  'age'=>18
 ),
 array(
  'name'=>'beatrice',
  'key'=>'6f8512a2066b8f35a27a495ce1228c76',
  'age'=>100
 ),
 array(
  'name'=>'denise',
  'age'=>25,
  'key'=>'ef6de3b178bf9f69a9fef72e4ee7bbe9'
 )
);

$arr1 = sortdata($data, "name","asc");
echo "<pre>";
var_dump($arr1);
echo "</pre>";

$arr2 = sortdata($data, "age","desc");
echo "<pre>";
var_dump($arr2);
echo "</pre>";

php教程实现记住密码自动登录方法不止一个,下面出现有二个emptyempty,其实是一个,那是因为代码高亮有bug。希望对大家有帮助。

一,用户登录的check 
代码如下:
//检查用户是否登录

function checklogin(){
if(emptyempty($_session['user_info'])){ //检查一下session是不是为空
if(emptyempty($_cookie['username']) || emptyempty($_cookie['password'])){ //如果session为空,并且用户没有选择记录登录状
header(”location:login.php?req_url=”.$_server['request_uri']); //转到登录页面,记录请求的url,登录后跳转过去,用户体验好。
}else{ //用户选择了记住登录状态
$user = getuserinfo($_cookie['username'],$_cookie['password']); //去取用户的个人资料
if(emptyempty($user)){ //用户名密码不对没到取到信息,转到登录页面
header(”location:login.php?req_url=”.$_server['request_uri']);
}else{
$_session['user_info'] = $user; //用户名和密码对了,把用户的个人资料放到session里面
}
}
}
}
//检查用户是否登录
function checklogin(){
if(empty($_session['user_info'])){ //检查一下session是不是为空
if(empty($_cookie['username']) || empty($_cookie['password'])){ //如果session为空,并且用户没有选择记录登录状
header(”location:login.php?req_url=”.$_server['request_uri']); //转到登录页面,记录请求的url,登录后跳转过去,用户体验好。
}else{ //用户选择了记住登录状态
$user = getuserinfo($_cookie['username'],$_cookie['password']); //去取用户的个人资料
if(empty($user)){ //用户名密码不对没到取到信息,转到登录页面
header(”location:login.php?req_url=”.$_server['request_uri']);
}else{
$_session['user_info'] = $user; //用户名和密码对了,把用户的个人资料放到session里面
}
}
}
}

在访问后台的每个页面时,都要先进行上面的检查

二,用户提交登录信息
当用户填写用户名和密码后就提交到这儿来, 
代码如下:

$username = trim($_post['username']);
$password = md5(trim($_post['password']));
$validatecode = $_post['validatecode'];
$ref_url = $_get['req_url'];
$remember = $_post['remember'];

$err_msg = ”;
if($validatecode!=$_session['checksum']){
$err_msg = “验证码不正确”;
}elseif($username==” || $password==”){
$err_msg = “用户名和密码都不能为空”;
}else{
$row = getuserinfo($username,$password);

if(emptyempty($row)){
$err_msg = “用户名和密码都不正确”;
}else{
$_session['user_info'] = $row;
if(!emptyempty($remember)){ //如果用户选择了,记录登录状态就把用户名和加了密的密码放到cookie里面
setcookie(”username”, $username, time()+3600*24*365);
setcookie(”password”, $password, time()+3600*24*365);
}
if(strpos($ref_url,”login.php”) === false){
header(”location:”.$ref_url);
}else{
header(”location:main_user.php”);
}
}
}
$username = trim($_post['username']);
$password = md5(trim($_post['password']));
$validatecode = $_post['validatecode'];
$ref_url = $_get['req_url'];
$remember = $_post['remember'];

$err_msg = ”;
if($validatecode!=$_session['checksum']){
$err_msg = “验证码不正确”;
}elseif($username==” || $password==”){
$err_msg = “用户名和密码都不能为空”;
}else{
$row = getuserinfo($username,$password);

if(empty($row)){
$err_msg = “用户名和密码都不正确”;
}else{
$_session['user_info'] = $row;
if(!empty($remember)){ //如果用户选择了,记录登录状态就把用户名和加了密的密码放到cookie里面
setcookie(”username”, $username, time()+3600*24*365);
setcookie(”password”, $password, time()+3600*24*365);
}
if(strpos($ref_url,”login.php”) === false){
header(”location:”.$ref_url);
}else{
header(”location:main_user.php”);
}
}
}

关于$ref_url简单解释一下,假如:用户a访问b.php,但是a用户没有登录,跳转到登录页面login.php,在登录页面填完用户和密码后,确定后又跳转到b.php这个页面,而不是跳转一个默认的页面main_user.php。因为b.php是用户a想去的那个页面,所以用户体验会好一点。

三,当用户点退出时,清出记录登录状态

为什么要这样做呢,因为如果有别人用你的电脑的话,他们有可能会浏览到你的个人隐私,所以当用户特意点了退出时,最好是把记录登录状态取消掉。
复制代码 代码如下:
//退出登录

function logout(){
unset($_session['user_info']);
if(!emptyempty($_cookie['username']) || emptyempty($_cookie['password'])){
setcookie(”username”, null, time()-3600*24*365);
setcookie(”password”, null, time()-3600*24*365);
}
}

第一行代码是强制下载;

第二行代码是给下载的内容指定一个名字;

第三行代码是把下载的内容读进文件中。

提示用户保存一个生成的 pdf 文件(content-disposition 报头用于提供一个推荐的文件名,并强制浏览器显示保存对话框):


<?php教程

2 header("content-type: application/force-download");

3 header("content-disposition: attachment; filename=ins.jpg");

4 readfile("imgs/test_zoom.jpg");

5 ?>


header() 函数向客户端发送原始的 http 报头。

认识到一点很重要,即必须在任何实际的输出被发送之前调用 header() 函数(在 php 4 以及更高的版本中,您可以使用输出缓存来解决此问题):

header(string,replace,http_response_code)

其它用法

<?php
// date in the past
header("expires: mon, 26 jul 1997 05:00:00 gmt");
header("cache-control: no-cache");
header("pragma: no-cache");
?>

 

[!--infotagslink--]

相关文章

  • php 获取用户IP与IE信息程序

    php 获取用户IP与IE信息程序 function onlineip() { global $_SERVER; if(getenv('HTTP_CLIENT_IP')) { $onlineip = getenv('HTTP_CLIENT_IP');...2016-11-25
  • php中登录后跳转回原来要访问的页面实例

    在很多网站用户先访问一个要登录的页面,但当时没有登录后来登录了,等待用户登录成功之后肯定希望返回到上次访问的页面,下面我就来给大家介绍登录后跳转回原来要访问的页...2016-11-25
  • php中用curl模拟登录discuz以及模拟发帖

    本文章完美的利用了php的curl功能实现模拟登录discuz以及模拟发帖,本教程供参考学习哦。 代码如下 复制代码 <?php $discuz_url = &lsquo;ht...2016-11-25
  • php简单用户登陆程序代码

    php简单用户登陆程序代码 这些教程很对初学者来讲是很有用的哦,这款就下面这一点点代码了哦。 <center> <p>&nbsp;</p> <p>&nbsp;</p> <form name="form1...2016-11-25
  • Ruby on Rails实现最基本的用户注册和登录功能的教程

    这里我们主要以has_secure_password的用户密码验证功能为中心,来讲解Ruby on Rails实现最基本的用户注册和登录功能的教程,需要的朋友可以参考下...2020-06-30
  • php根据用户语言跳转相应网页

    当来访者浏览器语言是中文就进入中文版面,国外的用户默认浏览器不是中文的就跳转英文页面。 <&#63;php $lan = substr(&#8194;$HTTP_ACCEPT_LANGUAGE,0,5); if ($lan == "zh-cn") print("<meta http-equiv='refresh' c...2015-11-08
  • js检测用户输入密码强度

    一个用Javascript检测用户输入密码强度的效果代码,以下代码主要是从以下四个方面检测用户输入的密码的强度的,有兴趣的朋友可以自己添加或修改成自己想要的形式! 1. 如果输入的密码位数少于5位,那么就判定为弱。 2. 如果...2015-10-23
  • PHP中SSO Cookie登录分析和实现

    什么是SSO?单点登录SSO(Single Sign-On)是身份管理中的一部分。SSO的一种较为通俗的定义是:SSO是指访问同一服务器不同应用中的受保护资源的同一用户,只需要登录一次,即通过一个应用中的安全验证后,再访问其他应用中的受保护...2015-11-08
  • php有效防止同一用户多次登录

    【问题描述】:同一用户在同一时间多次登录如果不能检测出来,是危险的。因为,你无法知道是否有其他用户在登录你的账户。如何禁止同一用户多次登录呢? 【解决方案】 (1) 每次登录,身份认证成功后,重新产生一个session_id。 s...2015-11-24
  • PHP中SSO Cookie登录分析和实现

    什么是SSO?单点登录SSO(Single Sign-On)是身份管理中的一部分。SSO的一种较为通俗的定义是:SSO是指访问同一服务器不同应用中的受保护资源的同一用户,只需要登录一次,即通过一个应用中的安全验证后,再访问其他应用中的受保护...2015-11-08
  • vue实现用户登录切换

    这篇文章主要为大家详细介绍了vue实现用户登录切换,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-04-22
  • php ajax注册验证用户名是否存在代码

    这是注册程序是一款当用户输入完用户名是,就会自动去数据库中查询用户要注册的用户名是否己经被注册了,如果是返回提示否则提示可以注册。 conn.php文件 代...2016-11-25
  • 修改mysql密码phpmyadmin不能登录

    出现phpmyadmin不能登录是我在修改我mysql服务器密码之后导致的,后来百度了相关的原因,原来是修改了mysql密码之后我们还需要在phpmyadmin目录中去修改config.inc.php中...2016-11-25
  • Vue-Element-Admin集成自己的接口实现登录跳转

    关于这个Vue-element-admin中的流程可能对于新的同学不是很友好,所以本文将结合实例代码,介绍Vue-Element-Admin集成自己的接口实现登录跳转,感兴趣的小伙伴们可以参考一下...2021-06-23
  • 浅谈js二维码扫码登录是什么原理

    这篇文章主要介绍了浅谈js二维码扫码登录是什么原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-04-13
  • 微信小程序用户授权最佳实践指南

    这篇文章主要给大家介绍了关于微信小程序用户授权最佳实践的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-05-08
  • phpmyadmin不能登录,无任何提示的问题解决

    昨天有一朋友说自己的phpmyadmin不能登录并且无任何提示了,问我怎么解决,下面我来分享一下关于phpmyadmin不能登录问题总结. phpmyadmin不能登录没有提示 解决方法:...2016-11-25
  • PHP中如何使用session实现保存用户登录信息

    session在php中是一个非常重要的东西,像我们用户登录一般都使用到session这个东西,相对于cookie来说session 要安全很多,同时我们购物车经常使用session来做临时的记录保存哦。使用session保存页面登录信息1、数据库连接...2015-10-21
  • 简单php cookie用户登录实例

    cookie 的用途之一是存储用户在特定网站上的密码和 id。另外,也用于存储起始页的首选项。在提供个人化查看的网站上,将要求阁下的网络浏览器利用阁下计算机硬驱上的少量...2016-11-25
  • SpringBoot登录拦截配置详解(实测可用)

    这篇文章主要介绍了SpringBoot登录拦截配置详解(实测可用),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-07-22