php使用fsockopen传送POST到別的URL并取得回应內容

如果不需要传送参数或是使用GET method传送可以直接使用fopen()或是file_get_contents()函式获得回应內容
但是如果需要不经过表单就送出POST给某URL就需要使用curl相关函式或是fsockopen()传送

curl的用法比较简单可以咕狗看看(但是php必须要先安裝curl才可以用),这边要讲的是fsockopen().

//接收POST參數的URL
$url = 'http://www.google.com';

//POST參數,在這個陣列裡,索引是name,值是value,沒有限定組數
$postdata = array(
'post_name'=>'post_value','acc'=>'hsin','nick'=>'joe');

//函式回覆的值就是取得的內容
$result = sendpost($url,$postdata);
 
function sendpost($url, $data){
//先解析url 取得的資訊可以看看http://www.php.net/parse_url
$url = parse_url($url);
$url_port = $url['port']==''?(($url['scheme']=='https')?443:80):$url['port'];
if(!$url) return "couldn't parse url";

//對要傳送的POST參數作處理
$encoded = "";
while(list($k,$v)=each($data)){
  $encoded .= ($encoded?'&':'');
  $encoded .= rawurlencode($k)."=".rawurlencode($v);
}

//開啟一個socket
$fp = fsockopen($url['host'],$url_port);
if(!$fp) return "Failed to open socket to ".$url['host'];

//header的資訊
fputs($fp,'POST '.$url['path'].($url['query']?'?'.$url['query']:'')." HTTP/1.0rn");
fputs($fp,"Host: ".$url['host']."n");
fputs($fp,"Content-type: application/x-www-form-urlencodedn");
fputs($fp,"Content-length: ".strlen($encoded)."n");
fputs($fp,"Connection: closenn");
fputs($fp,$encoded."n");

//取得回應的內容
$line = fgets($fp,1024);
if(!eregi("^HTTP/1.. 200", $line)) return;
$results = "";
$inheader = 1;
while(!feof($fp)){
  $line = fgets($fp,2048);
  if($inheader&&($line == "n" || $line == "rn")){
    $inheader = 0;
  }elseif(!$inheader){
    $results .= $line;
  }
}

fclose($fp);
return $results;
}

php采用rails思想提交数据入库

 

最近一直在考虑一种更方便的数据提交规则,

 

就POST来说,通常我大部分数据都是POST的,这样通常都是获取POST数组然后过滤,然后处理后提交到数据库" title="数据库" >数据库,现在如果加入rails的思想提交数据,然后表单字段变量和POST数组中的字段名称一致,并且跟数据库" title="数据库" >数据库中的字段一样,这样就可以利用方法获取$_POST array中的key然后循环一下就可以不用写sql句" title="句" >句中的字段了,然后按照顺序$_POST中的value写进去就ok了,是不是一种很便捷的方法呢,在这个时代就是一个要求敏捷的时代.

 

SQL代码

CREATE TABLE `table` (   

  `id` int(255) unsigned NOT NULL auto_increment,   

  `username` varchar(255) NOT NULL default '',   

  `age` varchar(255) NOT NULL default '',   

  `address` varchar(255) NOT NULL default '',   

  PRIMARY KEY  (`id`)   

) TYPE=MyISAM AUTO_INCREMENT=1 ;  

 

PHP代码

<?php       

if(!emptyempty($_POST)){       

    foreach ($_POST as $key=>$val)       

        {       

            $sql.=$key.",";       

            $value.="'".$val."',";       

        }       

    sql" title="mysql" >mysql_connect("localhost","root","troysqlserver");       

    sql" title="mysql" >mysql_select_db("tryease");       

    sql" title="mysql" >mysql_query("INSERT INTO `table` (".substr($sql, 0, -1).")VALUES(".substr($value, 0, -1).")");       

    echo "INSERT INTO `table` (".substr($sql, 0, -1).")VALUES(".substr($value, 0, -1).")";       

}       

?>  

 

XML/HTML代码

<form action="" method="post">       

<input type="text" name="username" />       

<input type="text" name="age" />       

<input type="text" name="address" />       

<input type="submit" value="提交" />       

</form>  

这样做不过需要一些函数将一些数据处理,做过滤,做安全,然后才能提交到数据库" title="数据库" >数据库.

具体数据型转换,过滤等等,因涉及的数据字段不一样,所以大家就自行处理了.

这里只是提出一种思想.仅供大家参考.

ajax返回中文乱码,servlet中的显示乱码,post提交的乱码问题,编码大总结

