主要就是利用php 的 fsocketopen 消息传输。 这里先通过upload.html 文件提交,利用chrome抓包,可以看到几个关键的信息。

首先指定了表单类型为multipart/form-data;。
boundary是分隔符
因为上传文件不在使用原有的http协议了。请求内容不再可能以
x = y方式发送了。而使用了
分隔符
字段内容
分隔符号
字段内容2
而boundary就是指定分隔符号的标志。
请求的内容就应该是这样的了。

在来看下消息体

 

#socket_upload.php  拼接http上传协议格式 post请求 

<?php
class SOCKET_UPLOAD
{
private $host = '127.0.0.1';
private $port = 80;
private $errno = null;
private $errstr = null;
public $timeout = 30;
public $url = '/socket/socketupload/upload.php';//请求地址
private $fp = null;
private $header = ''; //头信息
private $body = ''; //消息体
private $boundary = '----abcdefg'; //指定分隔符号的标志
private $res = null; //完整字符串
private $file = null; //文件
private $form = null; //表单 public function __construct($form ='',$file='')
{
//连接本地80端口
$this->fp = fsockopen($this->host,$this->port,$this->errno,$this->errstr,$this->timeout);
if (!$this->fp)
exit('failed');
//赋值
$this->form = $form;
$this->file = $file; //设置头信息,消息体
$this->setHead();
$this->setBody(); //拼接整个请求信息
$this->getStr(); } public function write()
{
//echo $this->res;
//写入
fwrite($this->fp, $this->res); //打印输出信息
$response = '';
while($row=fread($this->fp, 4096)){
$response .= $row;
} fclose($this->fp); $pos = strpos($response, "\r\n\r\n");
$response = substr($response, $pos+4); echo $response;
} private function getStr()
{
$this->header .= "Content-Length:".strlen($this->body)."\r\n";
$this->header .= "Connection: close\r\n\r\n";
$this->res = $this->header.$this->body;
} //设置头信息
private function setHead()
{
$this->header .= "POST {$this->url} HTTP/1.1\r\n";
$this->header .= "HOST:{$this->host} \r\n";
$this->header .= "Content-Type:multipart/form-data; boundary={$this->boundary}\r\n";
} //设置消息体
private function setBody()
{
$this->form();
$this->file();
} //非文件表单
private function form()
{
if ($this->form && is_array($this->form))
{
foreach ($this->form as $key=>$val)
{ $this->body .= "--$this->boundary"."\r\n";
$this->body .= "Content-Disposition: form-data; name=\"{$key}\"\r\n";
$this->body .= "Content-type:text/plain\r\n\r\n";
$this->body .= "{$val}\r\n";
}
}
} //文件表单
private function file()
{
if ($this->file && is_array($this->file))
{
foreach ($this->file as $key=>$val)
{
$this->body .= "--$this->boundary"."\r\n";
$this->body .= "Content-Disposition: form-data; name=\"{$val['name']}\"; filename=\"{$val['filename']}\"\r\n";
$this->body .= "Content-Type: {$val['type']}\r\n\r\n";
$this->body .= file_get_contents($val['path'])."\r\n";
$this->body .= "--{$this->boundary}";
} }
} }
$form = [
'name'=>'lemon',
'age'=>'12'
]; $file = [
[
'name'=>'file',
'filename'=>'a.jpg',
'path'=>'a.jpg',
'type'=>'image/jpeg',
]
]; $upload = new SOCKET_UPLOAD($form,$file);
$upload->write();

#接收post请求并保存图片代码

<?php
defined('UPLOAD') or define('UPLOAD',dirname(__FILE__).'/upload'); if ($_FILES['file']['error'] == 0){ $name = $_POST['name'];
$age = $_POST['age']; echo 'name is:',$name,"<br/>age is:",$age."<br/>"; $file = $_FILES['file'];
$ext = strrchr($file['name'],'.'); $filename = $_SERVER["REQUEST_TIME"].$ext; if (move_uploaded_file($file['tmp_name'],UPLOAD.'/'.$filename)) {
echo '<img src="upload/'.$filename.'">';
} }

范例代码:http://files.cnblogs.com/files/loveyouyou616/socket.zip

