主要就是利用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. C#获取电脑硬件信息(CPU ID、主板ID、硬盘ID、BIOS编号)

    最近学习过程中,想到提取系统硬件信息做一些验证,故而对网上提到的利用.NET System.Management类获取硬件信息做了进一步的学习.验证.验证是分别在4台电脑,XP SP3系统中进行,特将 ...

  2. 批处理框架-spring Batch

    并发处理业务 数据量大,并发度高,要支持事物,回滚,并发机制.事务.并发.监控.执行等,并不提供相应的调度功能.因此,如果我们希望批处理任务定期执行,可结合 Quartz 等成熟的调度框架实现. 业务 ...

  3. css图片变色变暗变亮

    本文章向码农介绍css 图片变色变暗变亮 实例代码如下: <style> *{margin:0;padding:0;list-style:none;} img{border:1px sol ...

  4. 深度学习、图像识别入门,从VGG16卷积神经网络开始

    刚开始接触深度学习.卷积神经网络的时候非常懵逼,不知道从何入手,我觉得应该有一个进阶的过程,也就是说,理应有一些基本概念作为奠基石,让你有底气去完全理解一个庞大的卷积神经网络: 本文思路: 一.我认为 ...

  5. 详解 Facebook 田渊栋 NIPS2017 论文:深度强化学习研究的 ELF 平台

    这周,机器学习顶级会议 NIPS 2017 的论文评审结果已经通知到各位论文作者了,许多作者都马上发 Facebook/Twitter/Blog/ 朋友圈分享了论文被收录的喜讯.大家的熟人 Faceb ...

  6. 【C语言】09条件编译

    条件编译的概念;通常我们希望程序的其中一部分代码只有在满足一定的情况下才进行编译,否则不参与编译,(只有参与编译的代码最终才能被执行) 这就是条件编译; 基本用法; #if condication01 ...

  7. UnicodeEncodeError: 'gbk' codec can't encode character '\xa0' in position 263: i llegal multibyte sequence

    UnicodeEncodeError: 'gbk' codec can't encode character '\xa0' in position 263: illegal multibyte seq ...

  8. bootstrap file input 多图片上传编辑THINKPHP5

    {layout name="layout" title="文章添加" /} <form id="defaultForm" role=& ...

  9. apache配置修改

    1.如何设置请求等待时间   在httpd.conf里面设置:   TimeOut n   其中n为整数,单位是秒.     2. 3.如何使得apache监听在特定的端口   修改httpd.con ...

  10. Java Collection.sort 排序升序, 降序问题

    不多说,记住2点, 直接上代码(下面是降序): package mall; import java.util.ArrayList; import java.util.Collections; impo ...