ajax返回中文乱码问题解决
使用ajax获取服务器数据返回给客户端,出现中文乱码。在之前的一个ajax应用中指定codepage=936,将所有页面编码都指定为GB2312即可解决。
这 次的应用中却无起作用了,经过多次的试验,客服端的编码应该绝对没有问题的。可以判断问题一定出在服务器端。稍微分析一下可知虽然服务器端指定了文件的编 码格式,但对于服务器输出流就成为了怀疑的对象。 由于使用MS SQL2000,采用unicode编码,所以返回数据给客户端将会出现unicode编码的中文在gb2312编码页面显示的问题。于是在服务器端输出 流加一个HEADER:ASP程序中加入<%Response.Charset = "GB2312"%>即解决了这个问题。
同样在php和jsp程序中的书写类似
PHP:header('Content-Type:text/html;charset=GB2312');
JSP:response.setHeader("Charset","GB2312"); ajax产生乱码的原因整理如下
1、xtmlhttp 返回的数据默认的字符编码是utf-8,如果客户端页面是gb2312或者其它编码数据就会产生乱码
2、post方法提交数据默认的字符编码是utf-8,如果服务器端是gb2312或其他编码数据就会产生乱码
解决办法有:
1、若客户端是gb2312编码,则在服务器指定输出流编码
2、服务器端和客户端都使用utf-8编码JSP中,AJAX使用POST方式提交中文乱码问题解决

今天终于解决了AJAX的中文乱码问题,写篇文章来帮助一下有同样问题的朋友们。我的开发环境:XP, eclipse,使用GB18030编码。
当遇到这个问题时,到网上去查了好多文章,提到几种解决方案,如:全站UTF-8编码;请求头编码为中文;使用javascript中的escape函数。
使用GET方式提交数据的时候, 中文问题很好解决,setrequestheader("Content-Type","text/html; encoding=gb18030")就可以了。但这个方法在POST方式中却不起作用。大家都知道GET方式提交数据有长度限制,有时我们必须使用 POST方式来提交数据。
但对于POST方式,使用上述的几种方法经过多次测试,问题依旧。我郁闷了好几天。
今天把问题解决了,很简单,是使用escape(或encodeURI,两个函数javascript的函数,功能基本相同,可以查一下相关的帮助),但要使用两次,这是解决问题的关键。
我的例子涉及两个页面,一个是初始页面,一个是AJAX请求处理页面。
初始页面内容如下(hello.jsp):
/////////////////////////////////////////////////////////////////////////////////////
<%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>
<%String path = request.getContextPath();%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>AJAX提交页面</title>
 <meta http-equiv="Content-Type" content="text/html; charset=GB18030">
   <script type="text/javascript">
    function justdo(){
  var post="name=王&email=w@su.com&bokee=http://www.sjolzy.cn";
  post = encodeURI(post);
  post = encodeURI(post);//两次,很关键
  var xmlObj = new ActiveXObject('Msxml2.XMLHTTP');
  var URL = '<%= path%>/page/act.jsp';//文件名需要调整成测试时的相应位置?
  xmlObj.open ('post',URL,true);
  xmlObj.setrequestheader("cache-control","no-cache");
  xmlObj.setrequestheader("Content-Type","application/x-www-form-urlencoded");
  xmlObj.send (post);//注意:POST方式,使用这个来发送内容?
   }
   </script>
  </head> 
  <body>
  <input type="button" value="提交" onclick="justdo()"/>
   </body>
</html>
/////////////////////////////////////////////////////////////////////////////////////
ajax请求处理页面(act.jsp)的内容如下:
/////////////////////////////////////////////////////////////////////////////////////
<%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>
<%String path = request.getContextPath();%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<%@page import="java.net.URLDecoder"%>
<html>
  <head>
    <title>ajax deal</title>
 <meta http-equiv="pragma" content="no-cache">
 <meta http-equiv="cache-control" content="no-cache">
 <meta http-equiv="expires" content="0">   
  </head>
  <body>
  <%
  //遍历输出参数内容。
  for (Enumeration e = request.getParameterNames(); e.hasMoreElements();) {
   String h = (String) e.nextElement();
   String v = request.getParameter(h);
   String mm =  java.net.URLDecoder.decode(v, "UTF-8");
   System.out.println("请求参数: " + h + " = " + mm);
  }
   %>
  </body>
</html>
/////////////////////////////////////////////////////////////////////////////////////
分析:当调用request.getParameter()函数时,会自动进行一次URI的解码过程,调用时内置的解码过程会导致乱码出现。而URI编 码两次后,request.getParameter()函数得到的是原信息URI编码一次的内容。再用可控的解码函数 java.net.URLDecoder.decode()就可解出原始的正确的信息。
以上分析纯属个人看法,不知是否正确。
========================
最后是servlet的问题呵呵,功夫不负有心人啊!!终于搞明白了,很简单:  
  1)   JSP中只要加入   <%@   page   contentType="text/html;charset=GB2312"   language="java"   %>   就能正确提交中文了!  
  2)servlet中分别对  
                1)   response.setContentType("text/html;   charset=gb2312");  
                2)     request.setCharacterEncoding("gb2312");  
  就可以正确的输出,和读取中文了!!  
  那么现在的问题就是如果用了struts,他给我们提供的servlet并没有加入  
  1)   response.setContentType("text/html;   charset=gb2312");  
  2)     request.setCharacterEncoding("gb2312");  
  所以在他调用我们写的actionform的时候就不能正确读取中文了,而我们只能写action,力所不能及。  
  那么怎么才能修改servlet呢?学习中!  
  谢谢大家,有好的建议继续哦 