php 利用http上传协议(表单提交上传图片 )的更多相关文章

  1. 基于Http原理实现Android的图片上传和表单提交

    版权声明:本文由张坤  原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/794875001483009140 来源:腾云阁  ...

  2. 如何用elementui去实现图片上传和表单提交,用axios的post方法

    下面是在vue搭建的脚手架项目中的组件component文件夹下面的upload.vue文件中的内容 <!--这个组件主要用来研究upload这个elementui的上传插件组件--> & ...

  3. 利用jquery.form.js实现将form提交转为ajax方式提交的方法(带上传的表单提交)

    提供一种方法就是利用jquery.form.js. (1)这个框架集合form提交.验证.上传的功能. 核心方法 -- ajaxForm() 和 ajaxSubmit() $('#myForm').a ...

  4. swift文件上传及表单提交

    var carData:NSMutableDictionary = NSMutableDictionary(); var request:NSMutableURLRequest = NSMutable ...

  5. ajax方式提交带文件上传的表单,上传后不跳转

    ajax方式提交带文件上传的表单 一般的表单都是通过ajax方式提交,所以碰到带文件上传的表单就比较麻烦.基本原理就是在页面增加一个隐藏iframe,然后通过ajax提交除文件之外的表单数据,在表单数 ...

  6. C# Winform利用POST传值方式模拟表单提交数据(Winform与网页交互)

    其原理是,利用winfrom模拟表单提交数据.将要提交的參数提交给网页,网页运行代码.得到数据.然后Winform程序将网页的全部源码读取下来.这样就达到windows应用程序和web应用程序之间传參 ...

  7. 文件上传---form表单,ajax,jquery,以及iframe无刷新上传 (processData,contentType讲解)

    服务端程序: import tornado.web import os IMG_LIST=[] class IndexHandler(tornado.web.RequestHandler): def ...

  8. thinkphp图片上传+validate表单验证+图片木马检测+缩略图生成

    目录 1.案例 1.1图片上传  1.2进行图片木马检测   1.3缩略图生成   1.4控制器中调用缩略图生成方法 1.案例 前言:在thinkphp框架的Thinkphp/Library/Thin ...

  9. PHP流式上传和表单上传(美图秀秀)

    最近需要开发一个头像上传的功能,找了很多都需要授权的,后来找到了美图秀秀,功能非常好用. <?php /** * Note:for octet-stream upload * 这个是流式上传PH ...

随机推荐

  1. Spark学习笔记6:Spark调优与调试

    1.使用Sparkconf配置Spark 对Spark进行性能调优,通常就是修改Spark应用的运行时配置选项. Spark中最主要的配置机制通过SparkConf类对Spark进行配置,当创建出一个 ...

  2. 搭建MySQL高可用负载均衡集群(收藏)

    https://www.cnblogs.com/phpstudy2015-6/p/6706465.html

  3. delphi WebBrowser的使用方法详解(五)-难点释疑

    网页代码:<SELECT id=fy onchange=TouchRefresh(1) name=fy> <OPTION selected value=15>每頁顯示15筆&l ...

  4. 网络虚拟化中的 offload 技术:LSO/LRO、GSO/GRO、TSO/UFO、RSS、VXLAN

    offload offload特性,主要是指将本来在操作系统协议栈中进行的一些数据包处理(如IP分片.TCP分片.重组.checksum校验等)放到网卡硬件中去做,降低系统 CPU 消耗,提高处理的性 ...

  5. python之列表操作

    1.列表的增操作(四种) append(object):append object to end,directly used on list insert(index,object):insert o ...

  6. 13.mysql基本查询

    1. 给表起个别名:但是,前面的也是需要进行修改的,否则会报错的: select * from s.name from students as s; 2. 为字段起别名 select s,name a ...

  7. Some facts about topological sort

    Definition: a topological sort of a DAG G is a sort such that for all edge (i,j) in G, i precedes j. ...

  8. leetcode953

    public class Solution { public bool IsAlienSorted(string[] words, string order) { string HumanDic = ...

  9. iTunes 错误 -50

    iTunes,给苹果安装软件,这个软件的体验这么差!!! 手机上基本打不开AppStore,用电脑iTunes,经常莫名其妙的错误代码冒出. 速度奇慢无比. error -50 打开iTunes -- ...

  10. webstorm使用

    1. 打开toolbar 2. 安装vue.js 3. 设置new vue file模板 <template> <div> <header-component/> ...