Javascript PHP GD使用Ajax实时编辑图像

Javascript PHP GD使用Ajax实时编辑图像,javascript,php,jquery,ajax,gd,Javascript,Php,Jquery,Ajax,Gd,我有一个表单,其中我发布了一些变量来生成图像文本、填充、背景图像和文本位置 <form id="form" action="img.php" method="post" name="form"> <label>text</label> <textarea name="text"></textarea> <label>Author</label> <input name="author"></in

我有一个表单,其中我发布了一些变量来生成图像文本、填充、背景图像和文本位置

<form id="form" action="img.php" method="post" name="form">
<label>text</label> <textarea name="text"></textarea>
<label>Author</label> <input name="author"></input>
<label>text padding</label> <input type="number" name="padding" min="10" max="200" value="30">
text-align:
<input type="radio" name="align" value="1"> left
<input type="radio" name="align" value="0" checked="yes"> center
<input type="radio" name="align" value="2"> right
<select name="background">
<option>- select image -</option>
<?php $range = range(0, 177);
foreach ($range as $key) { ?>
<option id="img" value="src/img<?php echo $key;?>.jpg">src/img<?php echo $key;?>.jpg</option>
<?php } ?>
</select>
<input class="btn btn-success" type="submit" value="submit"></input>
</form>

<div id="result"></div>
当我将这些变量发送到img.php文件时,脚本运行得非常好。我想在同一个页面上进行实时修改,就像使用ajax的图像编辑器一样,但是当我运行这个脚本时

<script type="text/javascript">
    $(document).ready(function(){
        // loader
        $().ajaxStart(function(){
            $('#loading').show();
            $('#result').hide();
        }).ajaxStop(function(){
            $('#loading').hide();
            $('#result').fadeIn('slow');
        });
        // post submit values
        $('#form').submit(function(){
            // ajax
            $.ajax({
                type: 'POST',
                url: $(this).attr('action'),
                data: $(this).serialize(),
                success: function(data) {
                    $('#result').html(data);
                }
            })
            return false;
        });

    })

</script>
html文件出现此错误,我无法获取图像:

����JFIF��>CREATOR: gd-jpeg v1.0 (using IJG JPEG v80), default quality ��C     $.' ",#(7),01444'9=82<.342��C     2!!22222222222222222222222222222222222222222222222222����"��   ���}!1AQa"q2���#B��R��$3br� %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz��������������������������������������������������������������������������� ���w!1AQaq"2�B���� #3R�br� $4�%�&'()*56789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz��������������������������������������������������������������������������?��'*���d^�~��N�7��dWF�E�����F�E!�8�QrG��H=y�+V�R�ei�ֳK����tX8����<����(R�ϥHaR�s �a��p���y�QbTe��_)�1���qW^�&� �73}��l�Ƴ��.`�E�-�-'#a�*ݏ�Zvךm��g^���&���ڄ�0"�tE��R]:I���U�\u�oNJ��o�a:T�%gF���s�?�*�Y���W�-�YL`���p2O_z�n��#�=:���l���T[��<�Y�6�̲/Ƹ�Ye�7����%W#��@���խm��d�s��o_�qQ�Ln���nC��'�ןҁ���/�� �������t�ޞ9N6�e��Ю?�dxN��Y�P+Ӧ��*�w���/���l�|�����?Z��6�q/�#c����d���Ȫ�͙N"/*�V���#4�������(1:��YF$�n=*��D H8ɦ%��R�I����AP~��օs������g �;FB���T� ��S��7kB�L�M�Gǿ4��_Ean��� ��S\����ߝ"<��U8>�ڬ"�+8�y��va�?Z��9�m��sO�wo���N    �HE���%eDY  ,�... and goes on...
如何使用ajax获取图像

谢谢

编辑

当我将这些变量提交到浏览器上的img.php窗口时,img.php工作正常,但它有点像在这里发布的扩展,下面是一个示例:

img.php

<?php 
require_once("functions.php");
header("Content-type: image/jpeg");

// Settings
$fontSize = 28;
$font = "./fonts/Oswald-Medium.ttf";
$fontlogo = "./fonts/Quicksand-Bold.otf";

$background = $_POST['background'];
$text = $_POST['text'];
$author = $_POST['author'];
$padding = $_POST['padding']; //from edges
$align = $_POST['align'];

.
.
etc
.
.

$md = md5($background).".jpg";
imagejpeg($im, './images/'.$md);
imagejpeg($im);
imagedestroy($im);
?>
ajax脚本的问题在于对这些变量进行实时编辑并在同一窗口上生成de图像。

img.php正在返回一个JPEG文件:

header("Content-type: image/jpeg");
...
imagejpeg($im, './images/'.$md);
imagejpeg($im);
imagedestroy($im);
直接访问img.php是有效的,因为您的浏览器会通过标头被告知需要一个JPEG文件,并呈现它接收到的数据

当通过AJAX访问img.php时,您告诉浏览器将输出视为文本,这就是它所做的:

$('#result').html(data);
由于要将图像保存到服务器,因此在通过AJAX调用时,只应返回图像的路径,而不应返回图像本身。然后,您可以告诉浏览器使用图像路径添加img元素:

$('#result').append($('<img>').attr('src', image_url));

您需要将php代码显示为well@cmorrisseyphp代码在这里发布是一种扩展,当我在img.php窗口中获得信息时,它运行良好,问题在于要加载的ajax脚本有两个答案,因此我的问题是确定您想要什么。你真的想将这些用户生成的图像保存到你的服务器上吗?@cmorrissey当然,它会将图像的最后修改保存在脚本img.php上,这就是为什么我要在实时中进行编辑,以确保这是我想要保存的版本:对不起,我的英语不好,hehethanks,我是新使用ajax和js的,image\u url必须位于一个变量上,并且数据取自image\u name之类的输入,对吗?例如:var image_url='/images/'+$'image_name'.val;