×

phpfsockopenhttps

包含phpfsockopenhttps的词条

admin admin 发表于2023-03-30 22:14:09 浏览49 评论0

抢沙发发表评论

本文目录一览:

php开启fsockopen函数

 1. 方法一:

第一步:

php.ini文件中查找

allow_url_fopen = On

使其值为On

第二步:

php.ini文件中查找

extension=php_openssl.dll

如果前面有分号,去掉分号

第三步:

重启web服务器,apache或IIS

2.还有一种情况,也就是方法二:

1. vi php.ini

找到 allow_url_fopen 这个参数设置成 On,即

allow_url_fopen = On

2. 让你的php支持 opensll扩展。

默认,是没有openssl扩展的,只能重新编译安装。

yum install openssl openssl-devel

cd /usr/local/src/php-5.2.14/ext/openssl

/usr/local/php/bin/phpize

./configure –with-openssl –with-php-config=/usr/local/bin/php-config

make make install

看提示,把编译成的openssl.so 拷贝到你在php.ini 中指定的 extension_dir 下

3. vi php.ini

加入

extension=openssl.so

4. 重启web server

PHP fsockopen()的使用方法

fsockopen(主机名称,端口号码,错误号的接受变量,错误提示的接受变量,超时时间)

使用fsockopen()函数比fopen()函数的优点:fopen()只会在PHP中已经将allow_url_fopen设置为真时才能使用,而fsockopen()并没有限制。

参考:

php如何实现脚本异步执行的方法具体分析

php语言得用fsockopen()函数,实现脚本异步运行,代码如下

异步请求函数(用debug参数若为true则为用为调试,开启调试可以看到异步的执行情况,但是失去异步的效果)

main.php

?php

/**

 * 异步请求

 * @copyright  Copyright (c) Hangzhou Technology Co.,Ltd. ()

 * @author     $Author: juny $

 * @version    $Id: main.php 332 2018-09-23 09:15:08Z juny $

 */

function request_by_fsockopen($url,$post_data=array(),$debug=false){

  $url_array = parse_url($url);

  $hostname = $url_array['host'];

  $port = isset($url_array['port'])? $url_array['port'] : 80;

  @$requestPath = $url_array['path'] ."?". $url_array['query'];

  $fp = fsockopen($hostname, $port, $errno, $errstr, 10);

  if (!$fp) {

    echo "$errstr ($errno)";

    return false;

  }

  $method = "GET";

  if(!empty($post_data)){

    $method = "POST";

  }

  $header = "$method $requestPath HTTP/1.1\r\n";

  $header.="Host: $hostname\r\n";

  if(!empty($post_data)){

    $_post = strval(NULL);

    foreach($post_data as $k = $v){

    $_post[]= $k."=".urlencode($v);//必须做url转码以防模拟post提交的数据中有符而导致post参数键值对紊乱

    }

    $_post = implode('', $_post);

    $header .= "Content-Type: application/x-www-form-urlencoded\r\n";//POST数据

    $header .= "Content-Length: ". strlen($_post) ."\r\n";//POST数据的长度

    $header.="Connection: Close\r\n\r\n";//长连接关闭

    $header .= $_post; //传递POST数据

  }else{

    $header.="Connection: Close\r\n\r\n";//长连接关闭

  }

  fwrite($fp, $header);

  //-----------------调试代码区间-----------------

  //注如果开启下面的注释,异步将不生效可是方便调试

  if($debug){

  $html = '';

  while (!feof($fp)) {

  $html.=fgets($fp);

  }

  echo $html;

  }

  //-----------------调试代码区间-----------------

  fclose($fp);

}

$data=array('name'='guoyu','pwd'='123456');

$url='';

request_by_fsockopen($url,$data,true);//

other.php

?php

header("content-type:text/html;charset=utf-8");

//error_reporting(0);

//ini_set('html_errors',false);

//ini_set('display_errors',false);

$name = isset($_POST['name'])?$_POST['name']:'';

$pwd = isset($_POST['pwd'])?$_POST['pwd']:'';

echo $name.$pwd;

echo 'success ok';

die;

?

使用实例:

[运行的main.php主脚本文件]

$data=array('name'='guoyu','pwd'='123456');

$url='';

request_by_fsockopen($url,$data,true);//把应用B的用户表异步-同步数据

[导步执行文件other.php]

在other.php中便可以用$_POST接收main.php提交过来的参数,从而进行下一步操作

以上就是php如何实现脚本异步执行的方法具体分析的详细内容.

PHP如何用fsockopen 连接https服务器

原理上使用fsockopen连接https和连接http是一样的

但是fsockopen向一个地址发送请求时,只能自己手动拼装头信息,下面是我写的一个函数,可直接调用,功能是向一个地址发起post请求

function request($url, $params){

    $URL = parse_url($url);

    if(!isset($URL['port'])){

      $URL['port'] = 80;

    }

    

    $request ='POST '.$URL['path']." HTTP/1.1\nHost: ".$URL['host']."\nContent-type: application/x-www-form-urlencoded\nContent-length: ".strlen(trim($params))."\nConnection: close\n\n".trim($params)."\n";-phpfsockopenhttps

    

    try{

      $fp = fsockopen($URL['host'], $URL['port']);

      fwrite($fp, $request);

      $res = fread($fp, 1024);

    }catch(Exception $e){

      fclose($fp);

      return false;

    }

    fclose($fp);

    return $res;

}

//调用

$url='https://地址';

$result = request($url, '');

//若服务器有反馈,则打印出来

echo $result;

怎么用fsockopen打开https链接

如果是http的话

$fp = fsockopen('http://'.$host, 80, $errno, $errstr, 20);

如果是https的话

$fp = fsockopen('ssl://'.$host, 443, $errno, $errstr, 20);