主要就是利用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. JVM内部细节之二:偏向锁(Biased Locking)

    在前面一片文章<JVM内部细节之一:synchronized关键字及实现细节>中已经提到过偏向锁的概念,在理解什么是偏向锁前必须先理解什么是轻量级锁(Lightweight Locking ...

  2. ECCV 2018 | Bi-Real net:超XNOR-net 10%的ImageNet分类精度

    这项工作由香港科技大学,腾讯 AI lab,以及华中科技大学合作完成,目的是提升二值化卷积神经网络(1-bit CNN)的精度.虽然 1-bit CNN 压缩程度高,但是其当前在大数据集上的分类精度与 ...

  3. 小朋友学Python(2)

    本节学习python的第一个程序:输出“Hello World!”.咱们用两种方法实现 方法(一) 进入python环境,直接使用print方法   hello world.png 方法(二) 先编程 ...

  4. 学习MongoDB 八: MongoDB索引(索引限制条件)(二)

    一.简介 我们上一篇介绍了索引基本操作,通过db.collection.createIndex(keys, options)语法创建索引,我们继续介绍地理空间索引.索引的限制,使我们在MongoDB时 ...

  5. HTML|CSS之CSS选择器及样式

    知识内容: 1.CSS选择器 2.CSS常用样式 参考:http://www.cnblogs.com/yuanchenqi/articles/5977825.html 一.CSS选择器 1.基础选择器 ...

  6. os模块和sys模块,以及random模块

    os模块 os模块是与操作系统交互的一个接口 os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径 os.chdir("dirname") 改变当前脚本工 ...

  7. 0_Simple__simpleZeroCopy

    两种方法使用零拷贝内存做简单的向量加和,并评估 GPU 计算结果与 CPU 计算结果的差. ▶ 源代码 #include <stdio.h> #include <cuda.h> ...

  8. 模拟Vue之数据驱动1

    一.前言 Vue有一核心就是数据驱动(Data Driven),允许我们采用简洁的模板语法来声明式的将数据渲染进DOM,且数据与DOM是绑定在一起的,这样当我们改变Vue实例的数据时,对应的DOM元素 ...

  9. 11.使用ForwardAction实现页面屏蔽。

    转自:https://wenku.baidu.com/view/84fa86ae360cba1aa911da02.html 我们在jsp页面之间写链接总会是.../xxx.jsp,而如果我们想屏蔽掉具 ...

  10. UI5-文档-4.5-Controllers

    在这个步骤中,我们将文本替换为一个按钮,并在按钮被按下时显示“Hello World”消息.按钮的按下事件的处理是在视图的控制器中实现的. Preview A Say Hello button is ...