====================
转码代码
    public static String iso2gb(String str) {
        if (str=="") {
        return "";
        }        String result = "";        try {
        byte[] tmp = str.getBytes("ISO8859_1");
        result = new String(tmp, "UTF-8");
        } catch (Exception e) {
            System.out.println(e);
        }        return result;
    }
===========================
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
    request.setCharacterEncoding("UTF-8");
%>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <meta http-equiv="Content-Language" content="UTF-8" />

标签: gb2312, 编码, POST, AJAX

php与ajax的应用

1.创建xmlhttp对象时的问题。
创建xmlhttp对象在不同的浏览器中有不同的方法,在IE里好像只能用ActiveXObject创建,然而在Firefox等其他浏览器里就不行 了:(,但可以用XMLHttpRequest()函数创建,这样的不统一给程序员写程序带来了很大的难度,所以我认为在学习JS的过程中记录下这些不同 的地方很有必要,不然一个很有前途的程序很容易就会成为 "IE only" 的!!
下面是一个兼容的xmlhttp对象创建函数。以后就可以直接用这个函数创建xmlhttp对象,而不用担心兼容性问题了:D
[code]
function createAJAX()
{
var xmlhttp;
try { xmlhttp = new ActiveXObject("Msxml2.XMLHTTP"); }
catch (e1)
{
try { xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); }
catch (e2) { xmlhttp = null; }
}
if (!xmlhttp)
{
if (typeof XMLHttpRequest != "undefined") { xmlhttp = new XMLHttpRequest(); }
else return false;
}
return xmlhttp;
}
[/code]


2.AJAX的数据传输方式。
正如你知道的,AJAX支持以POST何GET方式传送数据。但你知道怎样正确使用他们吗?
GET:
GET是最常用的数据传输方式,就是将变量名和值直接跟在URL后面就可以了,同时这个也是最简单的方法。
比如: 调用的URL为 ajax.php?id=1,这样在ajax.php中的$_GET数组里就有 $_GET["id"] = 1; 如果有多个变量,则用"&"分开。
POST:
POST相对于GET来说要用得比较少一点,而且POST的用法比GET要麻烦一点。
首先,POST也跟GET一样,要先把变量名和值用"="和"&"符号连成一个字符串。 然后用 xmlhttp的 send 方法传送。而且要在send之前设置header。
[code]
var ajax = createAJAX(); //就是前面那个创建xmlhttp对象的函数
ajax.open("POST","ajax.php",true);
ajax.onreadystatechange = function1; //配置状态处理函数名,不能在后面加上"()"!!
ajax.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); //这句必须要,而且一定要放在send以前
ajax.send("变量1=值1&变量2=值2");
[/code]
用这种方法传送出去的值就和用表单的post方式传出的值一样。

还有一个非常重要的,不管用POST还是GET,都应特别注意"&","+"和"%"等特殊字符的问题。如果变量的值里面含有这些字符,那么后果 不堪设想。一个很好地解决办法就是使用encodeURIComponent这个全局函数来将所有的值都处理一遍(注意只是处理值),将特殊字符转换 成%XX的形式(和php里的urlencode貌似是一个功能)。但这个函数在IE5里不能用!

用POST方法传送数据的时候,xmlhttp.send()传出的所有东西在php里都可以在一个名叫"php://input"的特殊文件里读取到。 比如上面的那个代码,在ajax.php里用 file_get_contents("php://input") 就可以得到 "变量1=值1&变量2=值2"。 这是一个非常好的功能!这样我们就可以不用再使用"变量名=值"的方式了!也不用担心特殊字符! 将这个方法和GET结合起来就可以做一个AJAX的文章自动保存的程序。
[code]
var ajax = createAJAX();
ajax.open("POST","ajax.php?filename=a.txt",true);
ajax.onreadystatechange = function1;
//ajax.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); //如果不需要将send出的字符串解析成POST变量数据,那么这句就可以不用了
ajax.send("这里可以传送文件正文!!!!!");
[/code]
这样从ajax.php的$_GET数组中可以获得文件名,用 file_get_contents("php://input") 就可以获得文件正文,而且不用担心任何的特殊字符,同时也不用处理数据,减轻客户端压力。
[code]

