`
huanlong78
  • 浏览: 34097 次
  • 性别: Icon_minigender_1
  • 来自: 郑州
社区版块
存档分类
最新评论

PHP 数据的中转

    博客分类:
  • PHP
阅读更多
在百度上 有个哥们 提个问题是 PHP 的数据中转问题.

大致流程如下:

  Client => A(数据接收,中转) => B(数据接收,处理)

详细:

A 服务器可以对外 通过 POST 方法接收 Client 的数据信息.
B 服务器 只对 A 开启访问权限,并且 要求数据的传送接收要安全.
思路一:
    最简单的通过 Javascript 脚本 直接生成个 GET 连接指向 B 接口
    PASS原因: B 服务器的访问限制.

思路二:
    A 上建立 数据库 来存放接收的 数据.
    PASS原因:1.麻烦(数据库); 2.不安全(数据在本地); 3.B 可能只提供传送接口;


以上思路被直接PASS掉了...
思来想去,有个办法 可以完结这个问题:
思路三:
    A 负责 接收数据 并且 直接 通过 POST 请求将数据 传送至 B 服务器.

    难度: 只有一点 如何让 A服务器发送 POST 请求到 B ?
    翻阅了PHP5手册 , 没找到 相关的字眼.

    在论坛上 又看到别人的方法 GET 的和题不符 不过 的确让人有醍醐灌顶的 感觉
   
    $content = file("http://www.baidu.com");
    

    代码很雷... 但是 用 GET 方法此为最简单的!( 忘记了代码出处 , 见谅 ).

    然后

     关于 POST 在网上找到 了用 Socket 方法 POST 数据的.
    之前没写过和 Socket 相关的任何东西
     就找个之前人写的函数,感觉很方便 (至少不知道别的方法前我这么认为.. - -! )
    贴出来: SocketPost.php

   
<?php
function PostToHost($url, $data) 
{
	$url = parse_url($url);
	if (!$url) return "couldn\'t parse url";

	$encoded = "";
	while( list($k,$v) = each($data) ) 
	{
		$encoded .= ($encoded ? "&" : "");
		$encoded .= rawurlencode($k)."=".rawurlencode($v);
	}

	$fp = fsockopen($url['host'], 80, $errno, $errstr);
	if (!$fp)
		return "Failed to open socket to $url[host] $port ERROR: $errno - $errstr";
	fputs($fp, sprintf("POST %s%s%s HTTP/1.0\n", $url['path'],  "" , "" ) );
	fputs($fp, "Host: $url[host]\n");
	fputs($fp, "Content-type: application/x-www-form-urlencoded\n");
	fputs($fp, "Content-length: " . strlen($encoded) . "\n");
	fputs($fp, "Connection: close\n\n");
	fputs($fp, "$encoded\n");
	$line = fgets($fp,1024);
	
	if ( !eregi("^HTTP/1\.. 200", $line) ) return;

	$results = "";
	$inheader = 1;
	
	while(!feof($fp)) 
	{
		$line = fgets($fp,1024);
		if ($inheader && ($line == "\n" || $line == "\r\n")) 
		{
			$inheader = 0;
		}
		elseif (!$inheader) 
		{
			$results .= $line;
		}
	}
	fclose($fp);
	return $results;
}
?>
    


    调用方法: Send.php (部署在 A 服务器)

   
<?php
//
//			流程	Client	 ->	A服务器	 ->	B服务器.
//
//			数据接接收中转文件	放在	A	服务器
//
require_once("SocketPost.php");
//------目的地址需要自己配--------
$Method = "_POST";
$Destination = "http://xxx.xxx.xxx.xxx/Receive.php";


//===========调用方式===========
//
//	PostToHost( Action as String , Data as Array )
//
//===========================

PostToHost("$Destination" , $$Method );

?>
    


   
    接口: Receive.php (部署在 B 服务器)


<?php
//
//			数据接收处理文件	放在	B	服务器
//

//------Config-------------

	$LogPath = "D:\\";
	$Logfile = $LogPath . date("Ymd" , time() ).".txt" ;

//============数据操作部分=======
	$UserName = $_POST['UserName'];
	$UserID = $_POST['UserID'];
	$MSISDN = $_POST['MSISDN'];

	// And So On

//===========================

//=============日志记录========
$datas = implode( "," , $_POST  );
$log = date("Y-m-d H:i:s" , time() ) . "  --- data : $datas ";
exec("echo $log >> $LogPath");

?>




接口可用可不用 , 在我本地测试通过了 , 接口部署在 别的服务器上 日志有记 数据有收.


此问题完结.


-----------------------------------

延伸貌似这个 思路可以用来做单次的 WEB 代理服务器.
只是要对获取的内容作大量的 链接修改,和安全控制...麻烦事..
Get 的方法比较简单,但是要代理的页面有表单的话 .....头大.
分享到:
评论

相关推荐

    ASP工具注入+手工注入+PHP注入+中转注

    本话题将详细讨论ASP工具注入、手工注入、PHP注入以及中转注入这四种类型的注入攻击,并提供一些预防措施。 1. ASP工具注入:ASP(Active Server Pages)是一种微软开发的服务器端脚本环境,用于生成动态网页。当...

    transit-php:PHP中转

    该库提供了对往返于PHP的Transit数据进行封送的支持。 与Java和Clojure实现不同,它依赖于宿主PHP环境的非流JSON解析机制。 此实现的major.minor版本号与其支持的Transit规范的版本相对应。 注意:运输是一项正在...

    Linphone消息图片中转服务端代码lft.php

    “lft.php”是Linphone图片消息中转服务的核心,它负责接收、处理并转发用户发送的图片数据。重写这个文件的主要目的是使其能够在非互联网环境或者私有服务器上正常工作,提供安全可控的内部通信环境。以下是对“lft...

    基于PHP的爱特php文件管理中转上传v1.8.1源码.zip

    1. **文件上传处理**:PHP中的`$_FILES`全局变量用于接收上传的文件数据,而`move_uploaded_file()`函数则用于将临时文件移动到指定位置。 2. **错误处理和验证**:文件上传过程中需要对文件大小、类型进行验证,...

    2024AI中转计费平台系统源码.zip

    综上所述,2024AI中转计费平台系统源码涉及了PHP编程、RESTful API设计、计费算法、数据库交互、安全机制等多个方面,是理解和学习现代Web服务开发的宝贵资源。通过深入研究源码,开发者可以提升自己的技能,同时也...

    伪静态注入中转

    2. **PHP输入过滤**:确保所有用户输入都经过适当的验证和过滤,防止恶意数据注入。这包括使用htmlspecialchars、mysqli_real_escape_string等函数来处理用户提交的数据。 3. **预编译语句和参数绑定**:在处理SQL...

    php中转义mysql语句的实现代码

    当我们在PHP脚本中构建SQL语句时,经常会遇到需要将用户输入的数据插入到数据库中的情况。由于这些数据可能包含特殊字符,如单引号(')或双引号("),直接插入会导致SQL语句语法错误,甚至可能引发SQL注入攻击。因此,...

    PHP 简单实现文件上传、保存、下载的功能(云盘)

    在本项目中,"PHP 简单实现文件上传、保存、下载的功能(云盘)",我们主要关注的是如何利用PHP构建一个基本的云存储服务,让用户能够在自己的账户空间内进行文件的操作。以下是对涉及的技术点的详细解释: 1. **PHP*...

    伪静态注入中转突破伪静态

    ,会直接暴露参数和数据,而伪静态后的URL,如`http://www.xxoo.net/aa.php/id/123.html`,虽然外观上看起来是静态页面,但其实仍然是动态处理。这种转换使得直接通过工具进行SQL注入变得困难,因为工具可能无法识别...

    php网盘系统/云存储个人网盘源码/仿百度云盘源码

    php网盘系统/云存储个人网盘源码/仿百度云盘源码 这是一套基于PHP MYSQL的网盘系统,php云存储个人网盘源码,仿百度云盘...回收站功用避免用户误删数据;云存储的不二之选。 装置阐明: 直接上传运转域名即可自动装置

    PHP IIS Windows 2003 配置

    - `extension=php_curl.dll`:用于通过URL传输数据。 - `extension=php_db.dll`:数据库支持。 - `extension=php_dba.dll`:DBA抽象层支持。 - `extension=php_dbase.dll`:对dBase文件的支持。 - `extension=...

    PHP中数据类型转换的三种方式

    允许转换的PHP数据类型主要包括整型(int)、浮点型(float)、字符串(string)、布尔型(bool)、数组(array)和对象(object)。 第一种转换方式是直接在变量前使用目标类型的强制转换语法,例如: ```php (num...

    PHP微信支付v3 完整实例

    V3版本中,商户需要管理私钥证书和公钥证书,用于加密和解密通信数据。证书的获取、存储和使用都需遵循安全规范,防止泄露。 6. **沙箱环境测试** 在正式上线前,开发者可以使用微信支付提供的沙箱环境进行功能...

    xml2json.php

    测试文件`xml2json_test.php`可能包含了调用`xml2json.php`中转换函数的代码,通过传入XML字符串或文件路径,然后打印出转换后的JSON结果。`test1.xml`至`test4.xml`则是用于测试转换功能的不同XML数据样本。`json`...

    PHP社交账号聚合登录平台系统源码

    PHP社会化账号聚合登录平台系统源码,支持中转 QQ、微信、支付宝、微博、百度等平台的快捷登录接口 覆盖国内主流互联网平台登录,包括:微信账号登录、QQ账号登录、Alipay账号登录、微博账号登录、百度账号登录 ...

    基于PHP的proxy网页代理程序 正式版.zip

    【标题】中的“基于PHP的proxy网页代理程序 正式版.zip”表明这是一个使用PHP语言编写的网页代理程序,主要用于帮助用户通过服务器中转访问互联网上的网页内容。代理程序在网络安全、数据隐私以及某些特定场景下(如...

    PHP中的POST&GET的应用.docx

    在PHP编程中,HTTP协议的两种主要方法POST和GET用于在客户端和服务器之间传输数据。它们是Web应用程序中数据交互的基础,特别是在动态网页和表单提交时。此文档主要探讨了如何在PHP中使用这两种方法以及相关的安全...

    淘宝PHP版 SDK下载 OAuth2.0授权协议开发 Demo讲解

    index.asp -- 中转页面,跳至授权页面,淘宝登录图标就是链接这个地址 配置淘宝APP Key、APP Secret、回调地址,打开config.asp页面,找到相应的参数,修改为自己的就可以了。 使用注意事项及疑难解决,及其他详情...

    php实现JWT(json web token)鉴权实例详解

    - 安全:通过签名确保数据未被篡改。 - 可扩展性:Payload可以包含任意信息,方便扩展。 在实际应用中,为了提高安全性,通常会使用更复杂的密钥,并且在服务端存储一个密钥的哈希,用于验证客户端传来的JWT签名...

Global site tag (gtag.js) - Google Analytics