sack.js文件说明:(代码附在最底下)
实体化对象:
var ajax = new sack("URL"); // URL为ajax调用地址

属性:( =默认值)
method = "GET"; //"GET"和"POST"或"GET&POST"
encodeURL = true; //是否处理参数值
late = true; //是否为异步方式
函数配置:
onLoading = 空函数; //当loading的时候触发
onLoaded = 空函数; //当下载完的时候触发
onInteractive = 空函数; //当交互的时候触发
onCompletion = 空函数; //当全部完成的时候触发
onError = 空函数; //当发生错误的时候触发
方法:
setVar 设置变量和值,可以以两种方式:setVar("varName","varValue"); 和 setVar( { "name1":"value1","name2":"value2"} );
send 发送,可以当method = "GET&POST" 的时候可以接受一个字符串作为 POST 的内容
当完成的时候才可用的属性(在onCompletion里可以使用):
response //返回的字符串
responseXML //返回的xml
[/code]

具体样例:
ajax.htm:
[code]
<div id='mydiv'>Loading...</div>
<script src='sack.js'></script>
<script>
var ajax = new sack("ajax.php");
ajax.method = "GET&POST";
ajax.setVar(
{
"action":"read",
"my":"posttdfsfdsfafasd"
});
ajax.onCompletion = function ()
{
document.getElementById('mydiv').innerHTML = ajax.response;
}

ajax.send("这里是POST出去的内容,可以有特殊字符&=等");
</script>
[/code]

ajax.php:
[code]
<?
$br = "<br/>---------------------------<br/>";
print_r($_GET);
echo $br;
print_r($_POST);
echo $br;
echo file_get_contents("php://input");
echo $br;
?>
[/code]

 

function sack(file) {

/*************************
/    小屋
/  //sjolzy.cn/post-182.html
/    www.sjolzy.cn
/     By sjolzy
*************************/

	this.xmlhttp = null;

	this.resetData = function() {
		this.method = "GET";
		this.URLString = "";
		this.encodeURL = true;
		this.file = file;
		this.late = true;
		this.failed = false;
  	};

	this.resetFunctions = function() {
  		this.onLoading = function() { };
  		this.onLoaded = function() { };
  		this.onInteractive = function() { };
  		this.onCompletion = function() { };
  		this.onError = function() { };
		this.encode = (encodeURIComponent && this.encodeURL)?function(s) {
			return encodeURIComponent(s);
		}:function(s){return s;}
	};

	this.reset = function() {
		this.resetFunctions();
		this.resetData();
	};

	this.createAJAX = function(){
		try {
			this.xmlhttp = new ActiveXObject("Msxml2.XMLHTTP");
		}catch (e1){
			try {
				this.xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
			} catch (e2) {
				this.xmlhttp = null;
			}
		}
		if (! this.xmlhttp) {
			if (typeof XMLHttpRequest != "undefined") {
				this.xmlhttp = new XMLHttpRequest();
			} else {
				this.failed = true;
			}
		}
	};

	this.setVar = function(name, value) {
		var arr1 = [], arr2 = [];
		if (typeof name == "object" && !value) {
			for(var i in name) {
				arr1[arr1.length] = i;
				arr2[arr2.length] = name[i];
			}
		}
		else {
			arr1[0] = name;
			arr2[0] = value;
		}
		var first = (this.URLString.length == 0);
		for(var i=0;i<arr1.length;i++) {
			this.URLString += (first)?"":"&";
			this.URLString += arr1[i] + "=" + this.encode(arr2[i]);
		}
	};

	this.send = function(content) {
		if (!content) content = "";
		if (!this.xmlhttp || this.failed ) {
			this.onError();
			return;
		}
		var self = this;
		if (this.method == "GET" || this.method == "GET&POST") {
			this.xmlhttp.open(this.method,this.file+"?"+this.URLString,this.late);
		} else if (this.method == "POST") {
			this.xmlhttp.open(this.method,this.file,this.late);
			try {
				this.xmlhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
			} catch(e) {}
		}
		else this.onError();

		this.xmlhttp.onreadystatechange = function() {
			switch (self.xmlhttp.readyState) {
				case 1:
					self.onLoading();
					break;
				case 2:
					self.onLoaded();
					break;
				case 3:
					self.onInteractive();
					break;
				case 4:
					self.response = self.xmlhttp.responseText;
					self.responseXML = self.xmlhttp.responseXML;
					if (self.xmlhttp.status == "200") {
						self.onCompletion();
					} else {
						self.onError();
					}
					self.URLString = "";
					break;
			}
		};
		
		if (this.method == "POST") {
			this.xmlhttp.send(this.URLString);
		} else if (this.method == "GET") {
			this.xmlhttp.send(null);
		} else if (this.method == "GET&POST") {
			this.xmlhttp.send(content);
		}
	};

	this.reset();
	this.createAJAX();
}